PHPエラー処理方法例

小云云
小云云オリジナル
2018-03-07 10:03:511566ブラウズ

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

PHPでは通常の状況ではエラーが出力されますが、一部のフレームワークでは、フレームワーク自体が独自の処理機構を持っているか、フレームワークで処理されている可能性があります。通常、これらの関数設定は次のとおりです:

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

error_reporting(report_level)

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

e_user_errorは、php function trigger_error()設定を使用してプログラマーによって設定されたe_errorE_USER_WARNINGPHP関数trigger_errorを使用してプログラマーによって設定されるE_WARNINGに似た、致命的ではないユーザー生成の警告E_USER_NOTICEユーザーが生成した通知。PHP 関数trigger_errorを使用してプログラマーによって設定されたE_NOTICEに似ています

定数

説明

1

E_ERROR

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

2

E_WARNING

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

4

E_PARSE

コンパイル時間分析エラー。解析では、実行時にアナライザーによって生成されたエラー

8

E_NOTICE

についてのみ通知する必要があります。見つかったスクリプトはバグである可能性がありますが、通常、スクリプトを実行すると、PHP の起動中に

16

E_CORE_ERROR

致命的なエラーが発生する可能性があります。これは、PHP 起動時の PHP コアの E_ERROR

32

E_CORE_WARNING

警告に似ています。これは、PHP コアでの E_WARNING

64

E_COMPILE_ERROR

の致命的なコンパイル時エラーのようなものです。これは、Zend スクリプト エンジンによって生成された E_ERROR を渡すようなものです

128

E_COMPILE_WARNING

致命的ではないコンパイル時警告。これは、zendスクリプトエンジンが生成したzendスクリプトエンジンによって生成されたエラーのようなものですe_warning256

に似ています

512

1024

2048

E_STRICT

実行時通知。 PHP では、コードの相互運用性と互換性を高めるためにコードを変更することをお勧めします

4096

E_RECOVERABLE_ERROR

E_ERROR と同様にキャッチ可能な致命的なエラーですが、ユーザー定義のプログラム キャプチャで処理できます (set_error_handler を参照) ())

8191

E_ALL

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

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

2.set_error_handler()

定義と使用法

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

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

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

構文

set_error_handler(error_function,error_types)

パラメータ

説明

error_function

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

error_types

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

ヒント: この関数が使用される場合、標準の PHP エラー処理関数は完全にバイパスされます。必要に応じて、ユーザー定義のエラー ハンドラーはスクリプトを終了 (die()) する必要があります。

注:スクリプト実行前にエラーが発生します。この時点ではカスタムプログラムが登録されていないため、カスタムエラーハンドラは使用されません。

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


/**
 *
 * @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_message

必需。规定错误消息。长度限制为 1024 个字符。

error_types

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

  • 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 data-filtered="filtered">";
    break;
  case E_USER_WARNING:
    echo "WARNING:<br data-filtered="filtered">";
    break;
  case E_USER_NOTICE:
    echo "NOTICE:<br data-filtered="filtered">";
    break;
  default:
    break;
  }
  echo "错误编号:" . $level . " <br data-filtered="filtered">";
  echo "错误信息:" . $msg;
}
//注册错误处理器
set_error_handler(&#39;my_error&#39;);
if (89 > 8) {
  //调用错误触发器
  trigger_error(&#39;这是错误啊&#39;, E_USER_WARNING);
}

运行结果如下:

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

相关推荐:

php错误处理和日志记录

PHP错误与异常调试视频教程资源分享

PHP错误机制

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

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