首頁  >  文章  >  後端開發  >  PHP錯誤處理方法實例

PHP錯誤處理方法實例

小云云
小云云原創
2018-03-07 10:03:511508瀏覽

系統錯誤處理器:

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 data-filtered="filtered">";
    break;
  case E_USER_WARNING:
    echo "WARNING:<br data-filtered="filtered">";
    break;
  case E_USER_NOTICE:
    echo "NOTICE:<br data-filtered="filtered">";
    break;
  default:
    break;
  }
  echo "错误编号:" . $level . " <br data-filtered="filtered">";
  echo "错误信息:" . $msg;
}
//注册错误处理器
set_error_handler(&#39;my_error&#39;);
if (89 > 8) {
  //调用错误触发器
  trigger_error(&#39;这是错误啊&#39;, E_USER_WARNING);
}

运行结果如下:

WARNING:
错误编号:512
错误信息:这是错误啊

相关推荐:

php错误处理和日志记录

PHP错误与异常调试视频教程资源分享

PHP错误机制

以上是PHP錯誤處理方法實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn