春节期间熟悉了 TP6, 也写了一个 TP6 的博客程序,但系统的异常页面实在另外头疼,很多时候无法查看到是哪行代码出的问题。
所以就特别的想把 whoops 引进来,经过一系列的研究,终于找到了解决的办法:
运行命令: composer require filp/whoops
注意:composer 引进的文件如果有语法错误,需要提前把语法错误处理好才能进行安装,否则一直报错。
在 /app/ExceptionHandle.php 文件的 render()方法中加入如下代码:
// 添加自定义异常处理机制
if (ENV('APP_DEBUG')) {
// 如果是 HttpResponseException 异常则原样输出
// JUMP 插件里的 success,error 和 result 方法均返回的是 HttpResponseException 异常
if ($e instanceof HttpResponseException) {
return $e->getResponse();
}
// Whoops 接管请求异常
$whoops = new \Whoops\Run;
$whoops->pushHandler(new \Whoops\Handler\PrettyPageHandler());
return Response::create(
$whoops->handleException($e),
'html',
500
);
}
如下图:

我在博客首页的 index 方法中写入了一个不存在的函数:

刷新页面一看, 妥了

OK. 熟悉的 whoops 又回来了.
为了在 thinkphp6 中使用 whoops, 我又认真的看了一遍 PHP7 中的异常机制,终于是把 whoops 给引进来了.
在学习异常处理的过程中, 我也发现在 PHP7 中应该使用 try()catch()来进行业务处理, 而不是再使用 if()else()了.
后续我会单独写篇文章来讲述我在研究 PHP7 的异常中获得的经验.
也希望大家能继续关注我的博客 http://laoliu.pro
1
yafoo 2020 年 3 月 1 日 via Android
请问 nodejs 程序异常时,如何在页面上显示出错行等信息?
|
2
casper13 2020 年 3 月 1 日
Environment Variables
APP_DEBUG 1 APP_DEFAULT_TIMEZONE Asia/Shanghai DATABASE_TYPE mysql DATABASE_HOSTNAME 127.0.0.1 DATABASE_DATABASE laoliu2020 DATABASE_USERNAME root DATABASE_PASSWORD *********-2020 DATABASE_HOSTPORT 3306 DATABASE_CHARSET utf8 DATABASE_DEBUG 1 DATABASE_PREFIX llp_ LANG_DEFAULT_LANG zh-cn 处理一下 |
3
2kCS5c0b0ITXE5k2 2020 年 3 月 1 日
用 try catch 来捕抓异常是很正常的啊... 而且 php5 就有了啊 注意跟上啊
|
7
masker 2020 年 3 月 2 日 via Android
laravel 出新功能了。
thinkphp:抄 |
10
liuguang 2020 年 3 月 2 日
不如不用 tp,哈哈😄
|
11
st2udio 2020 年 3 月 2 日
这个界面好熟悉的味道
|
12
ben1024 2020 年 3 月 2 日
tp 的异常虽然 UI 不是很好,对工程师体验还是友好些的
|
14
2kCS5c0b0ITXE5k2 2020 年 3 月 2 日
@33130317 然而 tp 是有的 最下面.
|
16
sunny2580839896 2020 年 3 月 2 日
@33130317 #6 大佬,这个是怎么看的???
|
18
ysc3839 2020 年 3 月 2 日 via Android
@yafoo 翻了下文档,和 express 不一样,koa 要在开头添加一个 middleware,用 try catch 来捕获后续 middleware 的错误。catch 后自己输出到 response 即可。
https://github.com/koajs/koa/wiki/Error-Handling#catching-downstream-errors |