您好,登錄后才能下訂單哦!
怎么在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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。