我如何打开所有错误和警告,并将它们记录到一个文件,但要在脚本中设置所有这些(不改变php.ini中的任何内容)?
我想定义一个文件名,以便将所有错误和警告都记录到其中。
我如何打开所有错误和警告,并将它们记录到一个文件,但要在脚本中设置所有这些(不改变php.ini中的任何内容)?
我想定义一个文件名,以便将所有错误和警告都记录到其中。
当前回答
使用以下代码:
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。
其他回答
使用以下代码:
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。
这些答案中没有一个提到敏捷团队的重要性或相关性;专业级别的开发工作通常不是在一个团队的范围内完成的。
请记住,许多开发团队使用任务跟踪工具,如JIRA,我更喜欢使用时间戳将每个错误记录为一个单独的文件:
error_reporting(E_ALL);
ini_set('log_errors', 1);
ini_set('error_log', $_SERVER['DOCUMENT_ROOT'] . '/logs/php/php-errors-' . time() . '.txt');
使用这种方法,项目经理或团队负责人可以很容易地将每个错误隔离为一个特定的文件,然后将该文件附加到一个唯一的JIRA缺陷,分配给开发人员,并跟踪(时间戳可以链接到缺陷内部,以便在缺陷修复正在进行时轻松跟踪)。当问题解决后,可以从日志目录中删除该文件,而在JIRA中可以访问该文件的副本(如果将来需要的话)。
简单地把这些代码放在PHP/index文件的顶部:
error_reporting(E_ALL); // Error/Exception engine, always use E_ALL
ini_set('ignore_repeated_errors', TRUE); // always use TRUE
ini_set('display_errors', FALSE); // Error/Exception display, use FALSE only in production environment or real server. Use TRUE in development environment
ini_set('log_errors', TRUE); // Error/Exception file logging engine.
ini_set('error_log', 'your/path/to/errors.log'); // Logging file path
看看php.ini中的log_errors配置选项。它似乎只做你想做的事。我认为您也可以使用error_log选项来设置您自己的日志文件。
当log_errors指令设置为On时,PHP报告的任何错误都将被记录到服务器日志或error_log指定的文件中。如果需要,你也可以用ini_set来设置这些选项。
(请注意,如果该选项被启用,在php.ini中应该禁用display_errors)
此外,你需要“AllowOverride Options”指令来实现这个功能。(Apache 2.2.15)