如果使用PHP来写一个后台程序,可能会考虑在程序中将标准输入、标准输出、标准错误给重定向,这样就不需要在启动程序的时候来做重定向(因为这样很容易忘记);在C中有比较正规的写法,但是PHP中没有找见对应的实现,今天想到一个变通的办法:
1. 使用ob_start(function); 来设置自定义的输出过滤器
2. 使用set_error_handler(function); 来实现自定义的标准错误处理器
然后,在自定义函数中就可以随意处理了,实例:
- <?php
- function my_stdout_handler($string) {
- file_put_contents("4.log", $string, FILE_APPEND);
- return ”;
- }
- function my_error_handler($errno, $errstr, $errfile, $errline) {
- if (!(error_reporting() & $errno)) {
-
- return;
- }
- switch ($errno) {
- case E_USER_ERROR:
- echo "<b>My ERROR</b> [$errno] $errstr<br />\n";
- echo " Fatal error on line $errline in file $errfile";
- echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />\n";
- echo "Aborting…<br />\n";
- exit(1);
- break;
- case E_USER_WARNING:
- echo "<b>My WARNING</b> [$errno] $errstr<br />\n";
- break;
- case E_USER_NOTICE:
- echo "<b>My NOTICE</b> [$errno] $errstr<br />\n";
- break;
- default:
- echo "Unknown error type: [$errno] $errstr<br />\n";
- break;
- }
-
- return true;
- }
- ob_start(my_stdout_handler);
- set_error_handler(my_error_handler);
- print_r(ob_list_handlers());
- trigger_error("something wrong", E_USER_WARNING);
|
<?php function my_stdout_handler($string) { file_put_contents("4.log", $string, FILE_APPEND); return ''; } function my_error_handler($errno, $errstr, $errfile, $errline) { if (!(error_reporting() & $errno)) { // This error code is not included in error_reporting return; } switch ($errno) { case E_USER_ERROR: echo "<b>My ERROR</b> [$errno] $errstr<br />\n"; echo " Fatal error on line $errline in file $errfile"; echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />\n"; echo "Aborting...<br />\n"; exit(1); break; case E_USER_WARNING: echo "<b>My WARNING</b> [$errno] $errstr<br />\n"; break; case E_USER_NOTICE: echo "<b>My NOTICE</b> [$errno] $errstr<br />\n"; break; default: echo "Unknown error type: [$errno] $errstr<br />\n"; break; } /* Don't execute PHP internal error handler */ return true; } ob_start(my_stdout_handler); set_error_handler(my_error_handler); print_r(ob_list_handlers()); trigger_error("something wrong", E_USER_WARNING); |