利用php的register_shutdown_function来记录php的输出日志
2014-09-18 19:35
337 查看
最近在做的一个项目..由于全是通过远程http请求来调用php的接口程序..
接收到的参数和返回的内容对开发人员来说都是未知不可见的..
虽然可以通过直接在脚本中模拟请求..但由于实际环境复杂的多..调试极其不方便.
于是想是否可以写一个函数用来记录对php接口调用的情况.
想到以前看到过的一个php函数register_shutdown_function..
该函数的作用是注册一个函数,当php脚本执行完成,或者代码中调用了exit ,die这样的代码之后,执行预先注册好的函数.
这样我们就可以在该函数中记录php调用执行的情况了.
简单写了下,看起来应该可以用了
?
需要调用时 包含此文件执行bdebug() 即可.当php被调用时,会在该文件同目录下生成日志文件
用以记录调用的相关信息.
我这里只记录了 request ,server 以及php输出返回的信息.
具体可根据实际需要增减要记录的信息.
php开发测试及线上的时候可以根据不同情况设定错误和异常处理需要用到有
set_error_handler(array(‘Debug’,'appError’)); // 设置一个用户定义的错误处理函数
set_exception_handler(array(‘Debug’,'appException’)); //自定义异常处理。
下面讲一下register_shutdown_function() 函数.
功能:register_shutdown_function() 函数可实现当程序执行完成后执行的函数,其功能为可实现程序执行完成的后续操作。程序在运行的时候可能存在执行超时,或强制关闭等情况,但这种情况下默认的提示是非常不友好的,如果使用register_shutdown_function()函数捕获异常,就能提供更加友好的错误展示方式,同时可以实现一些功能的后续操作,如执行完成后的临时数据清理,包括临时文件等。
2、当程序代码运行超时时
3、当PHP代码执行完成时,代码执行存在异常和错误、警告
<?php
function test() {
echo "test()";
}
register_shutdown_function(array("test"));
echo "show: ";
?>
这个例子输出
show: test()
这个函数的作用就是在退出脚本前,调用已经注册的函数,并执行该函数。
2. 在类中用一个数组作为一个参数
<?php
class ClassDemo {
public function __construct() {
register_shutdown_function(array($this, "f"));
}
public function f() {
echo "f()";
}
}
$demo = new ClassDemo();
echo "before </br>";
?>
输出:
before
f()
3. 带有参数的例子:
<?php
function f($str) {
echo $str."<br>";
}
register_shutdown_function("f","hello");
class ClassDemo {
public function __construct() {
register_shutdown_function(array($this, "f"),"hello");
}
public function f($str) {
echo "f():".$str;
}
}
$demo = new ClassDemo();
echo "before </br>";
?>
2,如果在调用register_shutdown_function()函数之前有exit()函数调用,register_shutdown_function()函数将不能执行
3,PHP4后支持注册函数参数传递
4,在某些服务端,如Apache,当前目录在register_shutdown_function()函数中能够改变
5,register_shutdown_function()函数执行在headers发送之后
接收到的参数和返回的内容对开发人员来说都是未知不可见的..
虽然可以通过直接在脚本中模拟请求..但由于实际环境复杂的多..调试极其不方便.
于是想是否可以写一个函数用来记录对php接口调用的情况.
想到以前看到过的一个php函数register_shutdown_function..
该函数的作用是注册一个函数,当php脚本执行完成,或者代码中调用了exit ,die这样的代码之后,执行预先注册好的函数.
这样我们就可以在该函数中记录php调用执行的情况了.
简单写了下,看起来应该可以用了
?
用以记录调用的相关信息.
我这里只记录了 request ,server 以及php输出返回的信息.
具体可根据实际需要增减要记录的信息.
php开发测试及线上的时候可以根据不同情况设定错误和异常处理需要用到有
设定错误和异常处理三函数
register_shutdown_function(array(‘Debug’,'fatalError’)); //定义PHP程序执行完成后执行的函数set_error_handler(array(‘Debug’,'appError’)); // 设置一个用户定义的错误处理函数
set_exception_handler(array(‘Debug’,'appException’)); //自定义异常处理。
下面讲一下register_shutdown_function() 函数.
功能:register_shutdown_function() 函数可实现当程序执行完成后执行的函数,其功能为可实现程序执行完成的后续操作。程序在运行的时候可能存在执行超时,或强制关闭等情况,但这种情况下默认的提示是非常不友好的,如果使用register_shutdown_function()函数捕获异常,就能提供更加友好的错误展示方式,同时可以实现一些功能的后续操作,如执行完成后的临时数据清理,包括临时文件等。
可以这样理解调用条件:
1、当页面被用户强制停止时2、当程序代码运行超时时
3、当PHP代码执行完成时,代码执行存在异常和错误、警告
实例说明
1. 一个简介的例子 , 调用一个函数<?php
function test() {
echo "test()";
}
register_shutdown_function(array("test"));
echo "show: ";
?>
这个例子输出
show: test()
这个函数的作用就是在退出脚本前,调用已经注册的函数,并执行该函数。
2. 在类中用一个数组作为一个参数
<?php
class ClassDemo {
public function __construct() {
register_shutdown_function(array($this, "f"));
}
public function f() {
echo "f()";
}
}
$demo = new ClassDemo();
echo "before </br>";
?>
输出:
before
f()
3. 带有参数的例子:
<?php
function f($str) {
echo $str."<br>";
}
register_shutdown_function("f","hello");
class ClassDemo {
public function __construct() {
register_shutdown_function(array($this, "f"),"hello");
}
public function f($str) {
echo "f():".$str;
}
}
$demo = new ClassDemo();
echo "before </br>";
?>
注意事项
1,register_shutdown_function()函数可重复调用,但执行的顺序与注册的顺序相同2,如果在调用register_shutdown_function()函数之前有exit()函数调用,register_shutdown_function()函数将不能执行
3,PHP4后支持注册函数参数传递
4,在某些服务端,如Apache,当前目录在register_shutdown_function()函数中能够改变
5,register_shutdown_function()函数执行在headers发送之后
相关文章推荐
- 利用php的register_shutdown_function来记录php的输出日志
- 利用PHP的register_shutdown_function来记录PHP的输出日志,模拟析构函数
- php中通过register_shutdown_function记录fatal error
- PHP ignore_user_abort 与 connection_status 与 register_shutdown_function 使用方法
- PHP中非期望致命错误的另一种处理方式:register_shutdown_function()
- PHP 的异常处理、错误处理:error_reporting,try-catch,trigger_error,set_error_handler,set_exception_handler,register_shutdown_function
- php中__destruct与register_shutdown_function执行的先后顺序问题
- PHP - Manual手册 - XLVII. Function Handling Functions函数管理函数 - register_shutdown_function注册一个脚本结束时调用的函数
- php中register_shutdown_function 函数详解
- php register_shutdown_function响应error 配合error_get_last 捕获错误
- php分享三十三:用php中的register_shutdown_function和fastcgi_finish_request
- php中的register_shutdown_function和fastcgi_finish_request
- PHP之register_shutdown_function方法
- 关于php的 register_shutdown_function 和 error_get_last函数
- 妙用php中的register_shutdown_function和fastcgi_finish_request
- 妙用php中的register_shutdown_function和fastcgi_finish_request
- 控制PHP的错误输出方式:直接输出至荧幕或将错误信息记录到错误日志文件内
- PHP register_shutdown_function
- PHP 错误与异常 笔记与总结(11 )register_shutdown_function() 函数的使用
- PHP register_shutdown_function()函数的使用示例