欧美亚洲中文,在线国自产视频,欧洲一区在线观看视频,亚洲综合中文字幕在线观看

      1. <dfn id="rfwes"></dfn>
          <object id="rfwes"></object>
        1. 站長(zhǎng)資訊網(wǎng)
          最全最豐富的資訊網(wǎng)站

          如何記錄PHP錯(cuò)誤日志

          記錄PHP錯(cuò)誤日志的方法:首先設(shè)置PHP的配置文件;然后將使用指定的文件記錄錯(cuò)誤報(bào)告日志;最后錯(cuò)誤信息記錄到操作系統(tǒng)的日志里。

          如何記錄PHP錯(cuò)誤日志

          記錄PHP錯(cuò)誤日志的方法:

          1、使用指定的文件記錄錯(cuò)誤報(bào)告日志

          如果使用自己指定的文件記錄錯(cuò)誤日志,一定要確保將這個(gè)文件存放在文檔根目錄之外,以減少遭到攻擊的可能。

          并且該文件一定要讓PHP腳本的執(zhí)行用戶 (Web服務(wù)器進(jìn)程所有者)具有寫權(quán)限。假設(shè)在Linux操作系統(tǒng)中,將/usr/local/目錄下的error.log文件作為錯(cuò)誤日志文件,并設(shè)置 Web服務(wù)器進(jìn)程用戶具有寫的權(quán)限。然后在PHP的配置文件中,將error_log指令的值設(shè)置為這個(gè)錯(cuò)誤日志文件的絕對(duì)路徑。

          相關(guān)學(xué)習(xí)推薦:php編程(視頻)

          需要將php.ini中的配置指令做如下修改:

          • error_reporting = E_ALL ;將會(huì)向PHP報(bào)告發(fā)生的每個(gè)錯(cuò)誤

          • display_errors = Off ;不顯示滿足上條 指令所定義規(guī)則的所有錯(cuò)誤報(bào)告

          • log_errors = On ;決定日志語句記錄的位置

          • log_errors_max_len = 1024 ;設(shè)置每個(gè)日志項(xiàng)的最大長(zhǎng)度

          • error_log = /usr/local/error.log ;指定產(chǎn)生的 錯(cuò)誤報(bào)告寫入的日志文件位置

          PHP 的配置文件按上面的方式設(shè)置完成以后,并重新啟動(dòng)Web服務(wù)器。這樣,在執(zhí)行PHP的任何腳本文件時(shí),所產(chǎn)生的所有錯(cuò)誤報(bào)告都不會(huì)在瀏覽器中顯示,而會(huì)記 錄在自己指定的錯(cuò)誤日志/usr/local/error.log中。此外,不僅可以記錄滿足error_reporting所定義規(guī)則的所有錯(cuò)誤,而且 還可以使用PHP中的error_log()函數(shù),送出一個(gè)用戶自定義的錯(cuò)誤信息。

          該函數(shù)的原型如下所示:

          bool error_log ( string message [, int message_type [, string destination [, string extra_headers]] )

          此 函數(shù)會(huì)送出錯(cuò)誤信息到Web服務(wù)器的錯(cuò)誤日志文件、某個(gè)TCP服務(wù)器或到指定文件中。該函數(shù)執(zhí)行成功則返回TRUE,失敗則返回FALSE。第一個(gè)參數(shù) message 是必選項(xiàng),即為要送出的錯(cuò)誤信息。如果僅使用這一個(gè)參數(shù),會(huì)按配置文件php.ini中所設(shè)置的位置處發(fā)送消息。第二個(gè)參數(shù)message_type為整 數(shù)值:0表示送到操作系統(tǒng)的日志中;1則使用PHP的Mail()函數(shù),發(fā)送信息到某E-mail處,第四個(gè)參數(shù)extra_headers亦會(huì)用到;2 則將錯(cuò)誤信息送到TCP 服務(wù)器中,此時(shí)第三個(gè)參數(shù)destination表示目的地IP及Port;3則將信息存到文件destination中。

          如果以登入Oracle數(shù)據(jù)庫(kù)出現(xiàn)問題的處理為例,該函數(shù)的使用如下所示:

          <?php  if(!Ora_Logon($username, $password)){  error_log("Oracle數(shù)據(jù)庫(kù)不可用!", 0); //將錯(cuò)誤消息寫入到操作系統(tǒng)日志中   }  if(!($foo=allocate_new_foo()){   error_log("出現(xiàn)大麻煩了!", 1, ". mydomain.com"); //發(fā)送到管理員郵箱中   }  error_log("搞砸了!", 2, "localhost:5000"); //發(fā)送到本機(jī)對(duì)應(yīng)5000端口的服務(wù)器中  error_log("搞砸了!", 3, "/usr/local/errors.log"); //發(fā)送到指定的文件中  ?>

          2、 錯(cuò)誤信息記錄到操作系統(tǒng)的日志里

          錯(cuò)誤報(bào)告也可以被記錄到操作系統(tǒng)日志里,但不同的操作系統(tǒng)之間的日志管理有點(diǎn)區(qū)別。在Linux上錯(cuò)誤語句將送往syslog,而在Windows上錯(cuò)誤 將發(fā)送到事件日志里。如果你不熟悉syslog,起碼要知道它是基于UNIX的日志工具,它提供了一個(gè)API來記錄與系統(tǒng)和應(yīng)用程序執(zhí)行有關(guān)的消息。 Windows事件日志實(shí)際上與UNIX的syslog相同,這些日志通??梢酝ㄟ^事件查看器來查看。如果希望將錯(cuò)誤報(bào)告寫到操作系統(tǒng)的日志里,可以在配 置文件中將error_log指令的值設(shè)置為syslog。

          具體需要在php.ini中修改的配置指令如下所示:

          • error_reporting = E_ALL ;將會(huì)向PHP報(bào)告發(fā)生的每個(gè)錯(cuò)誤

          • display_errors = Off ;不顯示 滿足上條指令所定義規(guī)則的所有錯(cuò)誤報(bào)告

          • log_errors = On ;決定日志語句記錄的位置

          • log_errors_max_len = 1024 ;設(shè)置每個(gè)日志項(xiàng)的最大長(zhǎng)度

          • error_log = syslog ;指定產(chǎn)生的錯(cuò)誤報(bào)告寫入操作系統(tǒng)的日志里

          除了一般的錯(cuò)誤輸出之外,PHP還允許向系統(tǒng)syslog中發(fā)送定制的消息。雖然通過前面介紹的error_log()函數(shù),也可以向syslog中發(fā)送定制的消息,但在PHP中為這個(gè)特性提供了需要一起使用的4個(gè)專用函數(shù)。

          分別介紹如下:

          define_syslog_variables()

          在使用openlog()、syslog及closelog()三個(gè)函數(shù)之前必須先調(diào)用該函數(shù)。因?yàn)樵谡{(diào)用該函數(shù)時(shí),它會(huì)根據(jù)現(xiàn)在的系統(tǒng)環(huán)境為下面三個(gè)函數(shù)初使用化一些必需的常量。

          openlog()

          打開一個(gè)和當(dāng)前系統(tǒng)中日志器的連接,為向系統(tǒng)插入日志消息做好準(zhǔn)備。并將提供的第一個(gè)字符串參數(shù)插入到每個(gè)日志消息中,該函數(shù)還需要指定兩個(gè)將在日志上下文使用的參數(shù),可以參考官方文檔使用。

          syslog()

          該 函數(shù)向系統(tǒng)日志中發(fā)送一個(gè)定制消息。需要兩個(gè)必選參數(shù),第一個(gè)參數(shù)通過指定一個(gè)常量定制消息的優(yōu)先級(jí)。例如LOG_WARNING表示一般的警 告,LOG_EMERG表示嚴(yán)重地可以預(yù)示著系統(tǒng)崩潰的問題,一些其他的表示嚴(yán)重程度的常量可以參考官方文檔使用。第二個(gè)參數(shù)則是向系統(tǒng)日志中發(fā)送的定制 消息,需要提供一個(gè)消息字符串,也可以是PHP引擎在運(yùn)行時(shí)提供的錯(cuò)誤字符串。

          closelog()

          該函數(shù)在向系統(tǒng)日志中發(fā)送完成定制消息以后調(diào)用,關(guān)閉由openlog()函數(shù)打開的日志連接。

          如果在配置文件中,已經(jīng)開啟向syslog發(fā)送定制消息的指令,就可以使用前面介紹的四個(gè)函數(shù)發(fā)送一個(gè)警告消息到系統(tǒng)日志中,并通過系統(tǒng)中的syslog解析工具,查看和分析由PHP程序發(fā)送的定制消息,如下所示:

          define_syslog_variables();  openlog("PHP5", LOG_PID , LOG_USER);   syslog(LOG_WARNING, "警告報(bào)告向syslog中發(fā)送的演示, 警告時(shí)間:".date("Y/m/d H:i:s"));   closelog();   ?>

          相關(guān)學(xué)習(xí)推薦:編程視頻

          贊(0)
          分享到: 更多 (0)
          網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)