full());
// 记录异常来源
Log::info('异常来源:'.get_class($exception));
Log::debug($exception);
}
parent::report($exception);
}
/**
* Render an exception into an HTTP response.
*
* @param Request $request
* @param Throwable $exception
* @return \Symfony\Component\HttpFoundation\Response
*
* @throws Throwable
*/
public function render($request, Throwable $exception)
{
// 调试模式下直接返回错误信息,非调试模式下渲染在返回
if ($exception instanceof UnauthorizedHttpException) {
$preException = $exception->getPrevious();
if ($preException instanceof TokenExpiredException) {
return response()->json(['code'=>401,'ret'=>401,'error' => 'TOKEN_EXPIRED'],200);
} else if ($preException instanceof TokenBlacklistedException) {
return response()->json(['code'=>402, 'ret' => 402, 'msg' => "TOKEN禁用,需要重新登陆"], 200);
}
if ($exception->getMessage() === 'Token not provided') {
return response()->json(['code'=>403,'ret' => 403, 'msg' => "TOKEN错误,需要重新登陆"], 200);
}
}
if (! config('app.debug')) {
switch ($exception) {
case $exception instanceof ValidationException:
if (strpos($request->fullUrl(),"client/v1") != false || strpos($request->fullUrl(),"client/v2") != false || strpos($request->fullUrl(),"client/v3") != false){
return Response::json([
'ret' => 404,
'msg' => Arr::first(Arr::collapse($exception->errors()))
],404);
}
return Response::view(
'auth.error',
['message' => Arr::first(Arr::collapse($exception->errors()))],
500
);
// return $this->response($code, Arr::first(Arr::collapse($exception->errors())));
// return Response::json(['status' => 'fail', 'message' => Arr::first(Arr::collapse($exception->errors()))], 409);
case $exception instanceof \Illuminate\Database\Eloquent\ModelNotFoundException:
// Log::info('异常请求:'.$exception->getMessage());
return Response::json(['status' => 'fail', 'message' => $exception->getMessage()], 408);
case $exception instanceof NotFoundHttpException: // 捕获访问异常
Log::info('异常请求:'.$request->fullUrl().',IP:'.IP::getClientIp());
Log::info('异常请求 route:'.$request->route());
if (strpos($request->fullUrl(),"client/v1") != false || strpos($request->fullUrl(),"client/v2") != false || strpos($request->fullUrl(),"client/v3") != false ){
return Response::json([
'ret' => 404,
'msg' => empty($exception->getMessage()) ? '资源没找到~' : $exception->getMessage()
],404);
}
if ($request->ajax() || $request->wantsJson()) {
// return Response::json(['status' => 'fail', 'message' => trans('error.missing_page')], 404);
return Response::json(['status' => 'fail', 'message' => empty($exception->getMessage()) ? '资源没找到~' : $exception->getMessage()], 407);
}
return Response::view('auth.error', ['message' => $exception->getMessage()], 404);
case $exception instanceof AuthenticationException: // 捕获身份校验异常
if (strpos($request->fullUrl(),"client/v1") != false || strpos($request->fullUrl(),"client/v2") != false || strpos($request->fullUrl(),"client/v3") != false ){
return Response::json([
'ret' => 401,
'msg' => "登陆失效,重新登陆下"
],200);
}
if ($request->ajax() || $request->wantsJson()) {
return Response::json(['status' => 'fail', 'message' => trans('error.unauthorized')], 401);
}
return Response::view('auth.error', ['message' => trans('error.unauthorized')], 401);
case $exception instanceof TokenMismatchException: // 捕获CSRF异常
if ($request->ajax() || $request->wantsJson()) {
return Response::json([
'status' => 'fail',
'message' => trans('error.refresh_page').''.trans('error.refresh').'',
], 419);
}
return Response::view(
'auth.error',
['message' => trans('error.refresh_page').''.trans('error.refresh').''],
419
);
case $exception instanceof ReflectionException:
if ($request->ajax() || $request->wantsJson()) {
return Response::json(['status' => 'fail', 'message' => trans('error.system')], 500);
}
return Response::view('auth.error', ['message' => trans('error.system')], 500);
case $exception instanceof ErrorException: // 捕获系统错误异常
if (strpos($request->fullUrl(),"client/v1") != false || strpos($request->fullUrl(),"client/v2") != false || strpos($request->fullUrl(),"client/v3") != false ){
return Response::json([
'ret' => 404,
'msg' => empty($exception->getMessage()) ? '系统错误' : $exception->getMessage()
],404);
}
if ($request->ajax() || $request->wantsJson()) {
return Response::json([
'status' => 'fail',
'message' => trans('error.system').', '.trans('error.visit').''.trans('error.log').'',
], 500);
}
return Response::view(
'auth.error',
['message' => trans('error.system').', '.trans('error.visit').''.trans('error.log').''],
500
);
case $exception instanceof ConnectionException:
if ($request->ajax() || $request->wantsJson()) {
return Response::json(['status' => 'fail', 'message' => $exception->getMessage()], 408);
}
return Response::view('auth.error', ['message' => $exception->getMessage()], 408);
default:
return Response::json([
'status' => 'fail',
'ret' => 404,
'msg' => $exception->getMessage()
],404);
}
}
return parent::render($request, $exception);
}
}