YII2 全局異常處理深入講解
首先,我們必須理性認識到,任何一個即使穩定的系統中也是存在著大量的 bug,不管是因為什麼原因導致的錯誤,我們都是需要做好防范的,最好的結果當然是將異常糾正過來,返回客戶端一個正確的響應結果,但絕大多數情況下是沒辦法返回正常結果的,隻能返回一個客戶端一個異常的信息。
處理異常的方式,通常分為:
- 記錄日志
- 修復異常
- 返回客戶端錯誤
要處理好這個問題,我認為比較簡單的方式就是將需要處理的異常按照場景先做一個分類。
常用的處理是: 用戶行為導致的錯誤通常不需要記錄日志,因為若是多人使用的情況下會導致日志量過大,但需要向客戶端返回具體原因以便用戶用正確的方式調用我們的接口;而服務器出現的錯誤則需要記錄日志,因為我們是需要解決這些錯誤的,記錄日志讓我們比較方便的找到錯誤的原因,快速解決,但不向客戶端返回具體原因,因為用戶沒辦法通過自己的行為使異常不再出現。當然我們也可以根據自己的業務決定自己的異常處理方式。
在 ThinkPHP 或者其他框架中,如果出現異常,則會出現框架的一個異常頁面。
但如果我們開發的是 API,直接返回一個頁面給客戶端顯然不合理,因為別人在使用你的接口的時候還需要解析界面分析出結果,這麼做是十分不合理的,所以,我們需要對框架的異常處理進行重寫。以下使用 Yii2 框架作為例子講解重寫的邏輯:
首先,我們需要找到 Yii 框架異常處理的設置(../config/web.php)
'components' => [ 'errorHandler' => [ 'errorAction' => 'site/error', 'class' => 'app\common\ExceptionHandler',//(這裡配置我們自己寫的異常處理方法) ],
為瞭讓我們的程序可以簡單的辨別出客戶的不當調用導致的錯誤和服務器的錯誤,我們可以寫一個客戶的異常類。新建 common\UserException.php 文件
class UserException extends Exception { // HTTP 狀態碼 404,200 /** * @var int|mixed */ public $code = 400; // 錯誤具體信息 /** * @var mixed|string */ public $msg = '參數錯誤'; // 自定義的錯誤碼 /** * @var int|mixed */ public $errorCode = 10000; /** * UserException constructor. * @param $params */ public function __construct($params=[]) { // 如果傳過來的不是數組則不進行對象初始化 if (!is_array($params)) { return; } // 判斷數組有沒有該鍵值 if (array_key_exists('code',$params)) { $this->code = $params['code']; } if (array_key_exists('msg',$params)) { $this->msg = $params['msg']; } if (array_key_exists('errorCode',$params)) { $this->errorCode = $params['errorCode']; } } }
新建 common/ExceptionHandler.php
文件,因為 yii 的異常處理的渲染是由 vendor\yiisoft\yii2\web\ErrorHandler.php
中的 renderException
方法渲染的,所以我們開發屬於自己的異常處理類的時候可以選擇繼承該類並重寫這個方法。
這就完成瞭全局的異常處理,讓我們看看效果
當我們開啟 debug 模式時拋出錯誤:
關閉 debug 模式,拋出服務器端異常:
public function actionIndex() { throw new \Exception(); }
關閉 debug 模式,拋出客戶端異常:
public function actionIndex() { throw new UserException(); }
到此這篇關於YII2 全局異常處理深入講解的文章就介紹到這瞭,更多相關YII2 全局異常處理內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- springboot框架的全局異常處理方案詳解
- java異常處理攔截器詳情
- springboot 實戰:異常與重定向問題
- Spring Boot統一處理全局異常的實戰教程
- thinkphp的鉤子的兩種配置和兩種調用方法