PHP エラーと例外処理

墨辰丷
墨辰丷オリジナル
2018-06-09 09:35:161494ブラウズ

この記事では主に PHP のエラーと例外処理について紹介します。興味のある方はぜひ参考にしてください。

日々のプロジェクト開発プロセスでは、予期せぬ例外やエラーが常に発生します。これらに比較的うまく対処しないと、プログラムは非常にプロフェッショナルに見えず、失敗する可能性が高くなります。他の人がシステムを攻撃するための有効な情報、一部のエラー例外によってスクリプトの実行が終了する場合は、コードを最初から確認するしかありません。プロジェクト内のコードは私たちにとって非常に重要ですが、プロジェクト開発プロセス中に例外やエラーを迅速かつ正確に特定し、それに応じて処理するにはどうすればよいでしょうか? この記事では、エラーと例外処理についての私自身の理解を基にしています。皆さんと共有します。誰もがお互いから学び、思い出させる役割を果たします。

システム エラー ハンドラー:

PHP 通常の状況では、エラーは正常に出力されますが、一部のフレームワークでは、エラー出力に影響を与える可能性があります。独自の処理メカニズム、またはコード内で処理される場合があります。通常、これらの関数設定は次のとおりです。

1.error_reporting(); PHP のエラー レベルを設定し、現在のレベルを返します。 error_reporting(report_level)

パラメータ レベルが指定されていない場合は、現在のエラー レベルが返されます。次の項目は、レベルの可能な値です:

#Value##1##E_PARSEコンパイル時間分析エラー。解析ではエラーのみが生成されます。 #8E_NOTICEランタイム通知。見つかったスクリプトはバグである可能性がありますが、通常はスクリプトの実行時に発生する可能性もあります。16##32PHP## に似ています。 ##E_COMPILE_ERROR#E_COMPILE_WARNING致命的ではないコンパイル時警告。これは、##256 を生成するのと似ています。 関数 と同様2048E_STRICT

Constant

説明

E_ERROR

##致命的なランタイムエラー。このエラーは再利用できません。スクリプトの実行が中断されました。

#2

E_WARNING

致命的ではない実行時警告。スクリプトの実行は中断されません。

#4

E_CORE_ERROR

PHP の起動時に致命的なエラーが発生しました。これは、PHP のコアの E_ERROR

## のようなものです。

#E_CORE_WARNING

起動時の警告。これは、PHP## のコアの #E_WARNING

64

致命的なコンパイル時エラー。これは、Zend スクリプト エンジンによって生成される ##E_ERROR

128## のようなものです。

Zend

スクリプト エンジンを通じて E_WARNING

E_USER_ERROR

プログラマが PHP

trigger_error() を使用する方法と同様の、ユーザー生成の致命的なエラー 設定 #E_ERROR

512

E_USER_WARNING

致命的ではないユーザー生成の警告、これプログラマが PHP 関数 trigger_error # を使用して設定する E_WARNING

##1024

E_USER_NOTICE

ユーザー生成の通知。これはプログラマが PHP

関数を使用する方法と似ています。 trigger_error SET E_NOTICE

実行時通知。 PHPこのコードの相互運用性と互換性を支援するために、コードに推奨される変更を行います

4096

E_RECOVERABLE_ERROR

E_ERROR に似たキャッチ可能な致命的なエラーですが、ユーザー定義のハンドラー キャプチャにすることができます ( を参照) set_error_handler())

8191

E_ALL

レベル E_STRICT を除くすべてのエラーと警告 (PHP6.0 では、E_STRICTE_ALL## になります) #########################################

$level が 0 の場合、エラー出力がオフになる、つまりエラーが出力されないことに注意してください。

2.set_error_handler()

定義と使用法

set_error_handler() 関数は、ユーザー定義のエラー処理関数を設定します。

この関数は、実行時にユーザー独自のエラー処理メソッドを作成するために使用されます。

この関数は古いエラー ハンドラーを返すか、失敗した場合は null を返します。

構文

set_error_handler(error_function,error_types)

ヒント: この関数を使用すると、標準の PHP エラー処理関数は完全にバイパスされます。必要に応じて、ユーザー定義のエラー ハンドラーはスクリプトを終了 (die()) する必要があります。 in スクリプト実行前にエラーが発生します。この時点ではカスタムプログラムが登録されていないため、カスタムエラーハンドラは使用されません。

テスト コードは次のとおりです:

/**
 *
 * @param type $error_level 错误级别
 * @param type $error_message    错误信息
 * @param type $error_file 可选 错误文件
 * @param type $error_line 可选 错误行
 * @param type $error_context 可选。规定一个数组,包含了当错误发生时在用的每个变量以及它们的值。
 */
function my_error($error_level, $error_message, $error_file, $error_line, $error_context) {
  echo date('Y-m-d H:i:s') . $error_level . $error_message . $error_file . $error_line;
  var_dump($error_context);
}
set_error_handler('my_error', E_ALL);
print_r($a);

//上記の例から、my_error メソッドを登録すると、システムは元のエラー処理 error_fuction() メソッドを自動的に上書きすることがわかります。

上記プログラムの実行結果:


カスタム エラー トリガー

定義と使用法

trigger_error( ) 関数はユーザー定義のエラー メッセージを作成します。

trigger_error() は、ユーザーが指定した条件下でエラー メッセージをトリガーするために使用されます。これは、組み込みエラー ハンドラー、または set_error_handler() 関数で作成されたユーザー定義関数とともに使用されます。

不正なエラー タイプが指定された場合、この関数は false を返し、それ以外の場合は true を返します。

構文

trigger_error(error_message,error_types)

パラメータ

説明

error_function

必須。エラーが発生したときに実行する関数を指定します。

#error_types

オプション。ユーザー定義エラーをどのエラー報告レベルで表示するかを指定します。デフォルトは「E_ALL」です。

パラメータ説明エラーメッセージ必須。エラーメッセージを指定します。長さの制限は エラーの種類

1024

文字です。

可选。规定错误消息的错误类型。 可能的值:

  • E_USER_ERROR

  • E_USER_WARNING

  • E_USER_NOTICE

测试代码如下:

/**
 *
 * @param type $level
 * @param type $msg
 */
function my_error($level, $msg) {
  switch ($level) {
  case E_USER_ERROR:
    echo "ERROR:<br/>";
    break;
  case E_USER_WARNING:
    echo "WARNING:<br/>";
    break;
  case E_USER_NOTICE:
    echo "NOTICE:<br/>";
    break;
  default:
    break;
  }
  echo "错误编号:" . $level . " <br/>";
  echo "错误信息:" . $msg;
}
//注册错误处理器
set_error_handler(&#39;my_error&#39;);
if (89 > 8) {
  //调用错误触发器
  trigger_error(&#39;这是错误啊&#39;, E_USER_WARNING);
}

运行结果如下:

WARNING:
错误编号:512
错误信息:这是错误啊

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。

相关推荐:

php字符串及流程控制的方法

PHP实现全角字符转为半角的方法

php实现针对html标签中结束标签的检测与补全功能

以上がPHP エラーと例外処理の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。