php error_log 函数的使用

 2025-01-16  阅读 438  评论 8  点赞 104

摘要:我们来大致了解一下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的端口或者是一个文件

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

php 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>



标签:phpphp教程

评论列表:

  •   danney
     发布于 3天前回复该评论
  • 写的很不错,学到了!
显示更多评论

发表评论:

管理员

承接各种程序开发,外贸网站代运营,外贸网站建设等项目
  • 内容2460
  • 积分67666
  • 金币86666

Copyright © 2024 LS'Blog-保定PHP程序员老宋个人博客 Inc. 保留所有权利。 Powered by LS'blog 3.0.3

页面耗时0.0275秒, 内存占用1.95 MB, 访问数据库31次

冀ICP备19034377号