給新人總結一下PHP的錯誤處理。
PHP提供了錯誤處理和日志記錄的功能. 這些函數允許你定義自己的錯誤處理規則,以及修改錯誤記錄的方式. 這樣,你就可以根據自己的需要,來更改和加強錯誤輸出信息以滿足實際需要.
通過日志記錄功能,你可以將信息直接發送到其他日志服務器,或者發送到指定的電子郵箱(或者通過郵件網關發送),或者發送到操作系統日志等,從而可以有選擇的記錄和監視你的應用程序和網站的最重要的部分。
錯誤報告功能允許你自定義錯誤反饋的級別和類型,可以是簡單的提示信息或者使用自定義的函數進行處理並返回信息.
為什麼要使用錯誤處理?
•是網站出錯時對用戶友好
•更好的避免錯誤、調試、修復錯誤
•避免一些安全風險
•更好保證程序的健壯性
•……
1、最簡單的錯誤處理——die()
當我們預計有錯誤發生時,停止腳步的運行。比如連接數據庫時
<?php
mysql_connect('localhost', www.3lian.net, '123456')
or die ('連接數據庫錯誤:'. mysql_error());
不過,簡單地終止腳本並不總是恰當的方式。
2、自定義錯誤和錯誤觸發器
我們創建一個錯誤處理專用函數,使用set_error_handler函數設置後,可以在 PHP 中發生錯誤時調用該函數。
定義錯誤處理函數的參數
預定定變量
(級別E_ERROR、E_USER_ERROR不能被自定義錯誤處理函數撲捉到)自定義錯誤函數中不能撲捉到致命錯誤信息,因為發生致命的運行時錯誤時腳本都是立即停止執行的。
觸發錯誤
在腳本中用戶輸入數據的位置,當用戶的輸入無效時觸發錯誤的很有用的。在 PHP 中,這個任務由 trigger_error() 完成。
您可以在腳本中任何位置觸發錯誤,通過添加的第二個參數,您能夠規定所觸發的錯誤級別。
可能的錯誤類型:
•E_USER_ERROR – 致命的用戶生成的 run-time 錯誤。錯誤無法恢復。腳本執行被中斷。
•E_USER_WARNING – 非致命的用戶生成的 run-time 警告。腳本執行不被中斷。
•E_USER_NOTICE – 默認。用戶生成的 run-time 通知。腳本發現了可能的錯誤,也有可能在腳本運行正常時發生。
例如:
1
2
<!--?php<br /--> trigger_error("出錯了啊", E_USER_WARNING);
// 輸出 Warning: 出錯了啊 in xxxx 的錯誤信息
3、錯誤報告
默認地,根據在 php.ini 中的 error_log 配置,PHP 向服務器的錯誤記錄系統或文件發送錯誤記錄。
通過使用 error_log() 函數,您可以向指定的文件或遠程目的地發送錯誤記錄。比如把錯誤信息發送到郵箱中是一種好的方式。
4、異常處理
當異常被拋出時,其後的代碼不會繼續執行,PHP 會嘗試查找匹配的 “catch” 代碼塊。
如果異常沒有被捕獲,而且又沒用使用 set_exception_handler() 作相應的處理的話,那麼將發生一個嚴重的錯誤(致命錯誤),並且輸出 “Uncaught Exception” (未捕獲異常)的錯誤消息。
處理處理程序應當包括:
1.try – 使用異常的函數應該位於 “try” 代碼塊內。如果沒有觸發異常,則代碼將照常繼續執行。但是如果異常被觸發,會拋出一個異常。
2.throw – 這裡規定如何觸發異常。每一個 “throw” 必須對應至少一個 “catch”
3.catch – “catch” 代碼塊會捕獲異常,並創建一個包含異常信息的對象
重新拋出異常
有時,當異常被拋出時,您也許希望以不同於標准的方式對它進行處理。可以在一個 “catch” 代碼塊中再次拋出異常。
腳本應該對用戶隱藏系統錯誤。對程序員來說,系統錯誤也許很重要,但是用戶對它們並不感興趣。為了讓用戶更容易使用,您可以再次拋出帶有對用戶比較友好的消息的異常。
異常的規則
需要進行異常處理的代碼應該放入 try 代碼塊內,以便捕獲潛在的異常。
每個 try 或 throw 代碼塊必須至少擁有一個對應的 catch 代碼塊。
使用多個 catch 代碼塊可以捕獲不同種類的異常。
可以在 try 代碼塊內的 catch 代碼塊中再次拋出(re-thrown)異常。
簡而言之:如果拋出了異常,就必須捕獲它。