春节期间熟悉了 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-03-01 23:26:43 +08:00 via Android
请问 nodejs 程序异常时,如何在页面上显示出错行等信息?
|
2
casper13 2020-03-01 23:27:10 +08:00
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-03-01 23:37:10 +08:00
用 try catch 来捕抓异常是很正常的啊... 而且 php5 就有了啊 注意跟上啊
|
4
33130317 OP |
6
33130317 OP @casper13 不懂就问, 麻烦告诉下如何查看这些 ENV 的信息吗? tp6 和 env 都是刚接触, 还不知道如何处理
|
7
masker 2020-03-02 10:48:50 +08:00 via Android
laravel 出新功能了。
thinkphp:抄 |
10
liuguang 2020-03-02 12:46:33 +08:00
不如不用 tp,哈哈😄
|
11
st2udio 2020-03-02 12:49:58 +08:00
这个界面好熟悉的味道
|
12
ben1024 2020-03-02 13:30:26 +08:00
tp 的异常虽然 UI 不是很好,对工程师体验还是友好些的
|
14
2kCS5c0b0ITXE5k2 2020-03-02 14:28:04 +08:00
@33130317 然而 tp 是有的 最下面.
|
15
ysc3839 2020-03-02 14:32:14 +08:00 via Android
@yafoo Node.js 的话要看是什么 http 框架了,express 的话默认会输出错误信息的。
|
16
sunny2580839896 2020-03-02 14:49:31 +08:00
@33130317 #6 大佬,这个是怎么看的???
|
17
yafoo 2020-03-02 16:16:51 +08:00 via Android
@ysc3839 使用 koa 框架,出错时,命令行控制台会显示出错行,用页面输出的话,不知道怎么能显示出来?
|
18
ysc3839 2020-03-02 16:43:13 +08:00 via Android
@yafoo 翻了下文档,和 express 不一样,koa 要在开头添加一个 middleware,用 try catch 来捕获后续 middleware 的错误。catch 后自己输出到 response 即可。
https://github.com/koajs/koa/wiki/Error-Handling#catching-downstream-errors |