您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“PHP錯(cuò)誤和異長(zhǎng)常處理的方法有哪些”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
通過(guò)日志記錄功能,你可以將信息直接發(fā)送到其他日志服務(wù)器,或者發(fā)送到指定的電子郵箱(或者通過(guò)郵件網(wǎng)關(guān)發(fā)送),或者發(fā)送到操作系統(tǒng)日志等,從而可以有選擇的記錄和監(jiān)視你的應(yīng)用程序和網(wǎng)站的最重要的部分。
錯(cuò)誤報(bào)告功能允許你自定義錯(cuò)誤反饋的級(jí)別和類(lèi)型,可以是簡(jiǎn)單的提示信息或者使用自定義的函數(shù)進(jìn)行處理并返回信息.
為什么要使用錯(cuò)誤處理?
1.是網(wǎng)站出錯(cuò)時(shí)對(duì)用戶(hù)友好
2.更好的避免錯(cuò)誤、調(diào)試、修復(fù)錯(cuò)誤
3.避免一些安全風(fēng)險(xiǎn)
4.更好保證程序的健壯性
5.……
一、最簡(jiǎn)單的錯(cuò)誤處理――die()
當(dāng)我們預(yù)計(jì)有錯(cuò)誤發(fā)生時(shí),停止腳步的運(yùn)行。比如連接數(shù)據(jù)庫(kù)時(shí):
復(fù)制代碼 代碼如下:
mysql_connect('localhost', 'root', '123456') or die ('連接數(shù)據(jù)庫(kù)錯(cuò)誤:'. mysql_error());
不過(guò),簡(jiǎn)單地終止腳本并不總是恰當(dāng)?shù)姆绞健?br/>二、自定義錯(cuò)誤和錯(cuò)誤觸發(fā)器
我們創(chuàng)建一個(gè)錯(cuò)誤處理專(zhuān)用函數(shù),使用set_error_handler函數(shù)設(shè)置后,可以在 PHP 中發(fā)生錯(cuò)誤時(shí)調(diào)用該函數(shù)。
1.定義錯(cuò)誤處理函數(shù)的參數(shù):
參數(shù) | 描述 |
---|---|
error_level | 必需。為用戶(hù)定義的錯(cuò)誤規(guī)定錯(cuò)誤報(bào)告級(jí)別。必須是一個(gè)值數(shù)。 參見(jiàn)下面的表格:錯(cuò)誤報(bào)告級(jí)別。 |
error_message | 必需。為用戶(hù)定義的錯(cuò)誤規(guī)定錯(cuò)誤消息。 |
error_file | 可選。規(guī)定錯(cuò)誤在其中發(fā)生的文件名。 |
error_line | 可選。規(guī)定錯(cuò)誤發(fā)生的行號(hào)。 |
error_context | 可選。規(guī)定一個(gè)數(shù)組,包含了當(dāng)錯(cuò)誤發(fā)生時(shí)在用的每個(gè)變量以及它們的值。 |
2.錯(cuò)誤基本預(yù)定義常量:
值 | 常量 | 說(shuō)明 | 備注 |
---|---|---|---|
1 | E_ERROR (integer) | 致命的運(yùn)行時(shí)錯(cuò)誤。這類(lèi)錯(cuò)誤一般是不可恢復(fù)的情況,例如內(nèi)存分配導(dǎo)致的問(wèn)題。后果是導(dǎo)致腳本終止不再繼續(xù)運(yùn)行。 | |
2 | E_WARNING (integer) | 運(yùn)行時(shí)警告 (非致命錯(cuò)誤)。僅給出提示信息,但是腳本不會(huì)終止運(yùn)行。 | |
4 | E_PARSE (integer) | 編譯時(shí)語(yǔ)法解析錯(cuò)誤。解析錯(cuò)誤僅僅由分析器產(chǎn)生。 | |
8 | E_NOTICE (integer) | 運(yùn)行時(shí)通知。表示腳本遇到可能會(huì)表現(xiàn)為錯(cuò)誤的情況,但是在可以正常運(yùn)行的腳本里面也可能會(huì)有類(lèi)似的通知。 | |
16 | E_CORE_ERROR (integer) | 在PHP初始化啟動(dòng)過(guò)程中發(fā)生的致命錯(cuò)誤。該錯(cuò)誤類(lèi)似 E_ERROR,但是是由PHP引擎核心產(chǎn)生的。 | since PHP 4 |
32 | E_CORE_WARNING(integer) | PHP初始化啟動(dòng)過(guò)程中發(fā)生的警告 (非致命錯(cuò)誤) 。類(lèi)似 E_WARNING,但是是由PHP引擎核心產(chǎn)生的。 | since PHP 4 |
64 | E_COMPILE_ERROR(integer) | 致命編譯時(shí)錯(cuò)誤。類(lèi)似E_ERROR, 但是是由Zend腳本引擎產(chǎn)生的。 | since PHP 4 |
128 | E_COMPILE_WARNING(integer) | 編譯時(shí)警告 (非致命錯(cuò)誤)。類(lèi)似E_WARNING,但是是由Zend腳本引擎產(chǎn)生的。 | since PHP 4 |
256 | E_USER_ERROR (integer) | 用戶(hù)產(chǎn)生的錯(cuò)誤信息。類(lèi)似 E_ERROR, 但是是由用戶(hù)自己在代碼中使用PHP函數(shù)trigger_error()來(lái)產(chǎn)生的。 | since PHP 4 |
512 | E_USER_WARNING(integer) | 用戶(hù)產(chǎn)生的警告信息。類(lèi)似 E_WARNING, 但是是由用戶(hù)自己在代碼中使用PHP函數(shù)trigger_error()來(lái)產(chǎn)生的。 | since PHP 4 |
1024 | E_USER_NOTICE(integer) | 用戶(hù)產(chǎn)生的通知信息。類(lèi)似 E_NOTICE, 但是是由用戶(hù)自己在代碼中使用PHP函數(shù)trigger_error()來(lái)產(chǎn)生的。 | since PHP 4 |
2048 | E_STRICT (integer) | 啟用 PHP 對(duì)代碼的修改建議,以確保代碼具有最佳的互操作性和向前兼容性。 | since PHP 5 |
4096 | E_RECOVERABLE_ERROR(integer) | 可被捕捉的致命錯(cuò)誤。 它表示發(fā)生了一個(gè)可能非常危險(xiǎn)的錯(cuò)誤,但是還沒(méi)有導(dǎo)致PHP引擎處于不穩(wěn)定的狀態(tài)。 如果該錯(cuò)誤沒(méi)有被用戶(hù)自定義句柄捕獲 (參見(jiàn) set_error_handler()),將成為一個(gè) E_ERROR 從而腳本會(huì)終止運(yùn)行。 | since PHP 5.2.0 |
8192 | E_DEPRECATED (integer) | 運(yùn)行時(shí)通知。啟用后將會(huì)對(duì)在未來(lái)版本中可能無(wú)法正常工作的代碼給出警告。 | since PHP 5.3.0 |
16384 | E_USER_DEPRECATED(integer) | 用戶(hù)產(chǎn)少的警告信息。 類(lèi)似E_DEPRECATED, 但是是由用戶(hù)自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 | since PHP 5.3.0 |
30719 | E_ALL (integer) | E_STRICT出外的所有錯(cuò)誤和警告信息。 | 30719 in PHP 5.3.x, 6143 in PHP 5.2.x, 2047 previously |
(級(jí)別E_ERROR、E_USER_ERROR不能被自定義錯(cuò)誤處理函數(shù)撲捉到)自定義錯(cuò)誤函數(shù)中不能撲捉到致命錯(cuò)誤信息,因?yàn)榘l(fā)生致命的運(yùn)行時(shí)錯(cuò)誤時(shí)腳本都是立即停止執(zhí)行的。
3.觸發(fā)錯(cuò)誤
在腳本中用戶(hù)輸入數(shù)據(jù)的位置,當(dāng)用戶(hù)的輸入無(wú)效時(shí)觸發(fā)錯(cuò)誤的很有用的。在 PHP 中,這個(gè)任務(wù)由 trigger_error() 完成。
您可以在腳本中任何位置觸發(fā)錯(cuò)誤,通過(guò)添加的第二個(gè)參數(shù),您能夠規(guī)定所觸發(fā)的錯(cuò)誤級(jí)別。
4.可能的錯(cuò)誤類(lèi)型:
1).E_USER_ERROR - 致命的用戶(hù)生成的 run-time 錯(cuò)誤。錯(cuò)誤無(wú)法恢復(fù)。腳本執(zhí)行被中斷。
2).E_USER_WARNING - 非致命的用戶(hù)生成的 run-time 警告。腳本執(zhí)行不被中斷。
3).E_USER_NOTICE - 默認(rèn)。用戶(hù)生成的 run-time 通知。腳本發(fā)現(xiàn)了可能的錯(cuò)誤,也有可能在腳本運(yùn)行正常時(shí)發(fā)生。
例如:
復(fù)制代碼 代碼如下:
trigger_error("出錯(cuò)了啊", E_USER_WARNING);
// 輸出 Warning: 出錯(cuò)了啊 in xxxx 的錯(cuò)誤信息
三、錯(cuò)誤報(bào)告
默認(rèn)地,根據(jù)在 php.ini 中的 error_log 配置,PHP 向服務(wù)器的錯(cuò)誤記錄系統(tǒng)或文件發(fā)送錯(cuò)誤記錄。
通過(guò)使用 error_log() 函數(shù),您可以向指定的文件或遠(yuǎn)程目的地發(fā)送錯(cuò)誤記錄。比如把錯(cuò)誤信息發(fā)送到郵箱中是一種好的方式。
更多錯(cuò)誤處理文檔見(jiàn):http://www.php.net/manual/zh/book.errorfunc.php
四、異常處理
當(dāng)異常被拋出時(shí),其后的代碼不會(huì)繼續(xù)執(zhí)行,PHP 會(huì)嘗試查找匹配的 “catch” 代碼塊。
如果異常沒(méi)有被捕獲,而且又沒(méi)用使用 set_exception_handler() 作相應(yīng)的處理的話(huà),那么將發(fā)生一個(gè)嚴(yán)重的錯(cuò)誤(致命錯(cuò)誤),并且輸出 “Uncaught Exception” (未捕獲異常)的錯(cuò)誤消息。
1.處理處理程序應(yīng)當(dāng)包括:
1.)try - 使用異常的函數(shù)應(yīng)該位于 “try” 代碼塊內(nèi)。如果沒(méi)有觸發(fā)異常,則代碼將照常繼續(xù)執(zhí)行。但是如果異常被觸發(fā),會(huì)拋出一個(gè)異常。
2.)throw - 這里規(guī)定如何觸發(fā)異常。每一個(gè) “throw” 必須對(duì)應(yīng)至少一個(gè) “catch”
3.)catch - “catch” 代碼塊會(huì)捕獲異常,并創(chuàng)建一個(gè)包含異常信息的對(duì)象
2.重新拋出異常
有時(shí),當(dāng)異常被拋出時(shí),您也許希望以不同于標(biāo)準(zhǔn)的方式對(duì)它進(jìn)行處理??梢栽谝粋€(gè) “catch” 代碼塊中再次拋出異常。
腳本應(yīng)該對(duì)用戶(hù)隱藏系統(tǒng)錯(cuò)誤。對(duì)程序員來(lái)說(shuō),系統(tǒng)錯(cuò)誤也許很重要,但是用戶(hù)對(duì)它們并不感興趣。為了讓用戶(hù)更容易使用,您可以再次拋出帶有對(duì)用戶(hù)比較友好的消息的異常。
3.異常的規(guī)則
1).需要進(jìn)行異常處理的代碼應(yīng)該放入 try 代碼塊內(nèi),以便捕獲潛在的異常。
2).每個(gè) try 或 throw 代碼塊必須至少擁有一個(gè)對(duì)應(yīng)的 catch 代碼塊。
3).使用多個(gè) catch 代碼塊可以捕獲不同種類(lèi)的異常。
4).可以在 try 代碼塊內(nèi)的 catch 代碼塊中再次拋出(re-thrown)異常。
“PHP錯(cuò)誤和異長(zhǎng)常處理的方法有哪些”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。