以下の例を見てください。
set_error_handler()
set_error_handler の使用方法は次のとおりです:
コードをコピーします コードは次のとおりです:
view sourceprint?1 string set_error_handler ( callback error_handler [, int error_types])
phpには、この問題を解決する関数set_error_handlerがあります
php関数 register_shutdown_function もこの問題を解決できます
1. ファイルの絶対パスは表示されないので安全です
2. エラーメッセージが表示された場合でも、致命的なエラーなどをユーザーが認識できないようにエラーメッセージを処理することができます。ユーザーエクスペリエンスの向上
3. プロジェクトがオンラインになった後も、ユーザーが問題を解決できるように支援する必要がある場合があります。その際には、エラー メッセージも報告され、ユーザーには表示されないようにする必要があります。このような関数は非常に優れています。
ちょっとしたテストをしてみました
リーリー
ここで、カスタム エラー処理を使用して実際のパスを除外します。変数 $admin があるとします。これを使用して、訪問者が管理者であるかどうかを判断します (この判断は、IP またはログインしたユーザー ID によって行うことができます)
//Admin は管理者の身元判定、true は管理者です。
リーリー
このようにしてエラー処理関数をカスタマイズしました。では、このカスタム関数にエラー処理をどのように引き渡すのでしょうか?
リーリー
上記の例では、エラー メッセージをオフにし、独自の関数を使用してエラーを処理しました。エラー ハンドラーを使用して、報告されたエラー メッセージを制御および処理できます。
リーリー
PHP の set_error_handler() 関数について少しご紹介します定義と使用法
set_error_handler() 関数は、ユーザー定義のエラー処理関数を設定します。
この関数は、実行時にユーザー独自のエラー処理メソッドを作成するために使用されます。
この関数は古いエラー ハンドラーを返すか、失敗した場合は null を返します。
文法set_error_handler(error_function,error_types)
パラメータの説明
error_function 必需。规定发生错误时运行的函数。 提示和注释 提示:如果使用了该函数,会完全绕过标准的 PHP 错误处理函数,如果必要,用户定义的错误处理程序必须终止 (die() ) 脚本。 注释:如果在脚本执行前发生错误,由于在那时自定义程序还没有注册,因此就不会用到这个自定义错误处理程序。 例子 输出: Custom error: [1024] A custom error has been triggered
error_types 可选。规定在哪个错误报告级别会显示用户定义的错误。默认是 "E_ALL"。
<?php
//error handler function
function customError($errno, $errstr, $errfile, $errline)
{
echo "<b>Custom error:</b> [$errno] $errstr<br />";
echo " Error on line $errline in $errfile<br />";
echo "Ending Script";
die();
}
//set error handler
set_error_handler("customError");
$test=2;
//trigger error
if ($test>1)
{
trigger_error("A custom error has been triggered");
}
?>
Error on line 19 in C:/webfolder/test.php
Ending Script