ホームページ >バックエンド開発 >PHPチュートリアル >PHPのエラー処理を詳しく解説
PHP エラー処理の詳細な説明
エラー レポート
エラーの一般的な原因PHP プログラム 次の 3 つの領域:
1. 文法エラー
文法エラーは最も一般的であり、修正が簡単です。たとえば、コードにセミコロンがありません。このタイプのエラーは、スクリプトの実行を妨げます
# 2. 実行時エラー# この種のエラーは、通常、PHP スクリプトの実行を妨げませんが、現在行われている処理を妨げます。 。エラーを出力しますが、PHP スクリプトは実行を続けます
## 3. ロジックエラー## この種のエラーが最も厄介で、スクリプトの実行を妨げたり、エラー メッセージを出力したりすることはありません
[注意] php.ini設定ファイルのdisplay_errorsがデフォルトのonからoffに設定されている場合、エラーは表示されません
PHP スクリプト、ini_set( を呼び出すことができます) 関数、php.ini 設定ファイルを動的に設定します
ini_set("display_errors","On"); //すべてのエラー メッセージを表示します
エラーレベル
実は表の 13 種類のエラーは、注意レベル、警告レベル、エラー レベルの 3 つのカテゴリに分類できます。一般に、開発プロセス中、アテンション レベルのエラーは無視されます<?php
getType($a);//未定义变量,注意级别
echo "1111111111111111<br>"; getType();//未传入参数,警告级别
echo "222222222222222222222<br>";
getType3();//函数名错误,错误级别
echo "333333333333333333333<br>";
?>
デフォルトのエラー レベルでは、すべてのレベルのエラーが表示されます。 error_reporting = E_ALL
error_reporting = E_ALL
を # に変更します。 # #error_reporting = E_ALL & ~E_NOTICE
error_reporting = E_ALL & ~E_NOTICE
気付かないエラー (デフォルト値) をスローします
error_reporting = E_ERROR | E_PARSE | E_CORE_ERROR
error_reporting = E_ALL & ~(E_USER_ERROR | E_USER_WARNING | E_USER_NOTICE) ユーザー原因のエラーを除くすべてのエラーをレポートします
# PHP スクリプトでは、error_reporting() 関数を通じてエラー報告レベルを動的に設定できます
<?php error_reporting(E_ALL & ~E_NOTICE); getType($a);//注意级别 echo "1111111111111111<br>"; getType();//警告级别 echo "222222222222222222222<br>"; getType3();//错误级别 echo "333333333333333333333<br>";?>
カスタマイズされたエラー処理 エラー レポートの処理方法をカスタマイズします。これにより、標準の PHP エラー処理関数を完全にバイパスできるため、独自に定義した形式のエラー レポート、またはエラー レポートが印刷される場所を変更する次の状況では、エラー処理のカスタマイズを検討できます: 1. エラー情報を書き留め、運用環境での問題を迅速に発見する; 2. エラーをシールドする; 3. . エラーの出力を制御します。 ; 4. デバッグ ツールとして
# set_error_handler() 関数を使用してユーザー定義のエラー処理を設定します
<?php //error_reporting(E_ALL & ~E_NOTICE); //在php中注册一个函数来处理错误报告,替代默认的方式 set_error_handler("myerrorfun"); $mess = ""; //自定义错误报告处理函数 function myerrorfun($error_type, $error_message, $error_file, $error_line) { global $mess; $mess.="发生错误级别为{$error_type}类型, 错误消息<b>{$error_message}</b>, 在文件<font >{$error_file}</font>中, 第{$error_line}行。<br>"; } getType($a); echo "1111111111111111<br>"; getType(); echo "222222222222222222222<br>"; echo "--------------------------------------------<br>"; echo $mess; ?>
エラー ログ 一般に、プログラムは、プログラムの実行中にエラー情報を記録するためにエラー ログを保存します。また、エラー ログにはデフォルトの保存場所があります。エラー情報とエラーログの場所を変更できます
PHP.ini設定ファイルでは、エラーログに設定できる以下の項目があります
error_reporting = E_ALL
//すべてのエラーは PHP に送信されますdisplay_errors=Off
//エラー レポートを表示しませんlog_errors=On //ログ ステートメント レコードの場所を決定します
log_errors_max_log=1024 //各ログ項目の最大長
error_log=G:/myerror.log //エラーが書き込まれるファイルを指定
phpファイルでは、関数 error_log() を使用してエラー メッセージをカスタマイズできます。
<pre class="brush:php;toolbar:false"><?phperror_log("登录失败了!");?></pre>
例外処理
例外 (例外) 処理は、通常の動作を変更するために使用されます。指定されたエラーが発生したときにスクリプトの処理を実行するプロセスは、PHP5 の新しい重要な機能です。例外処理は、スケーラブルで保守が容易なエラー処理メカニズムであり、新しいオブジェクト指向のエラー処理メソッドを提供します
try{
使用try去包含可能会发生异常的代码
一旦出现异常try进行捕获异常,交给catch处理。
抛出异常语句:throw 异常对象。
}catch(异常对象参数){
在这里做异常处理。
}[catch(。,,){
.. .. ..
}]
<?php try { $error = 'Always throw this error'; throw new Exception($error); //创建一个异常对象,通过throw语句抛出 echo 'Never executed'; //从这里开始,try代码块内的代码将不会再被执行 } catch (Exception $e) { echo ‘Caught exception: ’.$e->getMessage()." "; //输出捕获的异常消息 } echo 'Hello World'; //程序没有崩溃继续向下执行?>
自定义异常
用户可以用自定义的异常处理类来扩展PHP内置的异常处理类。以下的代码说明了在内置的异常处理类中,哪些属性和方法在子类中是可访问和可继承的
<?phpclass Exception{ protected $message = 'Unknown exception'; // 异常信息 private $string; // __toString cache protected $code = 0; // 用户自定义异常代码 protected $file; // 发生异常的文件名 protected $line; // 发生异常的代码行号 private $trace; // backtrace private $previous; // previous exception if nested exception public function __construct($message = null, $code = 0, Exception $previous = null); final private function __clone(); // Inhibits cloning of exceptions. final public function getMessage(); // 返回异常信息 final public function getCode(); // 返回异常代码 final public function getFile(); // 返回发生异常的文件名 final public function getLine(); // 返回发生异常的代码行号 final public function getTrace(); // backtrace() 数组 final public function getPrevious(); // 之前的 exception final public function getTraceAsString(); // 已格成化成字符串的 getTrace() 信息 // Overrideable public function __toString(); // 可输出的字符串}?>
[注意]如果使用自定义的类来扩展内置异常处理类,并且要重新定义构造函数的话,建议同时调用parent::__construct()来检查所有的变量是否已被赋值。当对象要输出字符串的时候,可以重载__toString() 并自定义输出的样式
<?php /* 自定义的一个异常处理类,但必须是扩展内异常处理类的子类 */ class MyException extends Exception{ //重定义构造器使第一个参数 message 变为必须被指定的属性 public function __construct($message, $code=0){ //可以在这里定义一些自己的代码 //建议同时调用 parent::construct()来检查所有的变量是否已被赋值 parent::__construct($message, $code); } public function __toString() { //重写父类方法,自定义字符串输出的样式 return __CLASS__.":[".$this->code."]:".$this->message."<br>"; } public function customFunction() { //为这个异常自定义一个处理方法 echo "按自定义的方法处理出现的这个类型的异常<br>"; } }?>
<?php try { //使用自定义的异常类捕获一个异常,并处理异常 $error = '允许抛出这个错误'; throw new MyException($error); //创建一个自定义的异常类对象,通过throw语句抛出 echo 'Never executed'; //从这里开始,try代码块内的代码将不会再被执行 } catch (MyException $e) { //捕获自定义的异常对象 echo '捕获异常: '.$e; //输出捕获的异常消息 $e->customFunction(); //通过自定义的异常对象中的方法处理异常 } echo '你好呀'; //程序没有崩溃继续向下执行?>
相关参考:php教程
以上がPHPのエラー処理を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。