我需要捕捉一些警告从一些php本机函数抛出,然后处理它们。
具体地说:
array dns_get_record ( string $hostname [, int $type= DNS_ANY [, array &$authns [, array &$addtl ]]] )
当DNS查询失败时,它抛出一个警告。
Try /catch不起作用,因为警告不是异常。
我现在有两个选择:
set_error_handler似乎是多余的,因为我必须使用它来过滤页面中的每个警告(这是真的吗?);
调整错误报告/显示,这样这些警告就不会显示在屏幕上,然后检查返回值;如果为假,则没有找到主机名的记录。
这里的最佳实践是什么?
我想尝试/捕捉一个警告,但同时保持通常的警告/错误日志(例如在/var/log/apache2/error.log);处理程序必须返回false。然而,由于"throw new…"语句基本上会中断执行,因此必须使用"wrap in function"技巧,也在下面讨论过:
在php中有一种静态的方法来抛出异常吗
或者,简单地说:
function throwErrorException($errstr = null,$code = null, $errno = null, $errfile = null, $errline = null) {
throw new ErrorException($errstr, 0, $errno, $errfile, $errline);
}
function warning_handler($errno, $errstr, $errfile, $errline, array $errcontext) {
return false && throwErrorException($errstr, 0, $errno, $errfile, $errline);
# error_log("AAA"); # will never run after throw
/* Do execute PHP internal error handler */
# return false; # will never run after throw
}
...
set_error_handler('warning_handler', E_WARNING);
...
try {
mkdir($path, 0777, true);
} catch (Exception $e) {
echo $e->getMessage();
// ...
}
编辑:经过仔细检查,发现它不起作用:“return false && throwErrorException…”基本上不会抛出异常,而只是记录错误日志;删除"false &&"部分,如在"return throwErrorException…"中,将使异常抛出工作,但将不会记录error_log…尽管如此,我仍然会把这篇文章贴在网上,因为我还没有在其他地方看到这种行为的记录。
小心使用@操作符——虽然它抑制了警告,但也抑制了致命错误。我花了很多时间调试系统中的一个问题,其中有人写了@mysql_query('…’),问题是mysql支持没有加载到PHP中,它抛出了一个无声的致命错误。它对于PHP核心的一部分是安全的,但请谨慎使用。
bob@mypc:~$ php -a
Interactive shell
php > echo @something(); // this will just silently die...
没有进一步的输出-祝你调试好运!
bob@mypc:~$ php -a
Interactive shell
php > echo something(); // lets try it again but don't suppress the error
PHP Fatal error: Call to undefined function something() in php shell code on line 1
PHP Stack trace:
PHP 1. {main}() php shell code:0
bob@mypc:~$
这次我们可以看到为什么它失败了。