PHP错误日志的配置和小技巧
我们可以在单独的文本文件中将错误报告作为日志记录。错误日志的记录,可以帮助开发人员或者管理人员查看系统是否存在问题。如果需要将程序中的错误报告写入错误日志中,只要在 PHP 的配置文件中,将配置项 log_errors 开启即可。 错误报告默认会记录到 Web 服务器的日志文件里,例如记录到 Apache 服务器的错误日志文件 error.log 中。当然也可以将错误日志记录到指定的文件中或发送到系统的 syslog(系统日志)中,下面来分别介绍一下。 1、使用指定的文件记录错误报告日志 如果想使用自己指定的文件记录错误日志,一定要确保这个文件存放在文档根目录之外,以减少遭到攻击的可能。并且该文件一定要让 PHP 脚本具有写权限。假设在 Linux 操作系统中,将 /usr/local/ 目录下的 error.log 文件作为错误日志文件,并设置 Web 服务器进程用户具有写的权限。然后在 PHP 的配置文件中,将 error_log 指令的值设置为这个错误日志文件的绝对路径。 需要将 php.ini 中的配置指令做如下修改: error_reporting = E_ALL // 将会向PHP报告发生的每个错误 此外,不仅可以记录满足 error_reporting 所定义规则的所有错误,而且还可以使用 PHP 中的 error_log() 函数把错误信息发送到 web 服务器的错误日志或者到一个文件里。 error_log() 函数的原型如下所示: error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] ) : bool 参数说明如下:$message:需要记录的错误信息; $message_type:设置错误应该发送到何处。可能的信息类型有以下几个: 0:(默认值)将 $message 发送到 PHP 的系统日志,使用操作系统的日志机制或者一个文件,取决于配置文件中 error_log 设置了什么; 1:将 $message 发送到参数 $destination 设置的邮件地址。 第四个参数 $extra_headers 只有在这个类型里才会被用到; 2:(已废弃)不再是一个选项; 3:$message 被发送到位置为 $destination 的文件里。字符 $message 不会默认被当做新的一行; 4:将 $message 直接发送到 SAPI 的日志处理程序中。 $destination:目标,也就是错误消息被发送到的目的地。它的含义描述于以上,由 $message_type 参数所决定; $extra_headers:额外的头。当 $message_type 设置为 1 的时候使用。 该信息类型使用了 mail() 的同一个内置函数。 (编辑:随州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |