Whoops
优质
小牛编辑
144浏览
2023-12-01
swoft/whoops
是对 filp/whoops
在swoft中使用的简单封装,用于渲染并显示更加利于阅读的异常错误信息。
安装
swoft/whoops
作为一个额外的扩展组件,需要手动安装:
Composer 安装
composer require swoft/whoops
Git 仓库
参与贡献
欢迎参与贡献,您可以
- fork 开发仓库 swoft/whoops
- 修改代码然后发起 PR
- 阅读 提交代码 的注意事项
作为中间件使用
使用 Swoft\Whoops\WhoopsMiddleware
作为一个全局的Http中间件(app/bean.php
):
'httpDispatcher' => [
// Add global http middleware
'middlewares' => [
// Notice: Please add to the first place
\Swoft\Whoops\WhoopsMiddleware::class,
],
],
注意: 请将
Swoft\Whoops\WhoopsMiddleware
加到第一个位置
异常处理里使用
我们稍微调整一下默认的http异常处理类(App\Exception\Handler\HttpExceptionHandler
):
<?php declare(strict_types=1);
namespace App\Exception\Handler;
use ReflectionException;
use Swoft\Bean\Exception\ContainerException;
use Swoft\Error\Annotation\Mapping\ExceptionHandler;
use Swoft\Http\Message\Response;
use Swoft\Http\Server\Exception\Handler\AbstractHttpErrorHandler;
use Swoft\Log\Helper\CLog;
use Swoft\Whoops\WhoopsHandler;
use Throwable;
use function bean;
use function context;
use const APP_DEBUG;
/**
* Class HttpExceptionHandler
*
* @ExceptionHandler(\Throwable::class)
*/
class HttpExceptionHandler extends AbstractHttpErrorHandler
{
/**
* @param Throwable $e
* @param Response $response
*
* @return Response
* @throws ReflectionException
* @throws ContainerException
*/
public function handle(Throwable $e, Response $response): Response
{
$request = context()->getRequest();
if ($request->getUriPath() === '/favicon.ico') {
return $response->withStatus(404);
}
// Log
CLog::error($e->getMessage());
// Debug is false
if (!APP_DEBUG) {
return $response
->withStatus(500)
->withContent($e->getMessage());
}
// Debug is true
$whoops = bean(WhoopsHandler::class);
$content = $whoops->run($e, $request);
return $response->withContent($content);
}
}
现在我们重启 http server,当出现异常时就可以看到由 whoops
渲染的错误信息页面了。