淺談PHP中的錯誤處理和異常處理
錯誤處理:
1. 語法錯誤
2. 運行時的錯誤
3. 邏輯錯誤
錯誤報告:
錯誤E_ERROR
警告E_WARNING
注意E_NOTICE
開發(fā)階段:開發(fā)時輸出所有的錯誤報告,有利于我們進行調(diào)試
運行階段:不要讓程序輸出任何一種錯誤報告
將錯誤報告寫入日志中
一. 指定錯誤報告error_reporting=E_ALL(在php.inn)
二. 關(guān)閉錯誤輸出display_errors=off(在php.ini中)
三. 開啟錯誤日志的功能log_errors=on(在php.ini中)
1. 默認如果不指定錯誤日志位置,則默認寫入web服務器的日志中
2. 為error_log選項指定一個文件名,這個文件名就是錯誤日志
3. 寫入到操作系統(tǒng)日志中error_log=syslog
<?php
//注意和警告都不會終止程序的運行,但是錯誤會終止程序的運行
/*
錯誤E_ERROR
警告E_WARNING
注意E_NOTICE
*/
//所有的錯誤都輸出除了注意
error_reporting(E_ALL & ~E_NOTICE);
//設(shè)置配置文件的值(臨時)
//ini_set("upload_max_filesize", 2000000000);
//得到配置文件的值
//ini_get("upload_max_filesize");
//關(guān)閉錯誤報告的顯示,一般在運行階段使用
ini_set("display_errors", "off");
//將錯誤報告寫入日志中
ini_set("log_errors", "on");
//日志的目錄
ini_set("error_log", "D:/error.log");
gettype($var); //注意
gettype(); //警告
//getype(); //錯誤,程序終止
echo "############<br>";
?>
異常處理:意外,是在程序運行過程中發(fā)生的意料之外的事,使用異常改變腳本正常流程
PHP5中的一個新的重要特性
try{
}catch(異常對象){
}
1. 如果try中代碼沒有問題,則將try中代碼執(zhí)行完成后就到catch后執(zhí)行
2. 如果try中代碼有異常發(fā)生,則拋出一個異常對象(使用throw),拋出給了catch中的參數(shù),則在try中出現(xiàn)異常代碼后的內(nèi)容就不會執(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中的錯誤處理和異常處理就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
php urlencode()與urldecode()函數(shù)字符編碼原理詳解
中文字符編碼研究系列第五期,詳解 urlencode()與urldecode()函數(shù)字符編碼原理,兩個函數(shù)分別用于編碼 URL 字符串和解碼已編碼的 URL 字符串,實現(xiàn)對中文字符的編碼2011-12-12
PHP中遍歷stdclass object的實現(xiàn)代碼
從網(wǎng)上查到的方法是 用get_object_vars 把類類型轉(zhuǎn)換成數(shù)組 然后在用 foreach 遍歷即可2011-06-06

