真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

記錄PHP錯誤日志的方法

這篇文章將為大家詳細(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錯誤日志的方法

記錄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é)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


當(dāng)前標(biāo)題:記錄PHP錯誤日志的方法
文章來源:http://weahome.cn/article/pjjeoj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部