亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

PHP擴展之錯誤處理和日志記錄

瀏覽:15日期:2022-09-15 14:58:34
簡介

PHP提供了錯誤處理和日志記錄的功能. 這些函數允許你定義自己的錯誤處理規則,以及修改錯誤記錄的方式. 這樣,你就可以根據自己的需要,來更改和加強錯誤輸出信息以滿足實際需要.

通過日志記錄功能,你可以將信息直接發送到其他日志服務器,或者發送到指定的電子郵箱(或者通過郵件網關發送),或者發送到操作系統日志等,從而可以有選擇的記錄和監視你的應用程序和網站的最重要的部分。

錯誤報告功能允許你自定義錯誤反饋的級別和類型,可以是簡單的提示信息或者使用自定義的函數進行處理并返回信息.

范例

下面我們可以看到錯誤處理功能在 PHP 中的使用的示例。 我們定義錯誤處理函數,記錄錯誤信息到一個文件中 (使用以 XML 格式) ,并在發生嚴重邏輯錯誤時,給開發人員發送電子郵件。

Example #1 在腳本中使用錯誤句柄

<?php // 我們將要定義自己的錯誤處理 error_reporting(0); // 用戶自定義錯誤處理函數 function userErrorHandler($errno, $errmsg, $filename, $linenum, $vars) {// 錯誤發生的時間$dt = date('Y-m-d H:i:s (T)');// 定義錯誤字符串的關聯數組// 在這里我們只考慮// E_WARNING, E_NOTICE, E_USER_ERROR,// E_USER_WARNING 和 E_USER_NOTICE$errortype = array ( E_ERROR => ’Error’, E_WARNING => ’Warning’, E_PARSE => ’Parsing Error’, E_NOTICE => ’Notice’, E_CORE_ERROR => ’Core Error’, E_CORE_WARNING => ’Core Warning’, E_COMPILE_ERROR => ’Compile Error’, E_COMPILE_WARNING => ’Compile Warning’, E_USER_ERROR => ’User Error’, E_USER_WARNING => ’User Warning’, E_USER_NOTICE => ’User Notice’, E_STRICT => ’Runtime Notice’, E_RECOVERABLE_ERROR => ’Catchable Fatal Error’);// 設置要保存變量跟蹤信息的錯誤類別$user_errors = array(E_USER_ERROR, E_USER_WARNING, E_USER_NOTICE);$err = '<errorentry>n';$err .= 't<datetime>' . $dt . '</datetime>n';$err .= 't<errornum>' . $errno . '</errornum>n';$err .= 't<errortype>' . $errortype[$errno] . '</errortype>n';$err .= 't<errormsg>' . $errmsg . '</errormsg>n';$err .= 't<scriptname>' . $filename . '</scriptname>n';$err .= 't<scriptlinenum>' . $linenum . '</scriptlinenum>n';if (in_array($errno, $user_errors)) { $err .= 't<vartrace>' . wddx_serialize_value($vars, 'Variables') . '</vartrace>n';}$err .= '</errorentry>nn';// for testing// echo $err;// 記錄錯誤信息到錯誤日志,并在發生關鍵用戶錯誤時發送電子郵件error_log($err, 3, '/usr/local/php4/error.log');if ($errno == E_USER_ERROR) { mail('[email protected]', 'Critical User Error', $err);} } function distance($vect1, $vect2) {if (!is_array($vect1) || !is_array($vect2)) { trigger_error('Incorrect parameters, arrays expected', E_USER_ERROR); return NULL;}if (count($vect1) != count($vect2)) { trigger_error('Vectors need to be of the same size', E_USER_ERROR); return NULL;}for ($i=0; $i<count($vect1); $i++) { $c1 = $vect1[$i]; $c2 = $vect2[$i]; $d = 0.0; if (!is_numeric($c1)) {trigger_error('Coordinate $i in vector 1 is not a number, using zero',E_USER_WARNING);$c1 = 0.0; } if (!is_numeric($c2)) {trigger_error('Coordinate $i in vector 2 is not a number, using zero',E_USER_WARNING);$c2 = 0.0; } $d += $c2*$c2 - $c1*$c1;}return sqrt($d); } $old_error_handler = set_error_handler('userErrorHandler'); // 未定義的常量,將產生一個警告 $t = I_AM_NOT_DEFINED; // 定義一些 '載體' $a = array(2, 3, 'foo'); $b = array(5.5, 4.3, -1.6); $c = array(1, -3); // 引發一個用戶錯誤 $t1 = distance($c, $b) . 'n'; // 再次引發一個用戶錯誤 $t2 = distance($b, 'i am not an array') . 'n'; // 引發一個警告 $t3 = distance($a, $b) . 'n';?> 錯誤處理函數debug_backtrace — 產生一條回溯跟蹤(backtrace)debug_print_backtrace — 打印一條回溯。error_get_last — 獲取最后發生的錯誤error_log — 發送錯誤信息到某個地方error_reporting — 設置應該報告何種 PHP 錯誤restore_error_handler — 還原之前的錯誤處理函數restore_exception_handler — 恢復之前定義過的異常處理函數。set_error_handler — 設置一個用戶定義的錯誤處理函數set_exception_handler — 設置一個用戶定義的異常處理函數。trigger_error — 產生一個用戶級別的 error/warning/notice 信息user_error — trigger_error 的別名

標簽: PHP
相關文章:
主站蜘蛛池模板: 亚洲成a人片在线观看播放 亚洲成a人片在线播放观看国产 | 欧日韩视频 | 亚洲视频重口味 | 97精品国产91久久久久久久 | 天天拍夜夜添久久精品中文 | 同性欧美可播放videos免费 | 亚洲精品一级片 | 五月婷婷综合基地 | 奇米狠狠 | 国产精品视频全国免费观看 | 1024cc香蕉在线观看免费 | 最新国产成人综合在线观看 | 国产无套 | 久久亚洲精品无码观看不卡 | 国产成 人 色综合 亚洲 | 日韩精品一区二三区中文 | 亚洲 欧美 日韩 另类 | 国产中文欧美 | 国产精品极品美女免费观看 | 东京不太热视频高清在线 | 精品午夜久久影视 | 国产成人18黄网站免费 | 18以下勿进色禁视频免费看 | 日本中文字幕乱码免费 | 久爱青草视频在线观看 | 九九在线精品视频 | 精品久久久久不卡无毒 | 亚洲国产精品久久久久秋霞小 | 久久精品一区 | 亚洲精品午夜久久aaa级久久久 | 亚洲欧美日韩中文字幕网址 | 香蕉视频在线观看免费 | 性生活视频网站 | 欧美亚洲一区二区三区在线 | 久久99综合国产精品亚洲首页 | 一区二区三区亚洲 | 婷婷午夜天 | 亚洲精品xxx | 青草在线观看 | 亚洲免费在线视频播放 | 中国一级淫片aaa毛片毛片 |