錯(cuò)誤處理:
1. 語(yǔ)法錯(cuò)誤
2. 運(yùn)行時(shí)的錯(cuò)誤
3. 邏輯錯(cuò)誤
錯(cuò)誤報(bào)告:
錯(cuò)誤E_ERROR
警告E_WARNING
注意E_NOTICE
開發(fā)階段:開發(fā)時(shí)輸出所有的錯(cuò)誤報(bào)告,有利于我們進(jìn)行調(diào)試
運(yùn)行階段:不要讓程序輸出任何一種錯(cuò)誤報(bào)告
將錯(cuò)誤報(bào)告寫入日志中
一. 指定錯(cuò)誤報(bào)告error_reporting=E_ALL(在php.inn)
二. 關(guān)閉錯(cuò)誤輸出display_errors=off(在php.ini中)
三. 開啟錯(cuò)誤日志的功能log_errors=on(在php.ini中)
1. 默認(rèn)如果不指定錯(cuò)誤日志位置,則默認(rèn)寫入web服務(wù)器的日志中
2. 為error_log選項(xiàng)指定一個(gè)文件名,這個(gè)文件名就是錯(cuò)誤日志
3. 寫入到操作系統(tǒng)日志中error_log=syslog
<?php //注意和警告都不會(huì)終止程序的運(yùn)行,但是錯(cuò)誤會(huì)終止程序的運(yùn)行 /* 錯(cuò)誤E_ERROR 警告E_WARNING 注意E_NOTICE */ //所有的錯(cuò)誤都輸出除了注意 error_reporting(E_ALL & ~E_NOTICE); //設(shè)置配置文件的值(臨時(shí)) //ini_set("upload_max_filesize", 2000000000); //得到配置文件的值 //ini_get("upload_max_filesize"); //關(guān)閉錯(cuò)誤報(bào)告的顯示,一般在運(yùn)行階段使用 ini_set("display_errors", "off"); //將錯(cuò)誤報(bào)告寫入日志中 ini_set("log_errors", "on"); //日志的目錄 ini_set("error_log", "D:/error.log"); gettype($var); //注意 gettype(); //警告 //getype(); //錯(cuò)誤,程序終止 echo "############<br>"; ?>
異常處理:意外,是在程序運(yùn)行過程中發(fā)生的意料之外的事,使用異常改變腳本正常流程
PHP5中的一個(gè)新的重要特性
try{
}catch(異常對(duì)象){
}
1. 如果try中代碼沒有問題,則將try中代碼執(zhí)行完成后就到catch后執(zhí)行
2. 如果try中代碼有異常發(fā)生,則拋出一個(gè)異常對(duì)象(使用throw),拋出給了catch中的參數(shù),則在try中出現(xiàn)異常代碼后的內(nèi)容就不會(huì)執(zhí)行,直接跳轉(zhuǎn)到catch中去執(zhí)行,catch中執(zhí)行完成,再繼續(xù)向下執(zhí)行
<?php try{ echo "11111111<br>"; $file=@fopen("./hello.txt","r"); if(!$file){ throw new Exception("文件打開失敗"); } echo "2222222222<br>"; }catch(Exception $e){ echo "3333333<br>"; echo $e->getMessage()."<br>"; touch("hello.txt"); $file=@fopen("./hello.txt","r"); } echo "4444444<br>"; ?>
以上這篇淺談PHP中的錯(cuò)誤處理和異常處理就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持綠夏網(wǎng)。