首頁  >  文章  >  後端開發  >  PHP常用功能塊_錯誤與異常處理 — php(32)

PHP常用功能塊_錯誤與異常處理 — php(32)

WBOY
WBOY原創
2016-08-08 09:23:411038瀏覽

一、錯誤和異常處理

1.1 錯誤類型和基本的調試方法
??PHP程式的錯誤發生一般歸屬於下列三個領域:

?? ??語法錯誤最常見,也容易修復。如:代碼中遺漏一個分號。這類錯誤會阻止腳本的執行。
??運行時錯誤:

??這種錯誤一般不會阻止PHP腳本的執行,但會阻止目前要做的事情。輸出一條錯誤,但php腳本繼續執行
??邏輯錯誤:

??這種錯誤最麻煩,既不阻止腳本執行,也不輸出錯誤訊息。
??一個異常則是在一個程式執行過程中出現的一個例外,或是一個事件,它中斷了正常指令的運行,跳到其他程式模組繼續執行。
PHP的錯誤報告等級

??E_ALL //所有資訊值:6143
??E_ERROR//致命的運行時錯誤值:1143
??E_ERROR//致命的運行時錯誤值:1% =72_37437]M3?時錯誤,若未被捕獲則視同E_ERROR 值:4096
??E_WARNING //運行時警告(非致命性錯誤) 值:2
??E_PARSE//編譯時解析錯誤值:4
??E_NOTICE //運行時提醒(經常是bug,也可能是有意的) 值:8
??E_STRICT//編碼標準化警告(建議如何修改以向前兼容) 值:2048
??E_CORE_ERROR //PHP啟動時初始化過程中的致命錯誤值:16
??E_CORE_WARNING //PHP啟動時初始化過程中的警告(非致命性錯)值:32
??E_COMPILE??E_COMPILE_ERROR //編譯時致命性錯值:64
??E_COMPILE_WARNING //編譯時警告(非致命性錯) 值:128
??E_USER_ERROR //使用者自訂的致命錯誤值:256??E_USER_ERROR //使用者自訂的致命錯誤值:256
? E_USER_WARNING //使用者自訂的警告(非致命性錯誤) 值:512
??E_USER_NOTICE //使用者自訂的提醒(經常是bug) 值:1024
php.ini配置檔案

display_errors: 是否開啟PHP輸出錯誤報告的功能

??值為:On(預設輸出錯誤報告)、Off(屏蔽所有錯誤訊息)

??在PHP腳本中可呼叫ini_set( )函數,動態設定php.ini設定檔.
??如:ini_set("display_errors","On"); //顯示所有錯誤訊息
??error_reporting: 設定不同的錯誤報告等級。
??error_reporting= E_ALL & ~E_NOTICE
--可以拋出任何非注意的錯誤,預設值
??error_reporting= E_ERROR-- E_PARM.錯誤、新解析錯誤和核心錯誤。
??error_reporting= E_ALL & ~(E_USER_ERROR | E_USER_WARNING | E_USER_NOTICE)
--報告除使用者導致的錯誤之外的所有錯誤。
??在PHP腳本可以透過error_reporting( )函數動態設定錯誤報告層級。如:error_reporting(E_ALL);]
設定錯誤等級實例:error.php

<span><h2>测试错误报告</h2>
<?<span>php
</span><span>/*</span><span>开启php.ini中的display_errors指令,只有该指令开启如有错误报告才能输出</span><span>*/</span><span>ini_set(</span><span>'</span><span>display_errors</span><span>'</span>,<span>1</span><span>);
</span><span>/*</span><span>通过error_reporting()函数设置在本脚本中,输出所有级别的错误报告</span><span>*/</span><span>error_reporting(E_ALL);
</span><span>/*</span><span>&ldquo;注意(notice)&rdquo;的报告,不会阻止脚本的执行,并且不一定是一个问题</span><span>*/</span><span>getType($</span><span>var</span>);<span>//</span><span>调用函数时提供的参数变量没有在之前声明</span><span>/*</span><span>&ldquo;警告(warning)&rdquo;的报告,指示一个问题,但是不会阻止脚本的执行</span><span>*/</span><span>getType();</span><span>//</span><span>调用函数时没有提供必要的参数</span><span>/*</span><span>&ldquo;错误(error)&rdquo;的报告,它会终止程序,脚本不会再向下执行</span><span>*/</span><span>get_Type();</span><span>//</span><span>调用一个没有被定义的函数</span>?></span>

 PHP錯誤回報在初始化時遇到的錯誤。

??log_errors= On

??決定日誌語句記錄的位置。

??error_log(預設null)

??指定錯誤寫進的檔案或記錄錯誤日誌於系統日誌syslog。
??Log_errors_max_len=1024
??每個日誌項目的最大長度,單位是位元組。 0表示最大。
1.2 錯誤日誌
兩種方式記錄錯誤日誌:
??使用指定的檔案記錄錯誤報告日誌
??指定的檔案記錄錯誤回報日誌

1、先設定php.ini:

??error_reporting= E_ALL//將向PHP發送每個錯誤

??display_errerr=Off//
??log_errors=On//決定日誌語句所記錄的位置。
??log_errors_max_log=1024// 每個日誌項目的最大長度

??error_log=G:/myerror.log//指定錯誤寫入的檔案

?2、使用函數:在php文件中使用error_log()來記錄日誌,就可以將資訊寫入到myerror.log檔案中

??如:error_log("登入失敗了!");

2、使用四個函數來記錄日誌:
??define_syslog_variables();//為系統日誌初始化配置
??openlog();//開啟一個日誌連結
?syslog();//發送日誌範例

<span><?<span>php
</span><span>if</span>(!<span>Ora_Logon($username, $password)){
error_log(</span><span>"</span><span>Oracle数据库不可用!</span><span>"</span>, <span>0</span><span>);
</span><span>//</span><span>将错误消息写入到操作系统日志中</span><span>}
</span><span>if</span>(!($foo=<span>allocate_new_foo()){
error_log(</span><span>"</span><span>出现大麻烦了!</span><span>"</span>, <span>1</span>, <span>"</span><span>webmaster@www.mydomain.com</span><span>"</span>); <span>//</span><span>发送到管理员邮箱中</span><span>}
error_log(</span><span>"</span><span>搞砸了!</span><span>"</span>,<span>2</span>, <span>"</span><span>localhost:5000</span><span>"</span><span>);
</span><span>//</span><span>发送到本机对应5000端口的服务器中</span>error_log(<span>"</span><span>搞砸了!</span><span>"</span>, <span>3</span>, <span>"</span><span>/usr/local/errors.log</span><span>"</span><span>);
</span><span>//</span><span>发送到指定的文件中</span>?></span>

<span><?<span>php
define_syslog_variables();
openlog(</span><span>"</span><span>PHP5</span><span>"</span><span>, LOG_PID , LOG_USER);
syslog(LOG_WARNING, </span><span>"</span><span>警告报告向syslog中发送的演示,警告时间:</span><span>"</span>.date(<span>"</span><span>Y/m/dH:i:s</span><span>"</span><span>));
closelog();
</span>?></span>

查看日誌:如windows系統,透過右鍵點擊「我的電腦」-> 選擇管理選項->在系統工具選單中選擇事件檢視器->在應用程式選項中即可看到日誌了

1.3 異常處理

異常(Exception)處理用於在指定的錯誤發生時改變腳本的正常流程。是PHP5中的一個新的重要特性。異常處理是一種可擴展、易於維護的錯誤處理統一機制,並提供了一種新的物件導向的錯誤處理方式。
??異常處理格式:
try{
使用try去包含可能會發生異常的代碼.
一旦出現異常捕獲異常,交給catchtry進行捕獲異常,交給catchtry處理。
拋出異常語句:throw 異常物件。
}catch(異常物件參數){
在這裡做異常處理。
}[catch(。,,){
.. .. ..
}]

以上就介紹了PHP常用功能塊_錯誤和異常處理 — php(32),包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn