3.PHP自定义错误处理器
1. 使用set_error_handler 自定义错误处理函数说明
set_error_handler 说明
mixed set_error_handler ( callable $error_handler [, int $error_types = E_ALL | E_STRICT ] )设置一个用户的函数(error_handler)来处理脚本中出现的错误。本函数可以用你自己定义的方式来处理运行中的错误, 例如,在应用程序中严重错误发生时,或者在特定条件下触发了一个错误(使用 trigger_error()),你需要对数据/文件做清理回收。重要的是要记住 error_types 里指定的错误类型都会绕过 PHP 标准错误处理程序, 除非回调函数返回了 FALSE。 error_reporting() 设置将不会起到作用而你的错误处理函数继续会被调用 ?? 不过你仍然可以获取 error_reporting 的当前值,并做适当处理。 需要特别注意的是带 @ error-control operator 前缀的语句发生错误时,这个值会是 0。同时注意,在需要时你有责任使用 die()。 如果错误处理程序返回了,脚本将会继续执行发生错误的后一行。以下级别的错误不能由用户定义的函数来处理: E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING,和在 调用 set_error_handler() 函数所在文件中产生的大多数 E_STRICT。如果错误发生在脚本执行之前(比如文件上传时),将不会 调用自定义的错误处理程序因为它尚未在那时注册。参数error_handler用户的函数需要接受两个参数:错误码和描述错误的 string。 另外有可能提供三个可选参数:发生错误的文件名、发生错误的行号 以及发生错误的上下文(一个指向错误发生时活动符号表的 array)。 该函数可以表示为:handler ( int $errno , string $errstr [, string $errfile [, int $errline [, array $errcontext ]]] )errno第一个参数 errno,包含了错误的级别,是一个 integer。errstr第二个参数 errstr,包含了错误的信息,是一个 string。errfile第三个参数是可选的,errfile, 包含了发生错误的文件名,是一个 string。errline第四个参数是一个可选项, errline, 包含了错误发生的行号,是一个 integer。errcontext第五个可选参数, errcontext, 是一个指向错误发生时活动符号表的 array。 也就是说,errcontext 会包含错误触发处作用域内所有变量的数组。 用户的错误处理程序不应该修改错误上下文(context)。如果函数返回 FALSE,标准错误处理处理程序将会继续调用。error_types就像error_reporting 的 ini 设置能够控制错误的显示一样, 此参数能够用于屏蔽 error_handler 的触发。 如果没有该掩码, 无论 error_reporting 是如何设置的, error_handler 都会在每个错误发生时被调用。
2. set_error_handler的使用
header('content-type:text/html; charset=utf-8');//开启所有的错误报告error_reporting(-1);function customError($errno, $errmsg, $errfile, $errline){ if (!(error_reporting() & $errno)) { // This error code is not included in error_reporting return; } switch ($errno) { case E_USER_ERROR: echo "<b>My ERROR</b> [$errno] $errmsg<br />".PHP_EOL; echo " Fatal error on line $errline in file $errfile"; echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />".PHP_EOL; echo "Aborting...<br />\n"; // exit(1); break; case E_USER_WARNING: echo "<b>My WARNING</b> [$errno] $errmsg<br />".PHP_EOL; break; case E_USER_NOTICE: echo "<b>My NOTICE</b> [$errno] $errmsg<br />".PHP_EOL; break; default: echo "Unknown error type: [$errno] $errmsg<br />".PHP_EOL; break; } /* Don't execute PHP internal error handler */ return true;}set_error_handler('customError');echo $test;settype($var, 'king');// test();trigger_error('出错了!', E_USER_ERROR);echo '<hr>';//回收错误接管restore_error_handler();echo $king;echo '<hr>';set_error_handler('customError', E_ALL&~E_NOTICE);echo '<hr>';settype($var, 'king');echo 'continue...............';
3.自定义错误处理类
/** * 自定义错误处理类 */class MyErrorHandler { public $msg=''; public $filename=''; public $line=0; public $vars=array(); protected $_noticeLog = '/tmp/php_error.log'; function __construct($msg, $filename, $line, $vars) { $this->msg=$msg; $this->filename=$filename; $this->line=$line; $this->vars=$vars; } /** * [deal 自定义错误处理请求] * @param [int] $errno [错误号] * @param [string] $errmsg [错误描述] * @param [string] $errfile [出错的文件] * @param [int] $errline [出错的行号] * @param [array] $vars [错误触发处作用域内所有变量的数组] * @return [bool] */ public static function deal($errno, $errmsg, $errfile, $errline, $vars){ $self = new self($errmsg, $errfile, $errline, $vars); switch ($errno) { //致命级别的错误发邮件给管理员 case E_USER_ERROR: return $self->dealError(); break; case E_USER_WARNING: case E_WARNING: return $self->dealWarning(); break; case E_USER_NOTICE: case E_NOTICE: return $self->dealNotice(); break; default: //交给php本身的错误机制处理 return false; break; } } public function get_debug_print_backtrace($traces_to_ignore = 1){ $traces = debug_backtrace(); $ret = array(); foreach($traces as $i => $call){ if ($i < $traces_to_ignore ) { continue; } $object = ''; if (isset($call['class'])) { $object = $call['class'].$call['type']; if (is_array($call['args'])) { foreach ($call['args'] as &$arg) { $this->get_arg($arg); } } } $ret[] = '#'.str_pad($i - $traces_to_ignore, 3, ' ') .$object.$call['function'].'('.implode(', ', $call['args']) .') called at ['.$call['file'].':'.$call['line'].']'; } return implode("\n",$ret); } public function get_arg(&$arg) { if (is_object($arg)) { $arr = (array)$arg; $args = array(); foreach($arr as $key => $value) { if (strpos($key, chr(0)) !== false) { $key = ''; // Private variable found } $args[] = '['.$key.'] => '.get_arg($value); } $arg = get_class($arg) . ' Object ('.implode(',', $args).')'; } } /** * [dealError 处理错误级别的错误] * @return [type] [description] */ public function dealError(){ $backtrace=$this->get_debug_print_backtrace(); echo $backtrace; exit; $errorMsg=<<<EOF 出现了致命错误,如下 产生错误的文件:{$this->filename} 产生错误的信息:{$this->msg} 产生错误的行号:{$this->line} 追踪信息:{$backtrace} \n EOF; error_log($errorMsg, 1, '732578448@qq.com'); exit(1); } /** * [dealWarning 处理警告级别的错误] * @return [bool] */ public function dealWarning(){ $errorMsg=<<<EOF 出现了警告错误,如下 产生警告的文件:{$this->filename} 产生警告的信息:{$this->msg} 产生警告的行号:{$this->line} \n EOF; error_log($errorMsg, 1, '732578448@qq.com'); } /** * [dealNotice 处理通知级别的错误] * @return bool */ public function dealNotice(){ $datetime = date('Y-m-d H:i:s', time()); $errorMsg=<<<EOF 出现了通知错误,如下 产生通知的文件:{$this->filename} 产生通知的信息:{$this->msg} 产生通知的行号:{$this->line} 产生通知的时间:{$datetime} \n EOF; return error_log($errorMsg, 3, $this->_noticeLog); }}error_reporting(-1);set_error_handler(array('MyErrorHandler', 'deal'));ini_set('display_errors', 0);echo $var;trigger_error('zhiming', E_USER_ERROR);trigger_error('zhiming', E_USER_WARNING);
4.register_shutdown_function函数的使用
1.作用
1.通过register_shutdown_function函数,可以让我们设置一个当执行关闭时可以被调用的另一个函数。
2.当我们的脚本执行完成或意外死掉导致PHP执行即将关闭时,我们的这个函数将会被调用
2.使用场景
1.页面强制被停止
2.程序代码意外终止或超时
3.注意点
1.在register_shutdown_function之前不能有die() exit()等终止函数
版权声明:本文为博主原创文章,未经博主允许不得转载。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在PHP中,應使用password_hash和password_verify函數實現安全的密碼哈希處理,不應使用MD5或SHA1。1)password_hash生成包含鹽值的哈希,增強安全性。 2)password_verify驗證密碼,通過比較哈希值確保安全。 3)MD5和SHA1易受攻擊且缺乏鹽值,不適合現代密碼安全。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP類型提示提升代碼質量和可讀性。 1)標量類型提示:自PHP7.0起,允許在函數參數中指定基本數據類型,如int、float等。 2)返回類型提示:確保函數返回值類型的一致性。 3)聯合類型提示:自PHP8.0起,允許在函數參數或返回值中指定多個類型。 4)可空類型提示:允許包含null值,處理可能返回空值的函數。

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

在PHP中使用預處理語句和PDO可以有效防範SQL注入攻擊。 1)使用PDO連接數據庫並設置錯誤模式。 2)通過prepare方法創建預處理語句,使用佔位符和execute方法傳遞數據。 3)處理查詢結果並確保代碼的安全性和性能。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。
