在php中又两个方法都是在请求快结束的时候执行.方法名分别是 register_shutdown_function和fastcgi_finish_request.虽然执行的时机差不多,但是功能和应用场景不一样.比较两个方法的区别不是本文的重点.本文的重点的说明两个方法的应用场景. register_shutdown_function 功能: 注册一个方法,当一个请求request执行完毕时,调用这个注册的方法.注意,哪怕在执行过程中发生error导致本次请求被强制退出,注册的方法也会执行. 应用…
已前言 在php中又两个方法都是在请求快结束的时候执行.方法名分别是 register_shutdown_function和fastcgi_finish_request.虽然执行的时机差不多,但是功能和应用场景不一样.比较两个方法的区别不是本文的重点.本文的重点的说明两个方法的应用场景. register_shutdown_function 功能: 注册一个方法,当一个请求request执行完毕时,调用这个注册的方法.注意,哪怕在执行过程中发生error导致本次请求被强制退出,注册的方法也会执行…
前言 在php中又两个方法都是在请求快结束的时候执行.方法名分别是 register_shutdown_function和fastcgi_finish_request.虽然执行的时机差不多,但是功能和应用场景不一样.比较两个方法的区别不是本文的重点.本文的重点的说明两个方法的应用场景. register_shutdown_function 功能: 注册一个方法,当一个请求request执行完毕时,调用这个注册的方法.注意,哪怕在执行过程中发生error导致本次请求被强制退出,注册的方法也会执行.…
在php中又两个方法都是在请求快结束的时候执行.方法名分别是 register_shutdown_function和fastcgi_finish_request.虽然执行的时机差不多,但是功能和应用场景不一 样.比较两个方法的区别不是本文的重点.本文的重点的说明两个方法的应用场景. register_shutdown_function 功能: 注册一个方法,当一个请求request执行完毕时,调用这个注册的方法.注意,哪怕在执行过程中发生error导致本次请求被强制退出,注册的方法也会执行. 应…
公司内部的市场管理系统,一直是我一个人维护,最近老是有开发埋怨,内网的账号被人改了密码,账号被解绑了...哈的,错在这还不是一个完整的系统,既没有严格的权限也没有做操作日志呀... 权限现在是准备做在下一阶段的的API网关项目里面做统一的管理,想着还是先把操作日志做起来吧. 系统框架使用的Think PHP 5,查了一下文档,http://www.kancloud.cn/manual/thinkphp5/135195,模型是支持事件的,于是计划是这样,通过模型的事件触发记录日志的动作. 看了一下…
一.错误.异常 等级常量表 error:不能在编译期发现的运行期错误,比如试图用 echo 输出一个未赋值的变量,这类问题往往导致程序或逻辑无法继续下去而需要中断: exception:程序执行过程中出现意料之外的情况,逻辑上往往是行得通的,但不符合应用场景,比如接收到一个长度超出预定格式的用户命名,因此,异常主要靠编码人员做预先做判断后抛出,捕获异常后改变程序流程来处理这些情况,不必中断程序. PHP 对于异常和错误的界定似乎不是很明显,尤其是低版本的PHP. 错误和日志记录值 常量 说明 备…
最近在做的一个项目,由于全是通过远程HTTP请求来调用PHP的接口程序. 接收到的参数和返回的内容对开发人员来说都是未知不可见的. 虽然可以通过直接在脚本中模拟请求,但由于实际环境复杂的多,调试极其不方便. 于是想是否可以写一个函数用来记录对PHP接口调用的情况. 想到以前看到过的一个PHP函数 register_shutdown_function(). 该函数的作用是注册一个函数,当PHP脚本执行完成,或者代码中调用了 exit , die 这样的代码之后,执行预先注册好的函数. 这样我们就可…
当PHP运行在FastCGI模式时,PHP FPM提供了一个名为fastcgi_finish_request的方法.按照文档上的说法,此方法可以提高请求的处理速度,如果有些处理可以在页面生成完后再进行,就可以使用这个方法. 听起来可能有些茫然,我们通过几个例子来说明一下: <?php echo '例子:'; fastcgi_finish_request(); /* 响应完成, 关闭连接 */ /* 记录日志 */ file_put_contents('log.txt', '生存还是毁灭,这是个问…
设定错误和异常处理三函数 register_shutdown_function(array(‘Debug’,'fatalError’)); //定义PHP程序执行完成后执行的函数 set_error_handler(array(‘Debug’,'appError’)); // 设置一个用户定义的错误处理函数 set_exception_handler(array(‘Debug’,'appException’)); //自定义异常处理. 下面讲一下register_shutdown_functio…
最近在做的一个项目..由于全是通过远程http请求来调用php的接口程序.. 接收到的参数和返回的内容对开发人员来说都是未知不可见的.. 虽然可以通过直接在脚本中模拟请求..但由于实际环境复杂的多..调试极其不方便. 于是想是否可以写一个函数用来记录对php接口调用的情况. 想到以前看到过的一个php函数register_shutdown_function.. 该函数的作用是注册一个函数,当php脚本执行完成,或者代码中调用了exit ,die这样的代码之后,执行预先注册好的函数. 这样我们就可…