ThinkPHP中有一个debug调试功能,能输出报错文件的信息,并能看到这个函数被哪些函数调用,从框架的启动开始记录,特别方便调试。于是研究了下它的底层给予了实现。
<?php //--框架核心--Start //框架内置错误处理 function errDealWith($errno, $errstr, $errfile, $errline) { throw new Exception('错误信息:' . $errstr . '错误文件:' . $errfile . '错误行:' . $errline . '错误码:' . $errno); } set_error_handler('errDealWith'); //加载框架 try { init(); } catch (Exception $e) { showDebug($e); //showDebug($e->getMessage()); } //框架调用栈方法 function showDebug($ex) { //错误输出 var_dump($ex->getMessage()); //调用栈输出 var_dump('调用顺序'); $traces = array_reverse($ex->getTrace()); foreach ($traces as $item) { //剔除框架自带的异常函数 if ($item['function'] != 'errDealWith') { var_dump($item['function']); var_dump($item); } } } //框架初始化方法 function init() { //加载index控制器 index(); } //--框架核心--结束 //-----------------------华丽的分割线 //控制器 function index() { //加载新闻的逻辑 getList(); } //新闻页面 function getList() { return $list; }
在上面的代码中存在$list未定义的错误。首先要自定义错误处理函数或类,这里为了演示只是处理了一种错误而已,实际上一个完整的错误处理类是非常庞大的,通过抛出异常再获取getTrace即可实现,开发自己的框架也可以采用。
/** * 计算两点地理坐标之间的距离 * @param Decimal $longitude1 起点经度 * @param Decimal $lati...
源码:特别适用于微信支付中通知微信支付网关function array2xml($arr, $level = 1) { $s = $level == 1 ? "<xml&g...
【一】.介绍session由于HTTP是无状态的请求,创建一个会话需要保持必须需要身份标识。当用户第一次访问,PHP会为用户创建一个唯一的sessionid,并将sessionid通过cookie发送给浏览器,并在服务器的临时文件创建一个以sessionid为名的文件用来保存这个sessionid保...
在编写多进程的实例中我在每个进程中使用如下代码://调用等待信号的处理器 while (true) { pcntl_signal_dispatch(); }开启5个进程,cpu直接100%修正之后的代码://调用等待信号的处理器 while&...
当我想在一个进程中监听kill 和 kill -9命令报了这个错误。//监听kill pcntl_signal(SIGTERM, function () { posix_kill(0, SIGTERM); });...
在项目下的composer配置文件修改(PaySdk是我这里一个支付sdk的目录,包含各种各样的支付sdk,这样写的意思让composer自动把PaySdk下的所有文件自动加载):"autoload": { &...