日期:2011-08-22 浏览次数:20570 次
今天发现php中,如果要记录fatal error的时候,可以实用一个不错的函数,
叫register_shutdown_function,小结如下:
register_shutdown_function可以让我们设置一个当执行关闭时可以被调用的另一个函数.也就是说当我们的脚本执行完成或意外死掉 导致PHP执行即将关闭时,我们的这个函数将会被调用.所以,我们可以使用在脚本开始处设置一个变量为false,然后在脚本末尾将之设置为true的方 法,让PHP关闭回调函数检查脚本完成与否. 如果我们的变量仍旧是false,我们就知道脚本的最后一行没有执行,因此它肯定在程序执行到某处死掉了;
例子如下:
- ?php
- $clean = false;
- function shutdown_func(){
- global $clean;
- if (!$clean){
- die("not a clean shutdown");
- }
- return false;
- }
- register_shutdown_function("shutdown_func");
- $a = 1;
- $a = new FooClass(); // 将因为致命错误而失败
- $clean = true;
- ?>
- 再来一个记录fatal error的例子
- function catch_fatal_error()
- {
- $last_error = error_get_last();
- // 检查是否属于fatal_error
- if(isset($last_error['type']) &&$last_error['type']==E_ERROR)
- {
- //相关的处理
- }
- }
- register_shutdown_function('catch_fatal_error');
注意的是;
1,register_shutdown_function()函数可重复调用,但执行的顺序与注册的顺序相同
2,如果在调用register_shutdown_function()函数之前有exit()函数调用,register_shutdown_function()函数将不能执行
3,PHP4后支持注册函数参数传递
4,在某些服务端,如Apache,当前目录在register_shutdown_function()函数中能够改变
5,register_shutdown_function()函数执行在headers发送之后