📖 File Reader
<?php
namespace app;
use think\db\exception\DataNotFoundException;
use think\db\exception\ModelNotFoundException;
use think\exception\Handle;
use think\exception\HttpException;
use think\exception\HttpResponseException;
use think\exception\ValidateException;
use think\Response;
use think\Facade\Db;
use Throwable;
/**
* 应用异常处理类
*/
class ExceptionHandle extends Handle
{
/**
* 不需要记录信息(日志)的异常类列表
* @var array
*/
protected $ignoreReport = [
HttpException::class,
HttpResponseException::class,
ModelNotFoundException::class,
DataNotFoundException::class,
ValidateException::class,
];
/**
* 记录异常信息(包括日志或者其它方式记录)
*
* @access public
* @param Throwable $exception
* @return void
*/
public function report(Throwable $exception): void
{
// 使用内置的方式记录异常日志
parent::report($exception);
}
/**
* Render an exception into an HTTP response.
*
* @access public
* @param \think\Request $request
* @param Throwable $e
* @return Response
*/
public function render($request, Throwable $e): Response
{
// 添加自定义异常处理机制
if ($e->getCode() != 0) {
$res = [
'file' => $e->getFile(),
'line' => $e->getLine(),
'message' => $e->getMessage(),
//'trace' => $e->getTraceAsString(),
'code' => $e->getCode(),
'host' => $request->host(),
'scheme' => $request->scheme(),
'port' => $request->port(),
'url' => $request->url(),
'method' => $request->method(),
'ip' => $request->ip(),
'param' => $request->param(),
];
$info = [
'ip'=>$request->ip(),
'describe'=>json_encode($res),
'add_time'=> date("Y-m-d H:i:s",time()),
];
db::name("system_error_log")->insertGetId($info);
}
// 其他错误交给系统处理
return parent::render($request, $e);
}
}