php中錯(cuò)誤處理操作實(shí)例分析
本文實(shí)例講述了php中錯(cuò)誤處理操作。分享給大家供大家參考,具體如下:
錯(cuò)誤觸發(fā)
有2種觸發(fā):
系統(tǒng)觸發(fā): E_NOTICE:提示性錯(cuò)誤,比如使用不存在的變量或常量
E_WARNING:警告性錯(cuò)誤,比如include載入一個(gè)不存在的文件
E_ERROR:致命錯(cuò)誤,導(dǎo)致程序無(wú)法執(zhí)行后續(xù)語(yǔ)句,比如調(diào)用一個(gè)不存在的函數(shù)
自定義觸發(fā):
語(yǔ)法形式:trigger_error("錯(cuò)誤提示信息內(nèi)容",3種用戶錯(cuò)誤代號(hào)之一);
其中觸發(fā)了用戶的致命錯(cuò)誤(E_USER_ERROR),也會(huì)終止程序的后續(xù)執(zhí)行
錯(cuò)誤顯示
是否顯示錯(cuò)誤報(bào)告(display_errors)
有2種來(lái)設(shè)定是否顯示:
1.在php.ini文件中,設(shè)定display_erros的值,為on(顯示),或?yàn)閛ff(不顯示),開(kāi)發(fā)階段應(yīng)該為on,顯示錯(cuò)誤信息
2.直接在php腳本文件中設(shè)定ini_set("display_errors",0);//不顯示錯(cuò)誤報(bào)告,1為顯示
顯示哪些級(jí)別的錯(cuò)誤報(bào)告(error_reporting)
前提是"display_errors"設(shè)置為on(或1),表示可以顯示
1.在php.ini文件中 error_reporting=E_ALL | E_STRICT這個(gè)值代表所有錯(cuò)誤


- 在當(dāng)前的腳本代碼中設(shè)置
ini_set("error_reporting",E_NOTICE); //就顯示該一個(gè)級(jí)別的錯(cuò)誤
ini_set("error_reporting",E_NOTICE| E_WARNING); //顯示該2個(gè)級(jí)別的錯(cuò)誤
//禁用錯(cuò)誤報(bào)告
error_reporting(0);
//報(bào)告運(yùn)行時(shí)錯(cuò)誤
error_reporting(E_ERROR | E_WARNING | E_PARSE);
//報(bào)告所有錯(cuò)誤
error_reporting(E_ALL);
錯(cuò)誤日志記錄
錯(cuò)誤日志其實(shí)就是錯(cuò)誤報(bào)告,只是會(huì)寫入文件中,此時(shí)就稱為錯(cuò)誤日志
是否記錄log_errors
php.ini中:log_errors=on或off 腳本中:ini_set("log_erros",1);或0
補(bǔ)充: ini_set("php配置項(xiàng)",值);//用于腳本中設(shè)置php.ini中某項(xiàng)的值
$v=ini_get("php配置項(xiàng)");//用于獲取php.ini中某項(xiàng)的值
記錄到哪里error_log
一般就只有2個(gè)寫法:
1.直接寫一個(gè)文件名,系統(tǒng)會(huì)自動(dòng)在每個(gè)文件夾下都建立該文件名,并用其記錄該文件夾下的所有網(wǎng)頁(yè)文件發(fā)生的錯(cuò)誤信息ini_set("error_log","my_error.txt");//記錄到該文件
2.使用一個(gè)特殊的名字"syslog",則所有的錯(cuò)誤信息都會(huì)記錄到系統(tǒng)的"日志文件中".系統(tǒng)日志文件在這里:控制面板》管理工具》事件查看器》window日志》應(yīng)用程序:
ini_set("error_log","syslog");//記錄到系統(tǒng)日志中
自定義錯(cuò)誤處理器
讓系統(tǒng)不要去處理錯(cuò)誤了,完全由開(kāi)發(fā)者對(duì)錯(cuò)誤進(jìn)行處理:顯示和記錄
第一步:設(shè)定要用于處理錯(cuò)誤的函數(shù)名:set_error_handler("f1");
第二步:去定義該函數(shù)function f1() {這里可以寫任意代碼,正常去顯示錯(cuò)誤報(bào)告,和記錄}
例:
set_error_handler("my_error_handler");
//定義該函數(shù),需要定義4個(gè)形參分別代表$errCode:代表錯(cuò)誤代號(hào)(級(jí)別) $errMsg:代表錯(cuò)誤//信息內(nèi)容 $errFile:代表錯(cuò)誤的文件名 $errLine:代表錯(cuò)誤的行號(hào),一旦發(fā)生錯(cuò)誤自動(dòng)調(diào)用
function my_error_handler($errCode,$errMsg,$errFile,$errLine) {
$str="";
$str .="<p><font color='red'>大事不好,發(fā)生錯(cuò)誤:</font>";
$str .="<br />錯(cuò)誤代號(hào)為:".$errCode;
$str .="<br />錯(cuò)誤內(nèi)容為:".$errMsg;
$str .="<br />錯(cuò)誤代號(hào)為:".$errFile;
$str .="<br />錯(cuò)誤代號(hào)為:".$errLine;
$str .="<br />發(fā)生時(shí)間為:".date("Y-d-m H:i:s");
$str .="</p>";
echo $str; //輸出該構(gòu)建完整的錯(cuò)誤處理結(jié)果,也可以將改內(nèi)容寫到某個(gè)文件中去
}
異常拋出
function checkAge($age){
if($age>100) throw new Exception('年齡不能大于100');
echo '年齡符合規(guī)范';
}
//如果年齡大于100,拋出異常
try{
checkAge(200);
}catch(Exception $e){
echo $e->getMessage();
}
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP錯(cuò)誤與異常處理方法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語(yǔ)法入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php+mysql實(shí)現(xiàn)的二級(jí)聯(lián)動(dòng)菜單效果詳解
這篇文章主要介紹了php+mysql實(shí)現(xiàn)的二級(jí)聯(lián)動(dòng)菜單效果,涉及php操作mysql的連接、查詢結(jié)合javascript的DOM節(jié)點(diǎn)操作實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)菜單效果,末尾還附帶了mysql數(shù)據(jù)庫(kù)相應(yīng)的sql語(yǔ)句,需要的朋友可以參考下2016-05-05
PHP中使用addslashes函數(shù)轉(zhuǎn)義的安全性原理分析
這篇文章主要介紹了PHP中使用addslashes函數(shù)轉(zhuǎn)義的安全性原理分析,較為深入的分析了addslashes函數(shù)的用法及ecshop自定義函數(shù)addslashes_deep的不足之處,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-11-11
Windows下IIS6/Apache2.2.4+MySQL5.2+PHP5.2.1安裝配置方法
Windows下IIS6/Apache2.2.4+MySQL5.2+PHP5.2.1安裝配置方法...2007-05-05
PHP GD 圖像處理組件的常用函數(shù)總結(jié)
如今,在互聯(lián)網(wǎng)上,很多網(wǎng)站都要處理大量圖片,比如:頭像、上傳的圖片做縮略圖加水印等等。他們需要服務(wù)端的大量圖片處理,一門好的服務(wù)端語(yǔ)言環(huán)境一定要有對(duì)圖像處理的支持。2010-04-04

