在之本文来源gao@daima#com搞(%代@#码@网&搞gaodaima代码前的文章中给大家带来了《带你一起了解PHP的错误类型和错误级别》,其中详细介绍了PHP中的错误类型和错误级别,本篇文章我们一起来看一下PHP中错误日志的配置和使用方法。希望对大家有帮助!
在我们之前的文章中,我们介绍了PHP错误的异常处理、错误类型还有错误级别,接下来我们来介绍一下PHP中错误日志的配置和使用方法。对于 PHP 开发者来说,一旦某个项目投入使用,应该立即将配置文件 php.ini 中的 display_errors
选项关闭,以免因为这些错误所透露的路径、数据库连接、数据表等信息而遭到黑客攻击。
但是任何一个项目在投入使用后,都难免会有错误出现,那么如何记录一些对开发者有用的错误报告呢?这时候我们可以在单独的文本文件中将错误报告作为日志记录。错误日志的记录,可以帮助开发人员或者管理人员查看系统是否存在问题。
如果需要将程序中的错误报告写入错误日志中,只要在 PHP 的配置文件中,将配置项 log_errors
开启即可。
错误报告默认会记录到 Web 服务器的日志文件里。当然也可以将错误日志记录到指定的文件中或发送到系统的 syslog也就是系统日志中,那接下来我们就分别来看一下吧。
使用指定文件记录错误报告日志
如果想使用自己指定的文件记录错误日志,一定要确保这个文件存放在文档根目录之外,以减少遭到攻击的可能。并且该文件一定要让 PHP 脚本具有写权限。首先我们需要将 php.ini 中的配置指令做如下修改:
-
log_errors = On
;决定日志语句记录的位置 -
log_errors_max_len = 1024
;设置每个日志项的最大长度 -
error_reporting = E_ALL
;将会向PHP报告发生的每个错误 -
display_errors = Off
;不显示满足上条 指令所定义规则的所有错误报告 -
error_log = /usr/local/error.log
;指定产生的 错误报告写入的日志文件位置
PHP 的配置文件按上面的方式设置完成以后,并重新启动 Web 服务器。这样,在执行 PHP 的任何脚本文件时,产生的所有错误报告都不会在浏览器中显示,而会记录在自己指定的错误日志中。
此外,不仅可以记录满足 error_reporting
所定义规则的所有错误,而且还可以使用 PHP 中的 error_log()
函数把错误信息发送到 web 服务器的错误日志或者到一个文件里。
error_log()
函数的原型如下所示:
error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] ) : bool
其中需要注意的是:
$message
表示需要记录的错误信息;$destination
表示目标,也就是错误消息被发送到的目的地。它的含义描述于以上,由 $message_type
参数所决定;$extra_headers
表示额外的头。当 $message_type
设置为 1 的时候使用。 该信息类型使用了 mail() 的同一个内置函数。
$message_type表示
设置错误应该发送到何处。可能的信息类型有以下几个:
-
0
:(默认值)将$message
发送到 PHP 的系统日志,使用操作系统的日志机制或者一个文件,取决于配置文件中 error_log 设置了什么; -