test_lgq/niucloud/app/ExceptionHandle.php

114 lines
4.0 KiB
PHP
Raw Permalink Normal View History

2024-01-24 17:36:08 +08:00
<?php
namespace app;
use app\dict\sys\AppTypeDict;
use core\exception\AdminException;
use core\exception\AuthException;
use core\exception\ServerException;
use think\db\exception\DataNotFoundException;
use think\db\exception\DbException;
use think\db\exception\ModelNotFoundException;
use think\exception\Handle;
use think\exception\HttpException;
use think\exception\HttpResponseException;
use think\exception\ValidateException;
use think\facade\Log;
use think\Response;
use Throwable;
use UnexpectedValueException;
/**
* 应用异常处理类
*/
class ExceptionHandle extends Handle
{
/**
* 不需要记录信息(日志)的异常类列表
* @var array
*/
protected $ignoreReport = [
HttpException::class,
HttpResponseException::class,
ModelNotFoundException::class,
DataNotFoundException::class,
ValidateException::class,
];
/**
* 记录异常信息(包括日志或者其它方式记录)
*
* @access public
* @param Throwable $e
* @return void
*/
public function report(Throwable $e): void
{
// 使用内置的方式记录异常日志
// parent::report($exception);
if (!$this->isIgnoreReport($e)) {
$data = [
'file' => $e->getFile(),
'line' => $e->getLine(),
'message' => $e->getMessage(),
'trace' => $e->getTrace(),
'previous' => $e->getPrevious(),
];
//这个类可能会分开拆成两个
$app_type = request()->appType() ;
$app_type = empty($app_type) ? str_replace('/', '', request()->rootUrl()) : $app_type;
//写入日志内容
$log = [
'服务主体:'.($app_type == AppTypeDict::ADMIN ? request()->uid() : request()->memberId()),//服务发起者 //用户ID
'IP'.request()->ip(),//ip
'耗时(毫秒):'.ceil((microtime(true) * 1000) - (request()->time(true) * 1000)),//耗时(毫秒)
'请求类型:'.request()->method(),//请求类型
'应用:'.$app_type,//应用
'路由:'.request()->baseUrl(),//路由
'请求参数:'.json_encode(request()->param() ?? []),//请求参数
'错误信息:'.json_encode($data),//错误信息
];
Log::write('DEBUG>>>>>>>>>'.PHP_EOL.implode(PHP_EOL, $log).PHP_EOL.'---------', 'error');
}
}
/**
* 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
{
// 添加自定义异常处理机制
$massageData = env('app_debug', false) ? [
'file' => $e->getFile(),
'line' => $e->getLine(),
'message' => $e->getMessage(),
'trace' => $e->getTrace(),
'previous' => $e->getPrevious(),
] : [];
// 添加自定义异常处理机制
if ($e instanceof DbException) {
return fail(get_lang('DATA_GET_FAIL').':'.$e->getMessage(), [
'file' => $e->getFile(),
'line' => $e->getLine(),
'message' => $e->getMessage(),
'trace' => $e->getTrace(),
'previous' => $e->getPrevious(),
]);
} elseif ($e instanceof ValidateException) {
return fail($e->getMessage());
} else if($e instanceof UnexpectedValueException){
return fail($e->getMessage(), [], 401);
}else if($e instanceof AuthException || $e instanceof AdminException){
return fail($e->getMessage(), [], $e->getCode() ?: 400);
}else if($e instanceof ServerException){
return fail($e->getMessage(), http_code:$e->getCode());
}else {
return fail($e->getMessage(), $massageData);
}
}
}