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即可实现,开发自己的框架也可以采用。
前面的文章对于高并发下单商品导致商品库存为负值的问题请先阅读再阅读本篇文章一定对您有帮助,建议亲手测试较好。加上文件锁后的下单处理代码:【一】.阻塞模式:(如果其他进程已经加锁文件,当前进程会一直等其他进程解锁文件后继续执行)<?php //连接数据库 $con=mysqli_connect(...
//$ak开发密钥,$cityname城市名称(支持省县乡详细地址) public function getposition($ak,$cityname){ $callback=array('lng'=>0,'l...
上篇文章已经讲解arrayacces的原理,现在来讲解下arrayaccess的实际应用。一个大型的互联网项目中必然会存在各种配置信息,例如多种数据库信息:mysql,tidb,mongodb,redis,某个业务模块单独的配置信息如比例,额度等等,那么该如何治理配置信息?PHP项目中大部分的框架都...
Redis提供了发布订阅功能,可以用于消息的传输,Redis的发布订阅机制包括三个部分,发布者(publisher),订阅者(subscriber)和频道(channel)。 发布者和订阅者都是Redis客户端,Channel则为Redis服务器端,发布者将消息发送到某个的频道,订阅了这个...
在使用ftok生成ipc进程通信key尝试将第二个参数项目标识符传入字符串报错:PHP Warning: ftok(): Project identifier is invalid,查阅资料发现第二个字符串只能是1个字符串,长度为1....