-
-
try{
- // you codes that maybe cause an error
}catch(Exception $catch(Exception $catch(Exception $catch(Exception $catch(Exception $ err){ // 這個錯誤物件需要宣告類型, Exception 是系統預設例外處理類別
- echo $err->getMessage();
- }
//thrown 可以拋出一個異常,如:
- thrown new Exception('an error');
-
複製程式碼
一個例子:
-
-
try {
- if ( empty( $var1 ) ) throw new NotEmptyException(); if ( ! preg_match() ) throw new InvalidInputException();
$model->write();
- $template- >render( 'success' );
-
- } catch ( NotEmptyException $e ) {
- $template->render( 'error_empty' );
- } catch ( InvalidInputException $e ) {
- $template->render( 'error_preg' );
- }
-
-
複製程式碼
Exception 類別的結構:其中大部分方法都是禁止改寫的(final )
Exception {
/* 屬性 */
protected string $message ;
protected int $code ;
protected string $file ;
protected int $line ;
/* 方法 */
public __construct ([ string $message = "" [, int $code = 0 [, Exception $previous = null]]] )
final public string getMessage ( void ) //異常拋出的訊息
final public Exception getPrevious ( void ) //前一個異常
final public int getCode ( void ) //例外碼,這是使用者自訂的
final public string getFile ( void ) //發生異常的檔案路勁
final public int getLine ( void ) //發生異常的行
final public array getTrace ( void ) //異常追蹤訊息(array)
final public string getTraceAsString ( void ) //異常追蹤訊息(string)
public string __toString ( void ) //試圖直接 將異常物件當作字串使用時呼叫子函數的回傳值
final private void __clone ( void ) //克隆異常物件時調用
}
擴充異常類別
try-catch 可以有多個catch 子句,從第一個catch 子句開始,如果子句內的異常變數類型符合thrown 語句拋出的例外類型,則該子句會被執行而不再執行其他catch子句,否則繼續嘗試下一個catch 子句,由於Exception 是所有異常類的基類,因此拋出的異常都會與他匹配,如果需要根據不同異常類型使用不同的處理方法,應該將Exception 類型的catch 子句放到最後。
Exception 是所有異常的基類,可以根據實際需要擴展異常類
-
calss MyException extends Exception{
- public errType = 'default';
- public function __construct($struct) '){
- $this->errType = $errType;
- }
- }
try{ // you codes that maybe cause an error
- thrown new MyException ('an error');
- }catch(MyException $err){ // 這個錯誤物件需要宣告類型
- echo $err->errType();
- }catch(ErrorException $err){ / /ErrorException 是PHP 5 增加的異常類,繼承於Exception
- echo 'error !';
- }catch(Exception $err){
- redirect('/error.php');
- }
- redirect('/error.php');
- }
複製程式碼
你可能會在catch 子句中判斷異常的類型,或是根據code 等資訊來決定是否處理異常,如果你卸載catch 子句的程式碼無法適當的處理捕獲的異常,你可以在catch 子句內繼續拋出異常。
三、Exception 異常的回呼函數
set_exception_handler(callback functionName) //發生 Exception 或其 子類別的 例外狀況是會呼叫此函數
function exceptionHandlerFun($errObj){ // Exception 例外的回呼函數 只有一個參數,就是拋出的例外物件。
//.......
}
Exception 異常的回呼函數並不能像set_error_handler 的回呼函數那樣透過傳回true 來使異常被消除,即使回呼函數處理了異常,後繼程式碼也不會被繼續執行,因此想繼續執行後續程式碼必須使用try -catch。
但是有一個例外:腳本結束回呼函數可以被執行,拋出的例外即使沒有被處理,該回呼函數也是能被執行的。
register_shutdown_function(callback functionName[,argument1,argument2,...]);
例如:
-
-
- function shutdownfunction(){
- echo 'script is end';
- }
- register_shutdown_function("shutdown_function"shut;
複製程式碼
因為shutdownfunction() 在腳本結束時被執行,所以這個回呼函數之內可以調用腳本中任意位置的函數,即使該函數定義在錯誤拋出位置之後(函數定義是在腳本編譯期完成的) 。
四、trigger_error(string errorMsg[,int user_error_type])
此函數用於主動觸發一個錯誤: user_error_type 只能是 E_ALL、E_USER_ERROR、 E_USER_WARNING、 E_USER_NOTICE 或其組合的值。
set_error_handler(callback functionName[,user_error_type]); // 為 trigger_error() 設定一個回呼函數來處理錯誤,包括系統拋出的錯誤和使用者使用 trigger_error() 函數觸發的錯誤。
可選參數 user_error_type :
如果設定此參數,則 trigger_error 拋出的錯誤類型符合 在user_error_type 的定義範圍才能觸發回呼函數。
這個值的設定類似 error_reporting() 函數 。
第一個參數(callbeck functionName):
一個函數名,函數 可以有 5 個參數,其中前 2 個必選,依序為:
trigger_error 拋出的user_error_type、trigger_error 拋出的errorMsg、拋出錯誤的檔案的絕對路勁、拋出錯誤的行號、拋出錯誤時的上下文環境(一個數組,包含了trigger_error() 所在作用域內的所有變數、函數、類別等資料)
回呼函數的回傳值: 如果傳回 false ,系統錯誤處理機制仍繼續拋出該錯誤,則傳回 true 或 無回傳值 則消除錯誤。
trigger_error() 觸發的錯誤不會被 try-catch 異常捕獲語句捕獲。
您可能感興趣的文章:
PHP 異常處理相關知識
使用php異常處理類別Exception的範例
php中的異常處理、錯誤的拋出及錯誤回呼函數
一個簡單的php自訂異常類別
學習php錯誤與異常設定
|