在PHP中,主要有以下3種錯誤類型。
1. 注意(Notices)
這些都是比較小而且不嚴重的錯誤,比如去訪問一個未被定義的變量。通常,這類的錯誤是不提示給用戶的,但有時這些錯誤會影響到運行的結果。
2. 警告(Warnings)
這就是稍微嚴重一些的錯誤了,比如想要包含include()一個本身不存在的文件。這樣的錯誤信息會提示給用戶,但不會導致程序終止運行。
3. 致命錯誤(Fatal errors)
這些就是嚴重的錯誤,比如你想要初始化一個根本不存在的類的對象,或調用一個不存在的函數,這些錯誤會導致程序停止運行,PHP也會把這些錯誤展現給用戶。
不同的錯誤種類包括:
E_ERROR:通常會顯示出來,也會中斷程序執行。
E_WARNING:通常都會顯示出來,但不會中斷程序的執行。
E_NOTICE:在腳本正常運行下發生的代碼錯誤。
E_PARSE:語法解析錯誤。
E_CORE_ERROR:在PHP啟動時發生的致命錯誤。
E_CORE_WARNING:報告在PHP啟動時發生的非致命性錯誤。
E_COMPILE_ERROR:編譯時發生的致命錯誤,指出腳本的錯誤。
E_USER_ERROR:用戶產生的錯誤信息。
E_USER_WARNING:用戶產生的警告信息。
E_USER_NOTICE:用戶引發的注意消息。
E_STRICT:編碼標準化警告,運行時發生的錯誤。
E_RECOVERABLE_ERROR:接近致命的運行時錯誤,若未被捕獲則視同E_ERROR。
E_ALL:捕獲所有的錯誤和警告。
屏蔽PHP錯誤提示
方法一:在有可能出錯的函數前加@,然后or die("")
如:
@mysql_connect(...) or die("Database Connect Error")
方法二:編輯php.ini ,查找"display_errors =" ,將“=”后面的值改為"off。
方法三:在php腳本前加error_reporting(0),屏蔽所有錯誤提示。
其中,error_reporting 配置錯誤信息回報的等級。
語法:int error_reporting(int [level]);
返回值:整數
函數種類:PHP 系統功能
說明 int error_reporting ([ int $level ] )
error_reporting() 函數能夠在運行時設置 error_reporting 指令。 PHP 有諸多錯誤級別,使用該函數可以設置在腳本運行時的級別。 如果沒有設置可選參數 level, error_reporting() 僅會返回當前的錯誤報告級別。
參數
level新的 error_reporting 級別。 可以是一個位掩碼也可以是一個已命名的常量。 強烈建議使用已命名的常量,以確保兼容將來的版本。 由于錯誤級別的添加、整數取值范圍的增加, 較久的基于整數的錯誤級別不會總是和預期的表現一致。
可用的錯誤級別常量及其實際含義描述在了 predefined constants 中。
返回值 返回舊的 error_reporting 級別,或者在 level 參數未給出時返回當前的級別。
范例
Example #1 error_reporting() 范例
<?php
// 關閉所有PHP錯誤報告
error_reporting(0);
// Report simple running errors
error_reporting(E_ERROR | E_WARNING | E_PARSE);
// 報告 E_NOTICE也挺好 (報告未初始化的變量
// 或者捕獲變量名的錯誤拼寫)
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
// 除了 E_NOTICE,報告其他所有錯誤
// 這是在 php.ini 里的默認設置
error_reporting(E_ALL ^ E_NOTICE);
// 報告所有 PHP 錯誤 (參見 changelog)
error_reporting(E_ALL);
// 報告所有 PHP 錯誤
error_reporting(-1);
// 和 error_reporting(E_ALL); 一樣
ini_set('error_reporting', E_ALL);
?>
1. 注意(Notices)
這些都是比較小而且不嚴重的錯誤,比如去訪問一個未被定義的變量。通常,這類的錯誤是不提示給用戶的,但有時這些錯誤會影響到運行的結果。
2. 警告(Warnings)
這就是稍微嚴重一些的錯誤了,比如想要包含include()一個本身不存在的文件。這樣的錯誤信息會提示給用戶,但不會導致程序終止運行。
3. 致命錯誤(Fatal errors)
這些就是嚴重的錯誤,比如你想要初始化一個根本不存在的類的對象,或調用一個不存在的函數,這些錯誤會導致程序停止運行,PHP也會把這些錯誤展現給用戶。
不同的錯誤種類包括:
E_ERROR:通常會顯示出來,也會中斷程序執行。
E_WARNING:通常都會顯示出來,但不會中斷程序的執行。
E_NOTICE:在腳本正常運行下發生的代碼錯誤。
E_PARSE:語法解析錯誤。
E_CORE_ERROR:在PHP啟動時發生的致命錯誤。
E_CORE_WARNING:報告在PHP啟動時發生的非致命性錯誤。
E_COMPILE_ERROR:編譯時發生的致命錯誤,指出腳本的錯誤。
E_USER_ERROR:用戶產生的錯誤信息。
E_USER_WARNING:用戶產生的警告信息。
E_USER_NOTICE:用戶引發的注意消息。
E_STRICT:編碼標準化警告,運行時發生的錯誤。
E_RECOVERABLE_ERROR:接近致命的運行時錯誤,若未被捕獲則視同E_ERROR。
E_ALL:捕獲所有的錯誤和警告。
屏蔽PHP錯誤提示
方法一:在有可能出錯的函數前加@,然后or die("")
如:
@mysql_connect(...) or die("Database Connect Error")
方法二:編輯php.ini ,查找"display_errors =" ,將“=”后面的值改為"off。
方法三:在php腳本前加error_reporting(0),屏蔽所有錯誤提示。
其中,error_reporting 配置錯誤信息回報的等級。
語法:int error_reporting(int [level]);
返回值:整數
函數種類:PHP 系統功能
說明 int error_reporting ([ int $level ] )
error_reporting() 函數能夠在運行時設置 error_reporting 指令。 PHP 有諸多錯誤級別,使用該函數可以設置在腳本運行時的級別。 如果沒有設置可選參數 level, error_reporting() 僅會返回當前的錯誤報告級別。
參數
level新的 error_reporting 級別。 可以是一個位掩碼也可以是一個已命名的常量。 強烈建議使用已命名的常量,以確保兼容將來的版本。 由于錯誤級別的添加、整數取值范圍的增加, 較久的基于整數的錯誤級別不會總是和預期的表現一致。
可用的錯誤級別常量及其實際含義描述在了 predefined constants 中。
返回值 返回舊的 error_reporting 級別,或者在 level 參數未給出時返回當前的級別。
范例
Example #1 error_reporting() 范例
<?php
// 關閉所有PHP錯誤報告
error_reporting(0);
// Report simple running errors
error_reporting(E_ERROR | E_WARNING | E_PARSE);
// 報告 E_NOTICE也挺好 (報告未初始化的變量
// 或者捕獲變量名的錯誤拼寫)
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
// 除了 E_NOTICE,報告其他所有錯誤
// 這是在 php.ini 里的默認設置
error_reporting(E_ALL ^ E_NOTICE);
// 報告所有 PHP 錯誤 (參見 changelog)
error_reporting(E_ALL);
// 報告所有 PHP 錯誤
error_reporting(-1);
// 和 error_reporting(E_ALL); 一樣
ini_set('error_reporting', E_ALL);
?>