123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214 |
- <?php
- namespace App\Exceptions;
- use App\Components\IP;
- use Arr;
- use ErrorException;
- use Illuminate\Auth\AuthenticationException;
- use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
- use Illuminate\Http\Client\ConnectionException;
- use Illuminate\Http\Request;
- use Illuminate\Session\TokenMismatchException;
- use Illuminate\Validation\ValidationException;
- use Log;
- use ReflectionException;
- use Response;
- use Symfony\Component\HttpKernel\Exception\HttpException;
- use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
- use Symfony\Component\HttpKernel\Exception\UnauthorizedHttpException;
- use Throwable;
- use Tymon\JWTAuth\Exceptions\TokenBlacklistedException;
- use Tymon\JWTAuth\Exceptions\TokenExpiredException;
- use Tymon\JWTAuth\Exceptions\TokenInvalidException;
- class Handler extends ExceptionHandler
- {
-
- protected $dontReport = [
- HttpException::class,
- ValidationException::class,
- ];
-
- protected $dontFlash = [
- 'password',
- 'password_confirmation',
- ];
-
- public function report(Throwable $exception)
- {
-
- if (config('app.debug') || config('app.demo')) {
- Log::debug('来自链接:'.url()->full());
-
- Log::info('异常来源:'.get_class($exception));
- Log::debug($exception);
- }
- parent::report($exception);
- }
-
- 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
- );
-
-
- case $exception instanceof \Illuminate\Database\Eloquent\ModelNotFoundException:
-
- 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' => 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:
- if ($request->ajax() || $request->wantsJson()) {
- return Response::json([
- 'status' => 'fail',
- 'message' => trans('error.refresh_page').'<a href="'.route('login').'" target="_blank">'.trans('error.refresh').'</a>',
- ], 419);
- }
- return Response::view(
- 'auth.error',
- ['message' => trans('error.refresh_page').'<a href="'.route('login').'" target="_blank">'.trans('error.refresh').'</a>'],
- 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').'<a href="'.route('admin.log.viewer').'" target="_blank">'.trans('error.log').'</a>',
- ], 500);
- }
- return Response::view(
- 'auth.error',
- ['message' => trans('error.system').', '.trans('error.visit').'<a href="'.route('admin.log.viewer').'" target="_blank">'.trans('error.log').'</a>'],
- 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);
- }
- }
|