PHP 錯誤處理機制_php技巧

來源:互聯網
上載者:User

在日常的項目開發過程中,總是會出現一些我們意想不到的異常錯誤,如果我們對此沒有進行相對完善的處理,那麼程式看上去也很不專業,也很可能就會成為別人攻擊系統的有效資訊;有些錯誤異常會終止指令碼執行,這個時候如果沒有一些錯誤提示資訊的話,那麼我們只能從頭開始看代碼了,要知道項目中成百上千行的代碼對我們來說是件多麼恐怖的事情啊,那麼我們如何在項目開發的過程中快速準確地定位到異常、錯誤呢,並進行相應的處理,本文由自己對錯誤、異常處理的瞭解,再此分享與大家相互學習交流,並作為一個備忘。

系統錯誤處理器:

PHP正常情況下,錯誤會正常的輸出,但在一些架構中,可能會影響錯誤的輸出,可能是架構本身有自己的處理機制,也可能代碼中作處理了,一般是這幾個函數設定:

1.error_reporting();  設定PHP 的報錯層級並返回當前層級

  error_reporting(report_level)

如果參數 level 未指定,當前報錯層級將被返回。下面幾項是 level 可能的值:

常量

描述

1

E_ERROR

致命的執行階段錯誤。不能回收此錯誤。指令碼被中斷執行。

2

E_WARNING

非致命的運行時警告。指令碼不被中斷執行。

4

E_PARSE

編譯時間分析錯誤。解析應該只由分析器產生的錯誤

8

E_NOTICE

運行時通知。該指令碼發現可能是一個錯誤,但通常運行一個指令碼時,也可能發生

16

E_CORE_ERROR

致命錯誤在PHP啟動時。這就好比在PHP核心的E_ERROR

32

E_CORE_WARNING

在PHP啟動時警告。這就好比在PHP核心的E_WARNING

64

E_COMPILE_ERROR

致命的編譯時間錯誤。這就好比通過了Zend指令碼引擎產生的E_ERROR

128

E_COMPILE_WARNING

非致命編譯時間警告。這就好比通過了Zend指令碼引擎產生E_WARNING

256

E_USER_ERROR

致命的使用者產生的錯誤,這類似於程式員使用PHP函數 trigger_error() 設定的 E_ERROR

512

E_USER_WARNING

非致命的使用者產生的警告,這類似於程式員使用PHP函數 trigger_error 設定的 E_WARNING

1024

E_USER_NOTICE

使用者產生的通知,這類似於程式員使用PHP函數trigger_error 設定的 E_NOTICE

2048

E_STRICT

運行時通知。PHP建議改變你的代碼,以協助該代碼的互通性和相容性

4096

E_RECOVERABLE_ERROR

可捕獲的致命錯誤,類似 E_ERROR,但可被使用者定義的處理常式捕獲(參見 set_error_handler())

8191

E_ALL

所有的錯誤和警告,除層級E_STRICT(在PHP6.0中,E_STRICT將是E_ALL的一部分)

這裡值得注意的是,$level為0的時候是關閉錯誤輸出,也就是任何錯誤都不會輸出。

2.set_error_handler()

定義和用法

set_error_handler() 函數設定使用者自訂的錯誤處理函數。

該函數用於建立運行時期間的使用者自己的錯誤處理方法。

該函數會返回舊的錯誤處理程式,若失敗,則返回 null。

文法

set_error_handler(error_function,error_types)

參數

描述

error_function

必需。規定發生錯誤時啟動並執行函數。

error_types

可選。規定在哪個錯誤報表層級會顯示使用者定義的錯誤。預設是 "E_ALL"。

提示:如果使用了該函數,會完全繞過標準的 PHP 錯誤處理函數,如果必要,使用者定義的錯誤處理程式必須終止 (die() ) 指令碼,

注釋:如果在指令碼執行前發生錯誤,由於在那時自訂程式還沒有註冊,因此就不會用到這個自訂錯誤處理程式。

測試代碼如下:

/** * * @param type $error_level 錯誤層級 * @param type $error_message    錯誤資訊 * @param type $error_file 可選 錯誤檔案 * @param type $error_line 可選 錯誤行 * @param type $error_context 可選。規定一個數組,包含了當錯誤發生時在用的每個變數以及它們的值。 */function my_error($error_level, $error_message, $error_file, $error_line, $error_context) {  echo date('Y-m-d H:i:s') . $error_level . $error_message . $error_file . $error_line;  var_dump($error_context);}set_error_handler('my_error', E_ALL);print_r($a); 

//通過上案例可以得知,在註冊 my_error 方法時,系統會自動覆蓋原有的錯誤處理 error_fuction() 方法
以上程式運行結果:

自訂錯誤觸發器

定義和用法

trigger_error() 函數建立使用者定義的錯誤訊息。

trigger_error() 用於在使用者指定的條件下觸發一個錯誤訊息。它與內建的錯誤處理器一同使用,也可以與由 set_error_handler() 函數建立的使用者自訂函數使用。

如果指定了一個不合法的錯誤類型,該函數返回 false,否則返回 true。

文法

trigger_error(error_message,error_types)

參數

描述

error_message

必需。規定錯誤訊息。長度限制為 1024 個字元。

error_types

可選。規定錯誤訊息的錯誤類型。 可能的值:

  • E_USER_ERROR
  • E_USER_WARNING
  • E_USER_NOTICE
測試代碼如下:

/** * * @param type $level * @param type $msg */function my_error($level, $msg) {  switch ($level) {  case E_USER_ERROR:    echo "ERROR:<br/>";    break;  case E_USER_WARNING:    echo "WARNING:<br/>";    break;  case E_USER_NOTICE:    echo "NOTICE:<br/>";    break;  default:    break;  }  echo "錯誤編號:" . $level . " <br/>";  echo "錯誤資訊:" . $msg;}//註冊錯誤處理器set_error_handler('my_error');if (89 > 8) {  //調用錯誤觸發器  trigger_error('這是錯誤啊', E_USER_WARNING);}

運行結果如下:

WARNING:
錯誤編號:512
錯誤資訊:這是錯誤啊

以上所述就是本文的全部內容了,希望大家能夠喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.