网上关于log4php配置的文章很多,下面是我的配置,跟网上部分略有不同

(1)添加日志
    1.下载log4php,到官网就可以下载到,下载后解压
    我的版本是log4php_2.3.0
    官网地址:http://logging.apache.org/log4php/changelog.html
    2.在项目中使用log4php
            工程的目录结构如下:

(1)include文件夹:包含第三方库的引用

(2)images文件夹:包含网站的图片

(3)js文件夹:包含网站的脚本文件

(4)css文件夹:包含网站的样式表

在include文件下,建立log4php目录,然后将刚才解压的log4php目录下的src文件夹下的log4php文件夹拷贝到该目录下,如下图所示:

其中多出来的log目录是之后的日志文件存放的位置

(3).

创建log4php.properties的配置文件

  1. log4php.rootLogger=DEBUG, A1
  2. log4php.appender.A1=LoggerAppenderRollingFile
  3. log4php.appender.A1.file=webdisk.log
  4. log4php.appender.A1.layout=LoggerLayoutTTCC
  5. log4php.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] %C{1}:%M %p %m%n
  6. log4php.appender.A1.MaxFileSize=1024
  7. log4php.appender.A1.MaxBackupIndex=3
 网上大多数这个时候配置就结束了,然而配置并没有结束
    还有一个配置文件log_conf.xml
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <log4php:configuration xmlns:log4php="http://logging.apache.org/log4php/" threshold="all">
  3. <appender name="default" class="LoggerAppenderDailyFile">
  4. <layout class="LoggerLayoutPattern" >
  5. <param name="conversionPattern" value="%date{Y-m-d H:i:s} %logger %msg%n" />
  6. </layout>
  7. <param name="file" value="D:/servers/phpweb/edu_system/log/data.%s.txt" />
  8. </appender>
  9. <appender name="dblog" class="LoggerAppenderDailyFile">
  10. <layout class="LoggerLayoutPattern">
  11. <param name="conversionPattern" value="%date{Y-m-d H:i:s} %logger %msg%n" />
  12. </layout>
  13. <param name="file" value="D:/servers/phpweb/edu_system/tpssdb.%s.txt" />
  14. </appender>
  15.  
  16. <logger name="db\PdoDB">
  17. <level value="DEBUG" />
  18. <appender_ref ref="dblog" />
  19. </logger>
  20. <root>
  21. <level value="DEBUG" />
  22. <appender_ref ref="default" />
  23. </root>
  24. </log4php:configuration>
打开apache服务器,访问test_log.php
浏览器结果:
 
 
 发现多了个文件夹log,log下多了个文件
(5)将之前的actSQL.class.php类加入logger
 代码部分如下:
  1. function insertData($objstr,$tablename)
  2. {
  3. $dbc=$this->conData();
  4. if($dbc)
  5. {
  6. $columnname=array();
  7. $columnname=$this->getColumns($tablename);
  8. //echo $columnname[0];
  9. $clos=implode(',',$columnname); //将列名数组转换为字符串
  10. $this->logger->debug(__LINE__ .' '.'列名字符串:'.$cols);
  11. //echo $clos;
  12. $this->logger->debug(__LINE__ .' '.'列名数组字符串:'.$clos);
  13. $data=json_decode($objstr,true); //将json格式的字符串转换为关联数组
  14. //echo $value['keychartname'];
  15. $values=array();
  16. foreach($columnname as $value)
  17. {
  18. //安装查询到的列名查询数据,数据为空的,赋值为NULL,防止数据库插入数值错位
  19. //echo $data[$value]."<br>";
  20. if(isset($data[$value]))
  21. {
  22. array_push($values,$data[$value]);
  23. }else{
  24. $data[$value]=NULL;
  25. array_push($value,$data[$value]);
  26. }
  27. }
  28. $strvalue=implode(',',$values);
  29. //echo $strvalue;
  30.  
  31. /*
  32. * SQL: insert into $tablename($clos) values(...)
  33. */
  34. $sql=<<<SQL
  35. insert into $tablename($clos) values($strvalue);
  36. SQL;
  37. //echo $sql;
  38. $this->logger->debug(__LINE__ .' '.'insert语句:'.$sql);
  39. $res=mysqli_query($dbc,$sql);
  40. if($res)
  41. {
  42. $this->logger->debug(__LINE__ .' '.'插入成功!');
  43. return true;
  44.  
  45. }else{
  46. $this->logger->debug(__LINE__ .' '.'插入失败!');
  47. return false;
  48. }
  49. }else{
  50. $this->logger->debug(__LINE__ .' '.'连接数据库失败,错误信息:'.mysqli_connect_error($dbc));
  51. }
  52. }

后台调试简单了许多,下面是日志部分截图

大功告成!

 
 

log4php的配置的更多相关文章

  1. PHP日志 LOG4PHP 的配置与使用

    维护了 一个老项目, 没有日志功能, 就给加了这个log4php,  主要是集成进去很简单,使用起来也够用了. 1.下载log4php 2.创建配置文件 log4php_config.xml < ...

  2. Log4PHP 配置和使用

    Log4PHP2.3.0使用解释 1. 什么是Log4PHP Log4php它为apche组织维护项目,是Log4xx系列日志组件之一,log4j在JAVA中可算是大名鼎鼎的日志开发包.Log4PHP ...

  3. log4php的使用方法与详细配置

    log4php的使用 首先引入logger.php文件.log4php可以通过引入logger.php来完成自动加载的过程.文件位置如下: 日志记录器自身没有定义日志的输出目的地和格式,所以我们通常需 ...

  4. log4php使用及配置

    log4php使用及配置 1.在项目中加入log4php包 2.log4php配置 在项目配置包中添加logger_config.xml配置文件: logger_config.xml配置文件添加代码如 ...

  5. Log4PHP日志库使用

    库下载地址: http://logging.apache.org/log4php/download.html 当前测试使用的版本为2.3.0 1.解压缩下载的压缩文件apache-log4php-2. ...

  6. 配置android sdk 环境

    1:下载adnroid sdk安装包 官方下载地址无法打开,没有vpn,使用下面这个地址下载,地址:http://www.android-studio.org/

  7. Android Studio配置 AndroidAnnotations——Hi_博客 Android App 开发笔记

    以前用Eclicps 用习惯了现在 想学学 用Android Studio 两天的钻研终于 在我电脑上装了一个Android Studio 并完成了AndroidAnnotations 的配置. An ...

  8. react-router 组件式配置与对象式配置小区别

    1. react-router 对象式配置 和 组件式配置    组件式配置(Redirect) ----对应---- 对象式配置(onEnter钩子) IndexRedirect -----对应-- ...

  9. 总结:Mac前端开发环境的搭建(配置)

    新年新气象,在2016年的第一天,我入手了人生中第一台自己的电脑(大一时好友赠送的电脑在一次无意中烧坏了主板,此后便不断借用别人的或者网站的).macbook air,身上已无分文...接下来半年的房 ...

随机推荐

  1. G-FAQ – Why is Bit Depth Important?

    直接抄: https://apollomapping.com/2012/August/article15.html For this month’s Geospatial Frequently Ask ...

  2. json 对象 字符串 转换

    json字符串转json对象:jQuery.parseJSON(jsonStr); json对象转json字符串:JSON.stringify(jsonObj);

  3. js自适应屏幕高度

    //自适应屏幕高度 $(window).resize(function() { hightChange(); }); function hightChange(){ ; $();// iframe i ...

  4. OC中的extern,static,const

    const的作用: const仅仅用来修饰右边的变量(基本数据变量p,指针变量*p). 被const修饰的变量是只读的. static的作用: 修饰局部变量: 1.延长局部变量的生命周期,程序结束才会 ...

  5. Java Web 学习链接

    解决JSP中文乱码问题:http://www.cnblogs.com/chengkai/articles/2171848.html 编程思想之多线程与多进程:http://blog.csdn.net/ ...

  6. CMake命令/函数汇总(翻译自官方手册)

    查看官方文档 cmake命令 选项 CMake变量 CMake命令汇总 / add_custom_command add_custom_target/add_definitions/add_depen ...

  7. java基础 集合 ArrayList 增删改除

    import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import ...

  8. 双系统Ubuntu分区扩容过程记录

    本人电脑上安装了Win10 + Ubuntu 12.04双系统.前段时间因为在Ubuntu上做项目要安装一个比较大的软件,导致Ubuntu根分区的空间不够了.于是,从硬盘又分出来一部分空间,分给Ubu ...

  9. HeapSort 堆排序 基于伪代码实现

    此文原创, http://www.cnblogs.com/baokang/p/4735431.html ,禁止转载 GIF 动态图 伪代码 /* From Wikipedia, the free en ...

  10. EF框架的三种工作方式

    EF框架step by step(1)—Database-First EF框架step by step(2)—Model-First EF框架step by step(3)—Code-First 通过 ...