這篇文章將為大家詳細(xì)講解有關(guān)記錄PHP錯誤日志的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)公司專注于商河企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),成都商城網(wǎng)站開發(fā)。商河網(wǎng)站建設(shè)公司,為商河等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站策劃,專業(yè)設(shè)計,全程項目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)
記錄PHP錯誤日志的方法:首先設(shè)置PHP的配置文件;然后將使用指定的文件記錄錯誤報告日志;最后錯誤信息記錄到操作系統(tǒng)的日志里。
記錄PHP錯誤日志的方法:
1、使用指定的文件記錄錯誤報告日志
如果使用自己指定的文件記錄錯誤日志,一定要確保將這個文件存放在文檔根目錄之外,以減少遭到攻擊的可能。
并且該文件一定要讓PHP腳本的執(zhí)行用戶 (Web服務(wù)器進(jìn)程所有者)具有寫權(quán)限。假設(shè)在Linux操作系統(tǒng)中,將/usr/local/目錄下的error.log文件作為錯誤日志文件,并設(shè)置 Web服務(wù)器進(jìn)程用戶具有寫的權(quán)限。然后在PHP的配置文件中,將error_log指令的值設(shè)置為這個錯誤日志文件的絕對路徑。
需要將php.ini中的配置指令做如下修改:
error_reporting = E_ALL ;將會向PHP報告發(fā)生的每個錯誤
display_errors = Off ;不顯示滿足上條 指令所定義規(guī)則的所有錯誤報告
log_errors = On ;決定日志語句記錄的位置
log_errors_max_len = 1024 ;設(shè)置每個日志項的最大長度
error_log = /usr/local/error.log ;指定產(chǎn)生的 錯誤報告寫入的日志文件位置
PHP 的配置文件按上面的方式設(shè)置完成以后,并重新啟動Web服務(wù)器。這樣,在執(zhí)行PHP的任何腳本文件時,所產(chǎn)生的所有錯誤報告都不會在瀏覽器中顯示,而會記 錄在自己指定的錯誤日志/usr/local/error.log中。此外,不僅可以記錄滿足error_reporting所定義規(guī)則的所有錯誤,而且 還可以使用PHP中的error_log()函數(shù),送出一個用戶自定義的錯誤信息。
該函數(shù)的原型如下所示:
bool error_log ( string message [, int message_type [, string destination [, string extra_headers]] )
此 函數(shù)會送出錯誤信息到Web服務(wù)器的錯誤日志文件、某個TCP服務(wù)器或到指定文件中。該函數(shù)執(zhí)行成功則返回TRUE,失敗則返回FALSE。第一個參數(shù) message 是必選項,即為要送出的錯誤信息。如果僅使用這一個參數(shù),會按配置文件php.ini中所設(shè)置的位置處發(fā)送消息。第二個參數(shù)message_type為整 數(shù)值:0表示送到操作系統(tǒng)的日志中;1則使用PHP的Mail()函數(shù),發(fā)送信息到某E-mail處,第四個參數(shù)extra_headers亦會用到;2 則將錯誤信息送到TCP 服務(wù)器中,此時第三個參數(shù)destination表示目的地IP及Port;3則將信息存到文件destination中。
如果以登入Oracle數(shù)據(jù)庫出現(xiàn)問題的處理為例,該函數(shù)的使用如下所示:
2、 錯誤信息記錄到操作系統(tǒng)的日志里
錯誤報告也可以被記錄到操作系統(tǒng)日志里,但不同的操作系統(tǒng)之間的日志管理有點區(qū)別。在Linux上錯誤語句將送往syslog,而在Windows上錯誤 將發(fā)送到事件日志里。如果你不熟悉syslog,起碼要知道它是基于UNIX的日志工具,它提供了一個API來記錄與系統(tǒng)和應(yīng)用程序執(zhí)行有關(guān)的消息。 Windows事件日志實際上與UNIX的syslog相同,這些日志通??梢酝ㄟ^事件查看器來查看。如果希望將錯誤報告寫到操作系統(tǒng)的日志里,可以在配 置文件中將error_log指令的值設(shè)置為syslog。
具體需要在php.ini中修改的配置指令如下所示:
error_reporting = E_ALL ;將會向PHP報告發(fā)生的每個錯誤
display_errors = Off ;不顯示 滿足上條指令所定義規(guī)則的所有錯誤報告
log_errors = On ;決定日志語句記錄的位置
log_errors_max_len = 1024 ;設(shè)置每個日志項的最大長度
error_log = syslog ;指定產(chǎn)生的錯誤報告寫入操作系統(tǒng)的日志里
除了一般的錯誤輸出之外,PHP還允許向系統(tǒng)syslog中發(fā)送定制的消息。雖然通過前面介紹的error_log()函數(shù),也可以向syslog中發(fā)送定制的消息,但在PHP中為這個特性提供了需要一起使用的4個專用函數(shù)。
分別介紹如下:
define_syslog_variables()
在使用openlog()、syslog及closelog()三個函數(shù)之前必須先調(diào)用該函數(shù)。因為在調(diào)用該函數(shù)時,它會根據(jù)現(xiàn)在的系統(tǒng)環(huán)境為下面三個函數(shù)初使用化一些必需的常量。
openlog()
打開一個和當(dāng)前系統(tǒng)中日志器的連接,為向系統(tǒng)插入日志消息做好準(zhǔn)備。并將提供的第一個字符串參數(shù)插入到每個日志消息中,該函數(shù)還需要指定兩個將在日志上下文使用的參數(shù),可以參考官方文檔使用。
syslog()
該 函數(shù)向系統(tǒng)日志中發(fā)送一個定制消息。需要兩個必選參數(shù),第一個參數(shù)通過指定一個常量定制消息的優(yōu)先級。例如LOG_WARNING表示一般的警 告,LOG_EMERG表示嚴(yán)重地可以預(yù)示著系統(tǒng)崩潰的問題,一些其他的表示嚴(yán)重程度的常量可以參考官方文檔使用。第二個參數(shù)則是向系統(tǒng)日志中發(fā)送的定制 消息,需要提供一個消息字符串,也可以是PHP引擎在運(yùn)行時提供的錯誤字符串。
closelog()
該函數(shù)在向系統(tǒng)日志中發(fā)送完成定制消息以后調(diào)用,關(guān)閉由openlog()函數(shù)打開的日志連接。
如果在配置文件中,已經(jīng)開啟向syslog發(fā)送定制消息的指令,就可以使用前面介紹的四個函數(shù)發(fā)送一個警告消息到系統(tǒng)日志中,并通過系統(tǒng)中的syslog解析工具,查看和分析由PHP程序發(fā)送的定制消息,如下所示:
define_syslog_variables(); openlog("PHP5", LOG_PID , LOG_USER); syslog(LOG_WARNING, "警告報告向syslog中發(fā)送的演示, 警告時間:".date("Y/m/d H:i:s")); closelog(); ?>
關(guān)于記錄PHP錯誤日志的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。