您好,登录后才能下订单哦!
怎么在Laravel中对错误与异常进行处理?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
忽略异常
在 $dontReport 中可以定义忽略的异常类名:
protected $dontReport = [ \Illuminate\Auth\AuthenticationException::class, \Illuminate\Auth\Access\AuthorizationException::class, \Symfony\Component\HttpKernel\Exception\HttpException::class, \Illuminate\Database\Eloquent\ModelNotFoundException::class, \Illuminate\Validation\ValidationException::class, ];
这些异常就不会经过 report 方法。
几个重要方法
主要介绍这三个方法,report,render 和 unauthenticated 的用法。
report方法
report 方法可以用来记录日志,可以根据不同的异常类型(包括自定义异常类型),如 ClientException,ConnectException 定制不同的日志级别和日志内容。
if ($exception instanceof ABCException) { Log::emergency('ABC异常', $context); } else if ($exception instanceof HeheException) { Log::info('Hehe异常', $context); }
report 方法没有返回值,也不应该在这里中断程序。
render方法
render 方法可以根据不同的异常类型,返回不同的数据。如:
if (get_class($exception) == 'Exception' || $exception instanceof NotAllowedException) { return response()->json(['message' => $exception->getMessage()], 400); } elseif ( $exception instanceof ValidationException) { return response()->json(['message' => '校验失败', 'errors'=> $exception->validator->errors()], 400); }
unauthenticated
在访问需要登录态的页面时,用户未登录就会进入这个方法进行处理,举个例子说明:
protected function unauthenticated($request, AuthenticationException $exception) { if ($request->expectsJson()) { return response()->json(['error' => 'Unauthenticated.'], 401); } //如果是后台页面未认证,跳转到后台登陆页面 $guard = $exception->guards(); if (in_array('admin', $guard)) { return redirect()->guest('/admin/login'); } return redirect()->guest('login'); }
如果是返回 json,则统一返回格式。
默认情况下返回前台的登录页,如果是访问后台页面未登录,则跳转到后台登录页。
看完上述内容,你们掌握怎么在Laravel中对错误与异常进行处理的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。