首頁 後端開發 php教程 針對PHP5.5.32版本的錯誤機制總結

針對PHP5.5.32版本的錯誤機制總結

Dec 10, 2016 am 09:33 AM
php 版本 錯誤機制

PHP的錯誤等級

首先需要了解php有哪些錯誤。截至到php5.5,一共有16個錯誤級別

注意:嘗試下面的代碼的時候請確保打開error_log:

error_reporting(E_ALL);  
ini_set('display_errors', 'On');
登入後複製

E_ERROR

這種錯誤是致命錯誤,會在頁面顯示Fatal Error, 當出現這種錯誤的時候,程式就無法繼續執行下去了

錯誤範例:

// Fatal error: Call to undefined function hpinfo() in /tmp/php/index.php on line 5 
hpinfo();  //E_ERROR
登入後複製

注意,如果有未被捕獲的異常,也是會觸發這個等級的。

// Fatal error: Uncaught exception 'Exception' with message 'test exception' in /tmp/php/index.php:5 Stack trace: #0 {main} thrown in /tmp/php/index.php on line 5 
throw new \Exception("test exception");
登入後複製

這種錯誤只是警告,不會終止腳本,程式還會繼續進行,顯示的錯誤訊息是Warning。例如include一個不存在的檔案。

//Warning: include(a.php): failed to open stream: No such file or directory in /tmp/php/index.php on line 7 
//Warning: include(): Failed opening 'a.php' for inclusion (include_path='.:/usr/share/pear:/usr/share/php') in /tmp/php/index.php on line 7 
include("a.php"); //E_WARNING
登入後複製

E_NOTICE

這種錯誤程度更為輕微一些,提示你這個地方不應該這麼寫。這個也是運行時錯誤,這個錯誤的程式碼可能在其他地方沒有問題,只是在當前上下文情況下出現了問題。

例如$b變數不存在,我們把它賦值給另外一個變數

//Notice: Undefined variable: b in /tmp/php/index.php on line 9 
$a = $b; //E_NOTICE
登入後複製

E_PARSE

這個錯誤是編譯時候發生的,在編譯期間發現語法錯誤,不能進行語法分析。

例如下面的z沒有設定為變數。

// Parse error: syntax error, unexpected '=' in /tmp/php/index.php on line 20 
z=1; // E_PARSE
登入後複製

E_STRICT

這個錯誤是PHP5之後引入的,你的程式碼可以運行,但是不是PHP建議的寫法。

例如在函數形參傳遞++符號

// Strict Standards: Only variables should be passed by reference in /tmp/php/index.php on line 17  
function change (&$var) { 
  $var += 10; 
} 
$var = 1; 
change(++$var); 
// E_STRICT
登入後複製

E_RECOVERABLE_ERROR

這個等級其實是ERROR等級的,但是它是期望被捕獲的,如果沒有被錯誤處理捕獲,表現和E_ERROR是一樣的。

經常出現在形參定義了類型,但調用的時候傳入了錯誤類型。它的錯誤提醒也比E_ERROR的fatal error前面多了一個Catachable的字樣。

//Catchable fatal error: Argument 1 passed to testCall() must be an instance of A, instance of B given, called in /tmp/php/index.php on line 37 and defined in /tmp/php/index.php on line 33 
class A { 
} 
 
class B { 
} 
 
function testCall(A $a) { 
} 
 
$b = new B(); 
testCall($b);
登入後複製

E_DEPRECATED

這個錯誤表示你用了一個舊版本的函數,而這個函數後期版本可能被禁用或不維護了。

例如curl的CURLOPT_POSTFIELDS使用@FILENAME來上傳檔案的方法

// Deprecated: curl_setopt(): The usage of the @filename API for file uploading is deprecated. Please use the CURLFile class instead in /tmp/php/index.php on line 42 
 
$ch = curl_init("http://www.php.cn/upload.php"); curl_setopt($ch, CURLOPT_POSTFIELDS, array('fileupload' => '@'. "test"));
登入後複製

E_CORE_ERROR, E_CORE_WARNING

這兩個錯誤是由PHP的初始化引擎產生的,在PHPPHPPHP的初始化過程中發生的。

E_COMPILE_ERROR, E_COMPILE_WARNING

這兩個錯誤是由PHP引擎產生的,在編譯過程中發生。

E_USER_ERROR, E_USER_WARNING, E_USER_NOTICE, E_USER_DEPRECATED,

這些錯誤都是使用者製造的,使用trigger_error,這裡就相當於一個

這些錯誤都是使用者製造出各種類型錯誤。這是一個很好逃避try catch異常的方式。

trigger_error("Cannot divide by zero", E_USER_ERROR); // E_USER_ERROR // E_USER_WARING // E_USER_NOTICE // E_USER_DEPRECATED
登入後複製

E_ALL

E_STRICT出外的所有錯誤和警告訊息。

錯誤控制

php中有很多配置和參數是可以控制錯誤,以及錯誤的日誌顯示的。第一步,我們要了解的是php中的有關錯誤的配置有哪些?

我們按照php+php-fpm的模型來說,會影響php錯誤顯示的其實是有兩個配置文件,一個是php本身的配置檔案php.ini,另外一個是php-fpm的配置文件,php -fpm.conf。

php.ini中的設定

error_reporting = E_ALL  // 报告错误级别,什么级别的 
 
error_log = /tmp/php_errors.log // php中的错误显示的日志位置 
 
display_errors = On // 是否把错误展示在输出上,这个输出可能是页面,也可能是stdout 
 
display_startup_errors = On // 是否把启动过程的错误信息显示在页面上,记得上面说的有几个Core类型的错误是启动时候发生的,这个就是控制这些错误是否显示页面的。 
 
log_errors = On // 是否要记录错误日志 
 
log_errors_max_len = 1024 // 错误日志的最大长度 
 
ignore_repeated_errors = Off // 是否忽略重复的错误 
 
track_errors = Off // 是否使用全局变量$php_errormsg来记录最后一个错误 
 
xmlrpc_errors = 0 //是否使用XML-RPC的错误信息格式记录错误 
 
xmlrpc_error_number = 0 // 用作 XML-RPC faultCode 元素的值。 
 
html_errors = On  // 是否把输出中的函数等信息变为HTML链接 
 
docref_root = http://manual/en/ // 如果html_errors开启了,这个链接的根路径是什么 
 
fastcgi.logging = 0 // 是否把php错误抛出到fastcgi中
登入後複製

我們常常被問到,error_reporting和display_errors有什麼差別呢?這兩個函數是完全不一樣的。

PHP預設是會在日誌和標準輸出(如果是fpm模式標準輸出就是頁)

error_reporting的參數是錯誤等級。表示什麼樣子的等級才應該觸發錯誤。如果我們告訴PHP,所有錯誤等級都不需要觸發錯誤,那麼,不管是日誌,還是頁面,都不會顯示這個錯誤,就等於什麼都沒有發生。

display_errors是控制是否要在標準輸出展示錯誤訊息

log_errors是控制是否要在日誌中記錄錯誤訊息。

error_log是顯示錯誤日誌的位置,這個在php-fpm中往往會被重寫,於是往往會發現的是cli和fpm的錯誤日誌竟然不是在同一個文件中。

ignore_repeated_errors這個標記控制的是如果有重複的日誌,那麼就只會記錄一條,例如下面的程式:

error_reporting(E_ALL); 
ini_set('ignore_repeated_errors', 1); 
ini_set('ignore_repeated_source', 1); 
$a = $c; $a = $c; //E_NOTICE 
//Notice: Undefined variable: c in /tmp/php/index.php on line 20
登入後複製

本來會出現兩次NOTICE的,但是現在,只會出現一次了…

track_errors會把最後一個錯誤訊息儲存到變數裡面去,這個可能在對記日誌的時候會有一些用處吧。不過我覺得真是沒啥用…

html_errors 和docref_root 兩個是個挺有人性化的配置,配置了這兩個參數以後,我們返回的錯誤信息中如果有一些在文檔中有的信息,就會變成連結形式。

error_reporting(E_ALL); 
ini_set('html_errors', 1); 
ini_set('docref_root', "https://secure.php.net/manual/zh/"); 
include("a2.php"); //E_WARNING
登入後複製

能讓你快速定位到我們出現錯誤的地方。是不是很人性~

php-fpm中的配置

error_log = /var/log/php-fpm/error.log // php-fpm自身的日志 
log_level = notice // php-fpm自身的日志记录级别 
php_flag[display_errors] = off // 覆盖php.ini中的某个配置变量,可被程序中的ini_set覆盖 
php_value[display_errors] = off // 同php_flag 
php_admin_value[error_log] = /tmp/www-error.log // 覆盖php.ini中的某个配置变量,不可被程序中的ini_set覆盖 
php_admin_flag[log_errors] = on // 同php_admin_value 
catch_workers_output = yes // 是否抓取fpmworker的输出 
request_slowlog_timeout = 0 // 慢日志时长 
slowlog = /var/log/php-fpm/www-slow.log // 慢日志记录
登入後複製

php-fpm的配置中也有一個error_log配置,這個很常會和php.ini中的error_log配置弄混。但他們記錄的東西是不一樣的,php-fpm的error_log只記錄php-fpm本身的日誌,例如fpm啟動,關閉。

🎜而php.ini中的error_log是記錄php程式本身的錯誤日誌。 🎜

那麼在php-fpm要覆寫php.ini中的error_log配置,就需要使用到下面幾個函數:

  • php_flag

  • php_value

  • 這四個函數admin的兩個函數說明這個變數設定完之後,就不能在程式碼中使用ini_set把這個變數重新賦值了。而php_flag/value就還是以php程式碼中的ini_set為準。

  • slowlog是fpm記錄的,可以使用request_slowlog_timeout設定來判斷慢日誌的時長。
  • 總結

我們經常弄混的就是日誌問題,以及某些等級的日誌為何沒有記錄到日誌中。最主要的是要看error_log,display_errors, log_errors這三個配置,只是在看配置的時候,我們還要注意區分php.ini裡面的配置是什麼,php-fpm.ini裡面的配置是什麼。

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

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1667
14
CakePHP 教程
1426
52
Laravel 教程
1328
25
PHP教程
1273
29
C# 教程
1255
24
PHP:網絡開發的關鍵語言 PHP:網絡開發的關鍵語言 Apr 13, 2025 am 12:08 AM

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP和Python:比較兩種流行的編程語言 PHP和Python:比較兩種流行的編程語言 Apr 14, 2025 am 12:13 AM

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP與Python:了解差異 PHP與Python:了解差異 Apr 11, 2025 am 12:15 AM

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP行動:現實世界中的示例和應用程序 PHP行動:現實世界中的示例和應用程序 Apr 14, 2025 am 12:19 AM

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP的持久相關性:它還活著嗎? PHP的持久相關性:它還活著嗎? Apr 14, 2025 am 12:12 AM

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。

PHP和Python:解釋了不同的範例 PHP和Python:解釋了不同的範例 Apr 18, 2025 am 12:26 AM

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

PHP與其他語言:比較 PHP與其他語言:比較 Apr 13, 2025 am 12:19 AM

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP和Python:代碼示例和比較 PHP和Python:代碼示例和比較 Apr 15, 2025 am 12:07 AM

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

See all articles