当前位置:首页 > PHP > 正文内容

Thinkphp Call Stack,PHP调用栈Call Stack的获取

高老师6年前 (2019-03-23)PHP1714

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即可实现,开发自己的框架也可以采用。

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/77.html

分享给朋友:

“Thinkphp Call Stack,PHP调用栈Call Stack的获取” 的相关文章

php多进程实现任务管理器,定时执行任务,支持守护

php多进程实现任务管理器,定时执行任务,支持守护

主要原理是通过PHP创建多个子进程,在子进程中发送进程闹钟信号,然后再监听闹钟信号中继续发送闹钟信号。同时通过父进程设置非阻塞运行。代码如下:<?php /**  * 订单任务  */ class Order {    &n...

PHP getenv函数和putenv函数的学习

PHP getenv函数和putenv函数的学习

(1).在PHP中可以查看的环境变量包括: (1.1).电脑环境变量 (2.1).服务器环境变量(2).getenv()函数获取一个环境变量的值.参数1是环境变量的key,参数2值为true的时候仅从你的电脑环境变量中查找,参数2值为false会从两种变量中全部查询//获取我电脑登录的用户名,输出A...

swoole中的worker_num和task_worker_num

swoole中的worker_num和task_worker_num

(1)swoole启动的主进程是master进程负责全局管理,然后master进程会再fork一个manager进程。(2)manager进程开始统一管理进程创建回收管理。(3)manager进程根据设置的worker_num和task_worker_num来创建work进程和task进程因此启动s...

composer自动加载类库(非psr4规范的文件)

composer自动加载类库(非psr4规范的文件)

在项目下的composer配置文件修改(PaySdk是我这里一个支付sdk的目录,包含各种各样的支付sdk,这样写的意思让composer自动把PaySdk下的所有文件自动加载):"autoload": {      &...

PHP最快方式模拟curl,PHP最快爬虫模拟方法

PHP最快方式模拟curl,PHP最快爬虫模拟方法

有时候我们需要爬一个接口,但是这个接口需要很多参数,包括header和cookie要去编写,使用php curl模拟实在太慢。我们可以通过浏览器的network来复制请求为curl命令。例如我需要模拟请求接口地址:https://www.xkmz.cc/Ajax/Debug/delly,我们只需要在...

在MyISAM引擎中使用事务会怎样

在MyISAM引擎中使用事务会怎样

众所周知MyISAM引擎不支持事务,但是我只是知道不支持事务,并未测试具体的表现是什么,测试代码如下:try {     //开启事务     Db::startTrans();    &...