ホームページ >バックエンド開発 >PHPチュートリアル >PHP のエラー処理と例外処理メカニズムの詳細な説明
この記事の内容は、PHP のエラー処理と例外処理の仕組みを詳しく説明したもので、必要な方は参考にしてください。 http://www.cnblogs.com/ より転載。 52php/ p/5665495.html
PHP プログラムを作成する場合、エラー処理は重要な部分です。プログラムにエラー検出コードがないと、プロフェッショナルらしくなく、セキュリティ リスクへの扉が開かれます
例:
2 3 4 |
りー |
1 2 3 4 5 6 7 |
<?php if (file_exists('test.txt')) { $f = fopen('test.txt', 'r'); // 使用完后关闭 fclose($f); } ?> |
A. 単純な die() ステートメントは、exit() と同等です。
if (!file_exists('aa.txt')) { die('文件不存在'); } else { // 执行操作 } // 如果上面die()被触发,那么这里echo接不被执行 echo 'ok';
简洁写法:
1 2 |
file_exits('aaa.txt') or die('文件不存在'); echo 'ok'; |
B. カスタム エラーとエラー トリガー
1. エラー ハンドラー (カスタム エラー、通常は構文エラーの処理に使用されます)
少なくとも 2 つのパラメーターを処理する機能が必要なカスタム エラー関数 (ハンドラー) を作成します。 (error_level および errormessage)、ただし最大 5 つのパラメーター (error_file、error_line、error_context) を受け入れることができます
構文:
function error_function($error_level, $error_message, $error_file, $error_line, $error_context)
// 作成後set_error_handler(); 関数を書き直す必要があります
set_error_handler('error_function', E_WARNING); // ここで、error_function は上で作成したカスタム プロセッサ名に対応し、2 番目のパラメータはカスタム エラー ハンドラー エラー レベルを使用します。
エラー レポート レベル (知っておくだけ)
これらのエラー レポート レベルは、エラー ハンドラーが処理するように設計されているさまざまな種類のエラーです。値 | 定数 | 説明 |
---|---|---|
2 | E_WARNING | 致命的ではない実行時エラー。スクリプトの実行を一時停止しないでください。 |
8 | E_NOTICE | 実行時通知。スクリプト検出エラーは発生する可能性がありますが、スクリプトが正常に実行されているときに発生することもあります。 |
256 | E_USER_ERROR | 致命的なユーザー生成エラー。これは、プログラマが PHP 関数trigger_error()を使用して設定する E_ERROR に似ています。 |
512 | E_USER_WARNING | 致命的ではないユーザー生成の警告。これは、プログラマが PHP 関数 trigger_error() を使用して設定する E_WARNING に似ています。 |
1024 | E_USER_NOTICE | ユーザーが生成した通知。これは、プログラマが PHP 関数trigger_error()を使用して設定する E_NOTICE に似ています。 |
4096 | E_RECOVERABLE_ERROR | キャッチ可能な致命的なエラー。 E_ERROR と似ていますが、ユーザー定義のハンドラーによってキャッチされる可能性があります。 (set_error_handler() を参照) |
8191 | E_ALL | レベル E_STRICT を除くすべてのエラーと警告。 (PHP 6.0 では、E_STRICT は E_ALL の一部です) |
2、错误触发器(一般用于处理逻辑上的错误)
需求:比如要接收一个年龄,如果数字大于120,就认为是一个错误
传统方法:
1 2 3 4 5 6 |
<?php if ($age > 120) { echo '年龄错误'; exit(); } ?> |
トリガーを使用:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
<?php if ($age > 120) { // trigger_error('错误信息'[,'错误等级']); 这里错误等级为可选项,用于定义该错误的级别 // 用户定义的级别包含以下三种:E_USER_WARNING 、E_USER_ERROR 、E_USER_NOTICE trigger_error('年龄错误'); // 这里是调用的系统默认的错误处理方式,我们也可以用自定义处理器 } /** * 自定义处理器,与上面相同 */ function myerror($error_level, $error_message) { echo 'error text'; } // 同时需要改变系统默认的处理函数 set_error_handler('myerror', E_USER_WARNING); // 同上面,第一个参数为自定义函数的名称,第二个为错误级别【这里的错误级别通常为以下三种:E_USER_WARNING 、E_USER_ERROR 、E_USER_NOTICE】 // 现在再使用trigger_error就可以使用自定义的错误处理函数了 ?> |
練習問題:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
<?php date_default_timezone_set('PRC'); function myerror($error_level, $error_message) { $info = "错误号:$error_level"; $info .= "错误信息:$error_message"; $info .= '发生时间:' . date('Y-m-d H:i:s'); $filename = 'aa.txt'; if (!$fp = fopen($filename, 'a')) { echo '创建文件' . $filename . '失败'; } if (is_writeable($filename)) { if (!fwrite($fp, $info)) { echo '写入文件失败'; } else { echo '已成功记录错误信息'; } fclose($fp); } else { echo '文件' . $filename . '不可写'; } exit(); } set_error_handler('myerror', E_WARNING); $fp = fopen('aaa.txt', 'r'); ?> |
C. エラーログ
デフォルトでは、php.ini の error_log 設定に従って、PHP はエラーレコードをサーバーのエラー記録システムまたはファイルに送信します。エラー レコードは、error_log() 関数を使用してファイルまたはリモートの宛先に送信できます。
構文:
error_log(error[, type, destination, headers])
type 部分は通常 3 で、エラー情報を追加することを意味します。 file の後に、元のコンテンツを上書きせずに、 destination は保存されたファイルまたはリモートの宛先を表します。例: error_log("$error_info",3,"errors.txt");
2。取り扱い 【ポイント】
1. 基本文法
3 4 5 6 7 8 9 10 |
<?php try { // 可能出现错误或异常的代码 //catch 捕获 Exception是PHP已定义好的异常类 } catch (Exception $e) { // 对异常处理,方法: //1、自己处理 //2、不处理,可以再次抛出 throw new Exception('xxx'); } ?> |
2. ハンドラーには以下を含める必要があります:
try - 例外を使用する関数は、「try」コード ブロック内に配置する必要があります。例外がトリガーされない場合、コードは通常どおり実行を続行します。ただし、例外がトリガーされると、例外がスローされます。
throw - 例外をトリガーする方法を指定します。各「スロー」は少なくとも 1 つの「キャッチ」に対応する必要があります。
catch - 「キャッチ」コード ブロックは例外をキャッチし、例外情報を含むオブジェクトを作成します。
1
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
<?php /** * 创建可抛出一个异常的函数 */ function checkNum($number) { if ($number > 1) { throw new Exception("Value must be 1 or below"); } return true; } // 在 "try" 代码块中触发异常 try { checkNum(2); // 如果异常被抛出,那么下面一行代码将不会被输出 echo 'If you see this, the number is 1 or below'; } catch (Exception $e) { // 捕获异常 echo 'Message: ' . $e->getMessage(); } ?> |
上面代码将获得类似这样一个错误:
1 |
Message: Value must be 1 or below |
例の説明:
上記のコードは例外をスローし、それをキャッチします:
数値が 1 より大きいかどうかをチェックし、1 より大きい場合は例外をスローする checkNum() 関数を作成します。
「try」コードブロックで checkNum() 関数を呼び出します。
checkNum()関数で例外がスローされます。
「catch」コード ブロックは例外を受け取り、例外情報を含むオブジェクト ($e) を作成します。
この例外オブジェクトから $e->getMessage() を呼び出して、この例外からのエラー メッセージを出力します。
ただし、「各スローはキャッチに対応する必要がある」という原則に従うために、見逃したエラーを処理するトップレベルの例外ハンドラーをセットアップできます。
set_Exception_handler() 関数は、キャッチされなかった例外をすべて処理するユーザー定義関数を設定できます。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
<?php /** * 设置一个顶级异常处理器 */ function myexception($e) { echo 'this is top exception'; } // 修改默认的异常处理器 set_exception_handler("myexception"); try { $i = 5; if ($i < 10) { throw new Exception('$i must greater than 10'); } } catch (Exception $e) { // 处理异常 echo $e->getMessage() . '<br/>'; // 不处理异常,继续抛出 throw new Exception('errorinfo'); // 也可以用throw $e 保留原错误信息; } ?> |
カスタム例外クラスを作成する
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
<?php class customException extends Exception { public function errorMessage() { $errorMsg = 'Error on line ' . $this->getLine() . ' in ' . $this->getFile() . ': <b>' . $this->getMessage() . '</b> is not a valid E-Mail address'; return $errorMsg; } } // 使用 try { throw new customException('error message'); } catch (customException $e) { echo $e->errorMessage(); } ?> |
複数のキャッチを使用して、さまざまな状況でエラー メッセージを返すことができます
123456 78 91011 12 13 14 15 |
<?php try { $i = 5; if ($i > 0) { throw new customException('error message'); // 使用自定义异常类处理 } if ($i < -10) { throw new Exception('error2'); // 使用系统默认异常处理 } } catch (customException $e) { echo $e->getMessage(); } catch (Exception $e1) { echo $e1->getMessage(); } ?> |
异常的规则
需要进行异常处理的代码应该放入 try 代码块内,以便捕获潜在的异常。
每个try或throw代码块必须至少拥有一个对应的 catch 代码块。
使用多个 catch 代码块可以捕获不同种类的异常。
可以在try代码内的catch 代码块中再次抛出(re-thrown)异常。
简而言之:如果抛出了异常,就必须捕获它。
相关推荐:
以上がPHP のエラー処理と例外処理メカニズムの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。