自制模仿apache访问日志文件格式的php日志类
2024-08-28 11:55:17
<?php
// 访问日志写入类 @author 王伟 2011.12.14
class Log{
//项目跟路径
private $root_path;
//日志文件绝对路径
private static $log_file_path;
function __construct($root_path){
$this->root_path = $root_path.DIRECTORY_SEPARATOR;
self::$log_file_path = $this->root_path .'logfile'.DIRECTORY_SEPARATOR .date('Y_m_d',time()).'.log';
}
// 获取访问者ip地址
private static function getRealIp(){
$ip = false;
if (!empty($_SERVER["HTTP_CLIENT_IP"])){
$ip = $_SERVER["HTTP_CLIENT_IP"];
}
if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])){
$ips = explode (", ", $_SERVER['HTTP_X_FORWARDED_FOR']);
if ($ip){
array_unshift($ips, $ip);
$ip = false;
}
for ($i = 0; $i < count($ips); $i++){
if (!eregi ("^(10|172\.16|192\.168)\.", $ips[$i])){
$ip = $ips[$i];
break;
}
}
}
return ($ip ? $ip : $_SERVER['REMOTE_ADDR']);
}
// 写访问日志
public function writeLog(){
//浏览当前页面的用户的主机名
$uhost = (isset($_SERVER['REMOTE_HOST']) ? $_SERVER['REMOTE_HOST'] : '-');
//请求时间
$rtime = date('Y-m-d H:i:s',$_SERVER['REQUEST_TIME']);
//请求类型
$rmethod = $_SERVER['REQUEST_METHOD'];
//请求来路
$ref = (isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '-');
//请求协议类型
$rprotocol = $_SERVER['SERVER_PROTOCOL'];
//请求浏览器的用户浏览器信息
$ragent = empty($_SERVER['HTTP_USER_AGENT']) ? 'Unknown' : $_SERVER['HTTP_USER_AGENT'];
$durl = $_SERVER['REQUEST_URI'];
$logStr = self::getRealIp() .' '.$uhost.' '.$rtime.' "'.$rmethod.' '.$ref.' '.$rprotocol.'" '.$ragent.' '.$durl."\r\n";
if(!file_exists($this->root_path .'logfile')){
mkdir($this->root_path .'logfile');
}
$flog = fopen(self::$log_file_path,'a');
fwrite($flog,$logStr);
fclose($flog);
}
}
?>
<?php
// 使用说明
// 在new Log类时传入想要生成日志文件的所在目录的绝对路径(注:不含末尾的 "/")
//会在这个目录下创建 logfile目录,并每天按日期命名生成一个访问日志文件
$log = new Log(想要生成日志文件的所在目录的绝对路径);
$log->writeLog();
?>
最新文章
- js图片前端预览之 filereader 和 window.URL.createObjectURL
- 【译】Spring 4 @PropertySource和@Value注解示例
- atomic vs. nonatomic
- [转]Android各大网络请求库的比较及实战
- Ewebeditor最新漏洞及漏洞大全
- SQL Server 中创建数据库、更改主文件组示例
- strpos、 strstr、 substr三个函数的对比讲解
- js求和运算在可变参数的情况下ES3、ES5和ES6的写法区别
- 关于UTF-8和GBK编码的转换
- 小T牛 绿色版 18.08.0100
- js自动运行
- THINKPHP5近期暴露的漏洞
- Linux(CentOS6)系统安装Windows字体
- Tacacs+认证详细调研
- js高级-闭包
- input type=&#39;number&#39;时,maxlength属性无效
- linux网络编程框架
- 在linux下安装eclipse以及运行c++程序的安装步骤
- Calibre 3.4版中,为epub书籍嵌入中文字体
- luogu 1360 阵容均衡(前缀和+差分+hash)
热门文章
- 前端之jQuery03 插件
- mysql数据库( 基础篇加破解)
- 【vs2013】如何在VS的MFC中配置使用GDI+?
- 《DSP using MATLAB》示例Example7.18
- ES6常用知识总结(20%的知识占80%的份额)
- tomcat部署去掉项目名称
- Aix之 xmanager 2.0连接AIX服务器
- Hadoop体系结构之 Yarn
- Excel 2007 打开 UTF-8 编码 CSV 文件的乱码BUG
- Linux yum操作时出现Error: xz compression not available