我如何打开所有错误和警告,并将它们记录到一个文件,但要在脚本中设置所有这些(不改变php.ini中的任何内容)?
我想定义一个文件名,以便将所有错误和警告都记录到其中。
我如何打开所有错误和警告,并将它们记录到一个文件,但要在脚本中设置所有这些(不改变php.ini中的任何内容)?
我想定义一个文件名,以便将所有错误和警告都记录到其中。
当前回答
看看php.ini中的log_errors配置选项。它似乎只做你想做的事。我认为您也可以使用error_log选项来设置您自己的日志文件。
当log_errors指令设置为On时,PHP报告的任何错误都将被记录到服务器日志或error_log指定的文件中。如果需要,你也可以用ini_set来设置这些选项。
(请注意,如果该选项被启用,在php.ini中应该禁用display_errors)
其他回答
看看php.ini中的log_errors配置选项。它似乎只做你想做的事。我认为您也可以使用error_log选项来设置您自己的日志文件。
当log_errors指令设置为On时,PHP报告的任何错误都将被记录到服务器日志或error_log指定的文件中。如果需要,你也可以用ini_set来设置这些选项。
(请注意,如果该选项被启用,在php.ini中应该禁用display_errors)
See
error_log -在某处发送错误消息
例子
error_log("You messed up!", 3, "/var/tmp/my-errors.log");
您可以使用自己的错误处理程序定制错误处理,以便在发生错误或警告或需要记录的任何事情时为您调用此函数。 有关更多信息,请参阅PHP手册中的章节错误处理
在.htaccess文件中添加以下代码(作为php.ini文件或ini_set函数的替代):
<IfModule mod_php5.c>
php_flag log_errors on
php_value error_log ./path_to_MY_PHP_ERRORS.log
# php_flag display_errors on
</IfModule>
如上所述:这是针对apache类型的服务器,而不是Nginx或其他服务器。
这是我个人的简短函数
# logging
/*
[2017-03-20 3:35:43] [INFO] [file.php] Here we are
[2017-03-20 3:35:43] [ERROR] [file.php] Not good
[2017-03-20 3:35:43] [DEBUG] [file.php] Regex empty
mylog ('hallo') -> INFO
mylog ('fail', 'e') -> ERROR
mylog ('next', 'd') -> DEBUG
mylog ('next', 'd', 'debug.log') -> DEBUG file debug.log
*/
function mylog($text, $level='i', $file='logs') {
switch (strtolower($level)) {
case 'e':
case 'error':
$level='ERROR';
break;
case 'i':
case 'info':
$level='INFO';
break;
case 'd':
case 'debug':
$level='DEBUG';
break;
default:
$level='INFO';
}
error_log(date("[Y-m-d H:i:s]")."\t[".$level."]\t[".basename(__FILE__)."]\t".$text."\n", 3, $file);
}
使用以下代码:
ini_set("log_errors", 1);
ini_set("error_log", "/tmp/php-error.log");
error_log( "Hello, errors!" );
然后看文件:
tail -f /tmp/php-error.log
或者从2008年开始更新这个博客条目中描述的php.ini。