php error_log 函数的使用


Posted in PHP onApril 13, 2009

我们来大致了解一下error_log()函数。我们看下手册的解释:

error_log
(PHP 3, PHP 4, PHP 5)

bool error_log ( string message [, int message_type [, string destination [, string extra_headers]]] )
发送一个错误信息到Web服务器的错误日志,一个TCP的端口或者是一个文件。

[separator]

我们看它的参数,第一个参数message是消息内容,第二个参数type是消息类型,第三个参数是目标文件,第四个参数是其他的头信息。其实一般第四个参数都用不到,我们主要看前面三个参数,第二个参数是消息类型,包括0, 1, 2, 3等四种类型,0是默认的类型。四个类型的作用:

0
信息内容发送到PHP的系统日志记录,使用操作系统的自己的日志记录机制或一个文件,整个取决于php.ini中的配置选项error_log的内容。这是缺省选项。

1
把信息内容发送到一个邮件地址,第三个参数就是一个邮件地址,第四个参数是一个头信息发送邮件的,第二个类型使用mail()函数来发送邮件

2
消息通过PHP的调试服务器,远程的写入到某个PHP调试服务器上,当然,PHP在编译的时候--enable-debugger必须打开,另外,整个类型只是针对PHP 3有效

3
消息作为一个新行附加在一个目标文件中

其实对于我们来说,日志为了简便起见,一般直接使用类型3就比较合适了,把日志文件写到自己需要的文件中。

为了示例error_log()函数的简单使用,我们个例子说明。假设我们数据库抽象类使用PEAR::DB类,现在我想在程序中记录我们的程序是否有执行错误。那么我们使用error_log()来记录我们那些SQL语句执行错误或者失败了,至少我们的PEAR::DB类提供了 DB::isError() 方法来获取某个执行结果对象是否有错误,那么我们就能够旁断是否执行某条SQL出现了错误,再来考虑是否记录日志,同时对象有个userinfo的属性,该属性记录了错误的SQL语句,那么我们可以构造这样一个函数:

function logError($object)
{
 if(DB::isError($object))
 {
  error_log(date("[Y-m-d H:i:s]")." -[".$_SERVER['REQUEST_URI']."] :".$object -> userinfo."\n", 3, "/tmp/php_sql_err.log");
  return true;
 }
 return false;
}

这个函数就是能够记录发现了错误SQL的地方,那么自动会把时间,当前页面,和错误的SQL语句信息记录到 /tmp/php_sql_err.log 文件当中,那么,当我们在调试程序的时候,发现数据提取不正确或者没有数据提取的时候,那么我们完全可以查看 /tmp/php_sql_err.log 文件来查看我们的错误页面和错误的SQL语句。

当然,我们必须在我们执行SQL查询的程序中去使用这个函数,比如我们执行一个编写一个提取新闻信息的函数:

function getNewsContent($news_id, $field="")
{
 global $db;
 $result = $db->getRow("SELECT $field FROM news WHERE news_id = '$news_id'");
 if (logError($result))
 {
  return false;
 }
 return $result;
}

我们在里面判断SQL是否错误,如果错误了则返回false,然后我们就可以查看日志一下,看我们的函数运行是否如我们预期想象的一样。
我们执行: tail /tmp/php_sql_err.log
能看到类似于这样的信息:

[2006-01-12 11:44:34] -[/news_list.php?news_id=1] :SELECT  FROM news WHERE news_id = '1' [nativecode=1064 ** You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version fo
r the right syntax to use near 'FROM news WHERE news_id = '1']

大致是因为我们select的时候,没有把需要提取的字段名写进去,那么我们就可以检查news_list.php文件,减产 getNewsContent ()函数法向没有传递$field参数进去,导致SQL执行错误。所以error_log()函数就帮助检查我们的SQL写的是否正确,或者是参数没有传递正确,这样大大的减轻了开发负担,想但于了对我们的程序进行了单元测试。

当然,你也可以利用error_log()函数做更多记录错误日志,方便PHP开发,这个全是由自己决定。


本次工作中使用它来记简单的log日志
<code>
            $address    = post('address');
            $group_add  = explode(',',$address);

            $url   ="/usr/local/apache/eyoung/tmp/maillog_".date("Y-m-d").".log";

            foreach($group_add as $value)
            {
                    /** {{{ modify by muzhaoyang -2006.12.13- 记log
                      *  已空格分隔数据,记录的数据为写文本时间 拉票人ID 选手ID 发信地址
                      */
                      $logstr=date("H:i:s")." ".$uid." ".$star_uid." ".$value."\n";
                      error_log($logstr,3,$url);
                    //}}}
             }

</code>

PHP 相关文章推荐
PHP 函数语法介绍一
Jun 14 PHP
使用PHP 5.0创建图形的巧妙方法
Oct 12 PHP
用PHP实现小写金额转换大写金额的代码(精确到分)
Jan 10 PHP
php实现memcache缓存示例讲解
Dec 04 PHP
php中ftp_chdir与ftp_cdup函数用法
Nov 18 PHP
php树型类实例
Dec 05 PHP
php使用for语句输出三角形的方法
Jun 09 PHP
解析WordPress中的post_class与get_post_class函数
Jan 04 PHP
深入解析Laravel5.5中的包自动发现Package Auto Discovery
Sep 13 PHP
PHP中危险的file_put_contents函数详解
Nov 04 PHP
基于thinkphp5框架实现微信小程序支付 退款 订单查询 退款查询操作
Aug 17 PHP
PHP时间类完整代码实例
Feb 26 PHP
PHP Document 代码注释规范
Apr 13 #PHP
php pcntl_fork和pcntl_fork 的用法
Apr 13 #PHP
sourcesafe管理phpproj文件的补充说明(downmoon)
Apr 11 #PHP
php 动态执行带有参数的类方法
Apr 10 #PHP
PHP获取类中常量,属性,及方法列表的方法
Apr 09 #PHP
php 随机生成10位字符代码
Mar 26 #PHP
php SQL之where语句生成器
Mar 24 #PHP
You might like
PHP 彩色文字实现代码
2009/06/29 PHP
php 来访国内外IP判断代码并实现页面跳转
2009/12/18 PHP
PHP实现HTTP断点续传的方法
2015/06/17 PHP
WordPress免插件实现面包屑导航的示例代码
2020/08/20 PHP
使用户点击后退按钮使效三行代码
2007/07/07 Javascript
XMLHTTP 乱码的解决方法(UTF8,GB2312 编码 解码)
2011/01/12 Javascript
js原生态函数中使用jQuery中的 $(this)无效的解决方法
2011/05/25 Javascript
jQuery判断iframe中元素是否存在的方法
2013/05/11 Javascript
jquery select多选框的左右移动 具体实现代码
2013/07/03 Javascript
jquery click([data],fn)使用方法实例介绍
2013/07/08 Javascript
jquery判断复选框选中状态以及区分attr和prop
2015/12/18 Javascript
javascript移动开发中touch触摸事件详解
2016/03/18 Javascript
JS实现消息来时让网页标题闪动效果的方法
2016/04/20 Javascript
详解Node.js模块间共享数据库连接的方法
2016/05/24 Javascript
Angular2+国际化方案(ngx-translate)的示例代码
2017/08/23 Javascript
20170918 前端开发周报之JS前端开发必看
2017/09/18 Javascript
React中上传图片到七牛的示例代码
2017/10/10 Javascript
微信小程序调用摄像头隐藏式拍照功能
2018/08/22 Javascript
基于vue如何发布一个npm包的方法步骤
2019/05/15 Javascript
[06:10]6.81新信使新套装!给你一个炫酷的DOTA2
2014/05/06 DOTA
pytorch打印网络结构的实例
2019/08/19 Python
Python tkinter和exe打包的方法
2020/02/05 Python
python GUI库图形界面开发之PyQt5控件数据拖曳Drag与Drop详细使用方法与实例
2020/02/27 Python
在Pytorch中使用Mask R-CNN进行实例分割操作
2020/06/24 Python
Python 随机按键模拟2小时
2020/12/30 Python
阿联酋电子产品购物网站:Menakart
2017/09/15 全球购物
Dune London官网:英国著名奢华鞋履品牌
2017/11/30 全球购物
俄罗斯名牌服装网上商店:UNIQUE FABRIC
2019/07/25 全球购物
英国卫浴商店:Ergonomic Design
2019/09/22 全球购物
介绍一下javax.servlet.Servlet接口及其主要方法
2015/11/30 面试题
工作迟到检讨书
2014/02/21 职场文书
大一学生职业生涯规划
2014/03/11 职场文书
中等生评语大全
2014/05/04 职场文书
学院党的群众路线教育实践活动第一阶段情况汇报
2014/10/25 职场文书
销售助理岗位职责
2015/02/11 职场文书
教师节主持词开场白
2015/05/29 职场文书