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即可实现,开发自己的框架也可以采用。
项目需要使用websocket推送最新订单,客户服务器非linux不支持swoole,因此使用原生,直接上代码(1).PHP服务端<?php ini_set('error_reporting', E_ALL ^ E_NOTICE); ini_set...
本篇文章不是讲解如何用.net开发自己的dll然后PHP通过com调用。主要记录PHP官方支持的DOTNET 基本语法如下:$obj = new DOTNET("assembly", "classname")a...
(1).前端文件:<form action="upload.php" method="post" enctype="multipart/form-data"> &...
面试中PHP面试官会问调用一个不存在的方法,如何知道是哪个文件哪行调用的?假设方法是getWorkLoad()回答1:开启PHP错误输出,PHP会输出Fatal error: Call to undefined function getWorkLoad() in D:\wwwroot\thinkpa...
(1).config.php 配置文件<?php /** * RabbitMQ_Config */ $config = [ 'host' => ...
(1).在PHP中可以查看的环境变量包括: (1.1).电脑环境变量 (2.1).服务器环境变量(2).getenv()函数获取一个环境变量的值.参数1是环境变量的key,参数2值为true的时候仅从你的电脑环境变量中查找,参数2值为false会从两种变量中全部查询//获取我电脑登录的用户名,输出A...