PHP開発における例外処理の基本チュートリアル
1.異常とは何ですか?
例外は、指定されたエラーが発生したときにスクリプトの通常のフローを変更するために使用されます。
PHP 5 は、新しいオブジェクト指向のエラー処理メソッドを提供します。
例外処理は、指定されたエラー (例外) 状況が発生したときにスクリプトの通常のフローを変更するために使用されます。この状況を例外と呼びます。
例外がトリガーされると、通常は次のことが起こります:
現在のコードの状態が保存されます
コードの実行が事前定義された (カスタム) 例外ハンドラー関数に切り替わります
状況に応じて、ハンドラー保存されたコード状態からコード実行を再開したり、スクリプト実行を終了したり、コード内の別の場所からスクリプト実行を継続したりすることができます
さまざまなエラー処理方法を示します:
例外の基本的な使用方法
-
カスタム例外ハンドラー
複数の例外
例外を再スローする
トップレベルの例外ハンドラーを設定する
注: 例外はエラー状況でのみ使用する必要があり、別の例外にジャンプするために使用する必要はありませんコード内の指定された位置にあります。
2. 例外の基本的な使用法
例外がスローされると、後続のコードは実行を続行せず、PHP は一致する「キャッチ」コード ブロックを見つけようとします。 。
例外がキャッチされず、 set_Exception_handler() を使用して適切に処理されなかった場合、重大なエラー (致命的エラー) が発生し、「Uncaught Exception」エラー メッセージが出力されます。
例外をキャッチせずにスローしてみましょう:
コードは次のとおりです:
<?php // 创建一个有异常处理的函数 function checkNum($number) { if($number>1) { throw new Exception("Value must be 1 or below"); } return true; } // 触发异常 checkNum(2); ?>
次のような出力が得られます:
3、Try、throw and catch
上の例に見られるエラーを回避するには、例外を処理する適切なコードを作成する必要があります。
適切な例外処理コードには以下を含める必要があります:
Try - 例外を使用する関数は「try」コード ブロック内に配置する必要があります。例外がトリガーされない場合、コードは通常どおり実行を続行します。ただし、例外がトリガーされると、例外がスローされます。
Throw - 例外をトリガーする方法を指定します。各「スロー」は少なくとも 1 つの「キャッチ」に対応する必要があります。
Catch - 「catch」コード ブロックは例外をキャッチし、例外情報を含むオブジェクトを作成します。
例外をトリガーしてみましょう:
コードは次のとおりです
<?php // 创建一个有异常处理的函数 function checkNum($number) { if($number>1) { throw new Exception("变量值必须小于等于 1"); } return true; } // 在 try 块 触发异常 try { checkNum(2); // 如果抛出异常,以下文本不会输出 echo '如果输出该内容,说明 $number 变量'; } // 捕获异常 catch(Exception $e) { echo 'Message: ' .$e->getMessage(); } ?>
出力は右に示すとおりです
例の説明:
上記のコードは例外をスローし、それをキャッチします:
checkNum()関数を作成します。数値が 1 より大きいかどうかを検出します。その場合は、例外をスローします。
「try」コードブロックで checkNum() 関数を呼び出します。
checkNum()関数で例外がスローされます。
「catch」コード ブロックは例外を受け取り、例外情報を含むオブジェクト ($e) を作成します。
この例外オブジェクトから $e->getMessage() を呼び出して、この例外からのエラー メッセージを出力します。
ただし、「各スローはキャッチに対応する必要がある」という原則に従うために、見逃したエラーを処理する最上位の例外ハンドラーをセットアップできます。
4. カスタム例外クラスを作成する
カスタム例外ハンドラーの作成は非常に簡単です。 PHP で例外が発生したときに関数を呼び出すことができる特殊なクラスを作成しただけです。このクラスは例外クラスの拡張である必要があります。
このカスタム例外クラスは、PHP の例外クラスのすべてのプロパティを継承しており、カスタム関数を追加できます。
例外クラスの作成を開始します:
コードは次のとおりです
<?php class customException extends Exception { public function errorMessage() { // 错误信息 $errorMsg = '错误行号 '.$this->getLine().' in '.$this->getFile() .': <b>'.$this->getMessage().'</b> 不是一个合法的 E-Mail 地址'; return $errorMsg; } } $email = "someone@example...com"; try { // 检测邮箱 if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE) { // 如果是个不合法的邮箱地址,抛出异常 throw new customException($email); } } catch (customException $e) { //display custom message echo $e->errorMessage(); } ?>
出力結果は右の図に示されています
この新しいクラスは、古い例外クラスのコピーに、errorMessage( ) 関数。古いクラスのコピーであるため、古いクラスからプロパティとメソッドが継承され、getLine()、getFile()、getMessage() などの例外クラスのメソッドを使用できます。
例の説明:
上記のコードは例外をスローし、カスタム例外クラスを通じてそれをキャッチします:
CustomException() クラスは、古い例外クラスの拡張として作成されます。このようにして、古い例外クラスのすべてのプロパティとメソッドを継承します。
errorMessage()関数を作成します。電子メール アドレスが無効な場合、この関数はエラー メッセージを返します。
$email 変数を不正な電子メール アドレス文字列に設定します。
電子メール アドレスが無効であるため、「try」コード ブロックを実行して例外をスローします。
「catch」コードブロックは例外をキャッチし、エラーメッセージを表示します
5. 複数の例外
スクリプトに複数の例外を使用して、複数の状況を検出できます。
複数の if..else コード ブロックまたは switch コード ブロックを使用したり、複数の例外をネストしたりできます。これらの例外は、異なる例外クラスを使用し、異なるエラー メッセージを返す可能性があります:
コードは次のとおりです
<?php class customException extends Exception { public function errorMessage() { // 错误信息 $errorMsg = '错误行号 '.$this->getLine().' in '.$this->getFile() .': <b>'.$this->getMessage().'</b> 不是一个合法的 E-Mail 地址'; return $errorMsg; } } $email = "someone@example.com"; try { // 检测邮箱 if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE) { // 如果是个不合法的邮箱地址,抛出异常 throw new customException($email); } // 检测 "example" 是否在邮箱地址中 if(strpos($email, "example") !== FALSE) { throw new Exception("$email 是 example 邮箱"); } } catch (customException $e) { echo $e->errorMessage(); } catch(Exception $e) { echo $e->getMessage(); } ?>
インスタンスの説明:
上記のコードは 2 つの条件をテストし、条件のいずれかが true でない場合は、例外が発生します。
CustomException() クラスは、古い例外クラスの拡張として作成されました。このようにして、古い例外クラスのすべてのプロパティとメソッドを継承します。
errorMessage()関数を作成します。電子メール アドレスが無効な場合、この関数はエラー メッセージを返します。
$email 変数を、有効な電子メール アドレスであるが、文字列「example」を含む文字列に設定します。
「try」コード ブロックを実行すると、最初の条件では例外はスローされません。
メールには「example」という文字列が含まれているため、2 番目の条件により例外がトリガーされます。
「catch」コード ブロックは例外をキャッチし、適切なエラー メッセージを表示します。
customException クラスが例外をスローしたが、customException がキャッチされず、基本例外のみがキャッチされた場合、例外はそこで処理されます。
6. 例外を再スローする
例外がスローされたときに、標準の方法とは異なる方法で処理したい場合があります。例外は「catch」ブロックで再度スローできます。
スクリプトはシステムエラーをユーザーから隠す必要があります。システム エラーはプログラマにとって重要かもしれませんが、ユーザーはそれらに興味がありません。ユーザーが使いやすくするために、よりユーザーフレンドリーなメッセージを付けて例外を再度スローできます:
コードは次のとおりです
<?php class customException extends Exception { public function errorMessage() { // 错误信息 $errorMsg = $this->getMessage().' 不是一个合法的 E-Mail 地址。'; return $errorMsg; } } $email = "someone@example.com"; try { try { // 检测 "example" 是否在邮箱地址中 if(strpos($email, "example") !== FALSE) { // 如果是个不合法的邮箱地址,抛出异常 throw new Exception($email); } } catch(Exception $e) { // 重新抛出异常 throw new customException($email); } } catch (customException $e) { // 显示自定义信息 echo $e->errorMessage(); } ?>
出力は右側に表示されます
例の説明:
上記のコードはメールアドレスを検出します。「example」という文字列が含まれていますか?その場合は、再度例外をスローします:
CustomException() クラスは、古い例外クラスの拡張として作成されました。このようにして、古い例外クラスのすべてのプロパティとメソッドを継承します。
errorMessage() 関数を作成します。電子メール アドレスが無効な場合、この関数はエラー メッセージを返します。
$email 変数を、有効な電子メール アドレスであるが、文字列「example」を含む文字列に設定します。
"try" ブロックには、例外を再度スローできるように別の "try" ブロックが含まれています。
メールに「example」という文字列が含まれているため、例外がトリガーされます。
「catch」コードブロックは例外をキャッチし、「customException」を再スローします。
「customException」をキャッチし、エラーメッセージを表示します。
現在の「try」ブロックで例外がキャッチされない場合は、より高いレベルの catch ブロックを探します。
7. 最上位の例外ハンドラーを設定します
set_Exception_handler() 関数は、キャッチされなかった例外をすべて処理するユーザー定義関数を設定できます。
コードは次のとおりです
<?php function myException($exception) { echo "<b>Exception:</b> " , $exception->getMessage(); } set_exception_handler('myException'); throw new Exception('Uncaught Exception occurred'); ?>
出力は右側に表示されます
上記のコードには「catch」ブロックはなく、代わりにトップレベルの例外ハンドラーがトリガーされます。この関数は、キャッチされなかった例外をすべてキャッチするために使用する必要があります。
8. 例外ルール
例外処理を必要とするコードは、潜在的な例外をキャッチするために try コード ブロックに配置する必要があります。
各 try または throw コード ブロックには、対応する catch コード ブロックが少なくとも 1 つ必要です。
複数の catch ブロックを使用して、さまざまな種類の例外をキャッチします。
例外は、try ブロック内の catch ブロックでスロー (再度スロー) できます。
つまり、例外がスローされた場合は、それをキャッチする必要があります。