set_error_handler() 関数は、ユーザー定義のエラー処理関数を設定します。この関数は、実行時にユーザー独自のエラー処理メソッドを作成するために使用されます。この関数は古いエラー ハンドラーを返すか、失敗した場合は null を返します。いくつかの例を見てみましょう。
set_error_handler()
PHP は 4.1.0 以降、カスタム エラー処理ハンドル関数 set_error_handler() を提供していますが、これを知っているスクリプト作成者はほとんどいません。 set_error_handler 関数はエラーパスの漏洩を防ぐことができますが、もちろん他の関数もあります。
1. エラーをブロックするために使用できます。 エラーが発生すると、一部の情報がユーザーに公開され、ハッカーが Web サイトを攻撃するツールとなる可能性が非常に高くなります。 次に、ユーザーにあなたのレベルが非常に低いと感じさせます。
2. エラー情報を書き留めて、運用環境の問題をタイムリーに発見できます。
3. エラーが発生した場合、対応する処理を実行して、事前定義されたエラー ページにジャンプして、ユーザー エクスペリエンスを向上させることができます。
4. デバッグ ツールとして使用できます。場合によっては、運用環境で何かをデバッグする必要がありますが、それを使用しているユーザーに影響を与えたくない場合があります。
5. 。 。 。
set_error_handler の使用法は次のとおりです:
view sourceprint?1 string set_error_handler ( callback error_handler [, int error_types])
error_reporting(); を使用して表示されるエラー メッセージには、エラー メッセージ、エラー ファイルの絶対アドレス、およびエラーが発生した行数の 3 つの部分が含まれます。実際には、別の種類のエラーがあります。 Array ( [type] => 1 [message] => 未定義メソッド SomeClass::somemedthod() の呼び出し [file] => /home/zhangy/www/aaaa/stasdf.php [line] => 67 )、ページの絶対パスを他人に公開しないことが最善です。そうしないと、一部の人が苦情を言う機会が与えられるため、多くの人は ini_set("display_errors",0); を使用して直接ブロックします。エラーメッセージ。これは不便です。情報を読みたい場合はどうすればよいでしょうか。チェックするたびにコードを変更する必要がありますか、それともApacheの設定を変更して再起動する必要がありますか?
PHP には、この問題を解決する関数 set_error_handler があります
使い方は以下の通りです
混合 set_error_handler ( callback $error_handler [, int $error_types = E_ALL | E_STRICT ] )
PHP 関数 register_shutdown_function もこの問題を解決できます
使い方は以下の通りです
int register_shutdown_function ( string $func )
個人的には、エラー報告関数を自分で定義することには少なくとも 3 つの利点があると感じています
1. ファイルの絶対パスは表示されないので安全です
2. エラーメッセージが表示された場合でも、致命的なエラーなどをユーザーが認識できないようにエラーメッセージを処理できます。ユーザーエクスペリエンスの向上
3. プロジェクトがオンラインになった後も、ユーザーの問題解決を支援する必要がある場合があります。このとき、コードの変更は避けられませんが、エラー メッセージは報告され、ユーザーには表示されないようにしたいと考えています。今回はこのように set_error_handler を使用します。関数は非常にクールです。
ちょっとしたテストをしてみました
エラー報告(0);
register_shutdown_function('error_alert');
関数error_alert()
{
if(is_null($e = error_get_last()) === false)
{
set_error_handler('errorHandler');
if($e['type'] == 1){
trigger_error("致命的なエラー", E_USER_ERROR);
}elseif($e['type'] == 8){
trigger_error("通知", E_USER_NOTICE);
}elseif($e['type'] == 2){
trigger_error("警告", E_USER_WARNING);
}その他{
trigger_error("その他", E_USER_OTHER);
}
}その他{
echo "エラーなし";
}
}
set_error_handler('errorHandler');
関数 errorHandler($errno, $errstr, $errfile, $errline,$errcontext)
{
スイッチ ($errno) {
ケース E_USER_ERROR:
echo "私のエラー [$errno] $errstr
n";
echo " ファイル $errfile の $errline 行で致命的なエラーが発生しました";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
n";
休憩
ケース E_USER_WARNING:
echo "私の警告 [$errno] $errstr
n";
echo " ファイル $errfile の $errline 行で警告";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
n";
休憩
ケース E_USER_NOTICE:
echo "私の通知 [$errno] $errstr
n";
echo " ファイル $errfile の $errline 行に注意してください";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
n";
休憩
デフォルト:
echo "不明なエラーの種類: [$errno] $errstr
n";
echo " ファイル $errfile の $errline 行で警告";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
n";
休憩
}
true を返します;
}
クラス SomeClass {
パブリック関数 someMethod() {
}
}
SomeClass::someMedthod();
$a="asdf";
foreach($a を $d){
エコー $d;
}
?>
ここで、カスタム エラー処理を使用して実際のパスを除外します。変数 $admin があるとします。これを使用して、訪問者が管理者であるかどうかを判断します (この判断は、IP またはログインしたユーザー ID によって行うことができます)
//Admin は管理者の ID 決定であり、true は管理者です。
//カスタム エラー処理関数には、これらの 4 つの入力変数 $errno、$errstr、$errfile、$errline が必要です。そうでない場合、関数は無効になります。
関数 my_error_handler($errno,$errstr,$errfile,$errline)
{
// 管理者ではない場合は、実際のパスをフィルタリングします
もし(!管理者)
{
$errfile=str_replace(getcwd(),"",$errfile);
$errstr=str_replace(getcwd(),"",$errstr);
}
スイッチ($errno)
{
ケース E_エラー:
echo "エラー: [ID $errno] $errstr (行: $errfile の $errline) n";
echo "プログラムの実行が停止しました。管理者に連絡してください。";
//エラーレベルのエラーが発生した場合はスクリプトを終了します
出る
休憩
ケース E_警告:
echo "警告: [ID $errno] $errstr (行: $errfile の $errline) n";
休憩
デフォルト:
//通知レベルのエラーを表示しません
休憩
}
}
このようにエラー処理関数がカスタマイズされていますが、このカスタム関数にエラー処理を引き継ぐにはどうすればよいでしょうか。
// クラスに申し込む
set_error_handler(array(&$this,"appError"));
//メソッド例
set_error_handler("my_error_handler");
とても簡単です。このようにして、セキュリティとデバッグの利便性の間の矛盾をうまく解決できます。また、Web サイトのスタイルに合わせてエラー メッセージをより美しくすることも考えられます。
上記の例では、エラー メッセージをオフにし、独自の関数を使用してエラーを処理しました。上記のページでは、errorHandler を使用して、報告されたエラー メッセージを制御および処理できます。
要約すると、set_error_handler の 3 つの使用法を次に示します。
PHPコード
クラス CallbackClass {
関数 CallbackFunction() {
// $this を参照します
}
関数 StaticFunction() {
// $this を参照しません
}
}
function NonClassFunction($errno, $errstr, $errfile, $errline) {
}
// 3 つのメソッドは次のとおりです:
1: set_error_handler(‘NonClassFunction’); // 通常の関数 NonClassFunction に直接移動します
2: set_error_handler(array(‘CallbackClass’, ‘StaticFunction’)); // CallbackClass クラスの静的メソッド StaticFunction
に移動します。
3: $o =& new CallbackClass();
set_error_handler(array($o, ‘CallbackFunction’)); // クラスのコンストラクターに移動します。これは、以下の 4 番目の項目と基本的に同じです。
4. $o = new CallbackClass();
// 以下も役に立つかもしれません:
クラス CallbackClass {
関数 CallbackClass() {
set_error_handler(array(&$this, ‘CallbackFunction’)); // & は重要です
}
関数 CallbackFunction() {
// $this を参照します
}
}