亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么解決php中500錯誤問題

發布時間:2021-12-29 10:02:11 來源:億速云 閱讀:278 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“怎么解決php中500錯誤問題”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“怎么解決php中500錯誤問題”這篇文章吧。

php 500錯誤的解決辦法:1、檢查PHP腳本并修改;2、捕獲異常并記錄異常到日志;3、分析日志并處理即可。

怎么解決php中500錯誤問題

本文操作環境:Windows7系統、PHP7.1版、Dell G3電腦。

PHP與500錯誤

PHP開發過程中經常會遇到返回500錯誤的情況,而且body體中也沒有任何調試(可用)內容。這個時候你就需要慢慢調試了(打斷點,開調試模式等),但如果是現網,這個錯誤就比較讓人抓狂了,既不好打斷點也不能開調試模式。但既然是錯誤,總是會有處理方法,下面就一步步分析500的成因及處理方案。

0x01、500錯誤

500錯誤,也叫Internal Server Error(內部服務錯誤),表示服務因未知錯誤導致無法處理請求。在PHP站點中一般是由PHP返回,也就是說,500錯誤一般都是PHP腳本的錯誤。

怎么解決php中500錯誤問題

php-fpm抓包500

從上圖中可以看出(Nginx+PHP-FPM架構),在PHP調用一個不存在的類時,腳本發生錯誤并返回500給Nginx(并且將錯誤信息也做了返回,只不過是卸載STDERR中)。

0x02、哪些錯誤異常會導致500

那么哪類錯誤會導致500錯誤呢,PHP所有的錯誤級別可以在PHP的官方文文檔(http://php.net/manual/zh/errorfunc.constants.php)中查詢到,而這其中錯誤級別為E_ERROR、E_PARSE、E_RECOVERABLE_ERROR、E_USER_ERROR以及未捕獲的異常等都會導致500錯誤。

怎么解決php中500錯誤問題

E_ERROR級別錯誤導致的500

0x03、什么情況下錯誤不會返回500

上面說了,這個是PHP腳本的錯誤導致的,但是PHP腳本有了錯誤或異常一定會導致500嗎?顯然不是,即使在腳本有致命錯誤的情況下,依舊可以返回200。

怎么解決php中500錯誤問題

display_errors配置選項

在基于python、nodejs等的web應用中,默認情況下,如果出現異常信息會被打印到控制臺(STDERR/STDOUT)中。而在基于PHP-FPM架構的PHP中沒有控制臺可以打印,它的stderr和stdout被置為FastCGI中對應的STRDERR和STDOUT。如果將錯誤重定向到STDOUT中,錯誤會直接輸出到響應中,并且狀態碼也會置為200。這個也是display_errors選項所實現的能力。

display_errors選項的配置需要通過ini_set來實現,PHP文檔中關于display_errors的配置表明該值為字符串類型,實際使用中數字和布爾類型也可以打開或關閉該配置。

怎么解決php中500錯誤問題

error_reporting配置

display_errors控制了PHP腳本發生錯誤時是否顯示錯誤詳情以及是否返回錯誤狀態碼,而error_reporting項則用來控制哪級別的錯誤可以被直接打印出來。

error_reporting的設置項可以通過error_reporting(E_ALL)或ini_set('error_reporting', E_ALL)來配置,函數參數的詳情可以參考PHP文檔。

需要注意的是,PHP本身是有錯誤日志的(error_log和log_errors兩個配置項目),若發生錯誤,PHP會將改錯誤寫入錯誤日志中,而哪些錯誤需要被寫入是受error_reporting項的控制的。

怎么解決php中500錯誤問題

在錯誤級別不匹配的情況下不顯示錯誤詳情

0x04、現網如何合理處理500

500錯誤發生已經說明PHP腳本無法正常運行了,這時候能做的只是捕獲異常并記錄異常到日志,以方便日后的調試和現網bug的處理。

PHP自帶錯誤日志

PHP本身已經帶了錯誤日志的記錄,可以在php.ini中將log_errors項設置為On,并配合error_log配置項來指定錯誤日志的存放路徑。

怎么解決php中500錯誤問題

錯誤日志記錄開關

怎么解決php中500錯誤問題

日志路徑設置

該錯誤日志的的寫入不受display_errors的配置的控制。也就是說不管display_errors是否開啟,錯誤都會記錄到日志中。但是卻受error_reporting配置的控制,如果當前錯誤級別跟error_reporting中的錯誤級別不匹配的話,錯誤不會寫入日志中。即如果錯誤級別是E_ERROR,但是設置卻為error_reporting(E_NOTICE),那么日志中不會出現E_ERROR的出錯信息。

怎么解決php中500錯誤問題

PHP錯誤日志記錄各種類型的錯誤

怎么解決php中500錯誤問題

錯誤級別不匹配導致的日志不寫入

捕獲錯誤異常記錄

PHP提供了set_error_handler、register_shutdown_function、set_exception_handler、error_get_last等相關的錯誤處理函數。可以通過函數將捕獲到的錯誤信息寫入指定日志來實現錯誤的記錄。

函數的使用詳情可以參考http://km.oa.com/group/19368/articles/show/302491,這里提供一個模版:

$previousHandler = set_exception_handler(function(Exception $ex) use (&$previousHandler) {
    call_user_func('exceptionHandler', $ex, $previousHandler);
});
set_error_handler('errorHandler');
register_shutdown_function('fatalErrorHandler');
function exceptionHandler(Exception $ex, $previousHandler)
{
    $info = array(
        $ex->getFile(),
        $ex->getLine(),
        $ex->getCode(),
        $ex->getMessage()
    );
    // 記錄日志
    logPHPError($info);
    if (isset($previousHandler) && is_callable($previousHandler)) {
        call_user_func($previousHandler, $ex);
    }
}
/**
 * 框架錯誤處理函數
 * @param $errno
 * @param $errstr
 * @param $errfile
 * @param $errline
 * @return bool
 */
function errorHandler($errno = 0, $errstr = '', $errfile = '', $errline = 0)
{
    switch ($errno) {
        case E_WARNING:
            $errname = 'E_WARNING';
            break;
        case E_NOTICE:
            $errname = 'E_NOTICE';
            break;
        case E_STRICT:
            $errname = 'E_STRICT';
            break;
        case E_RECOVERABLE_ERROR:
            $errname = 'E_RECOVERABLE_ERROR';
            break;
        case E_DEPRECATED:
            $errname = 'E_DEPRECATED';
            break;
        case E_USER_ERROR:
            $errname = 'E_USER_ERROR';
            break;
        case E_USER_WARNING:
            $errname = 'E_USER_WARNING';
            break;
        case E_USER_NOTICE:
            $errname = 'E_USER_NOTICE';
            break;
        case E_USER_DEPRECATED:
            $errname = 'E_USER_DEPRECATED';
            break;
        default:
            restore_error_handler();
            return false;
    }
    // 記錄日志
    $info = array(
        $errfile,
        $errline,
        $errname,
        $errstr
    );
    logPHPError($info);
    restore_error_handler();
    return false;
}
/**
 * Fatal error錯誤處理
 */
function fatalErrorHandler()
{
    if (($e = error_get_last()) && $e['type'] === E_ERROR) {
        $info = array(
            $e['file'],
            $e['line'],
            'E_ERROR',
            $e['message']
        );
        // 記錄日志
        logPHPError($info);
    }
}

0x05 總結

總結起來,error_reporting是用于控制向瀏覽器或PHP錯誤日志輸出錯誤信息級別的函數或配置,而display_errors則是控制是否向瀏覽器輸出錯誤和告警信息。

由于PHP的錯誤日志是全局的,而且受到error_reporting的控制,因此推薦在業務中實現自己的錯誤(異常)捕獲記錄邏輯。

以上是“怎么解決php中500錯誤問題”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

休宁县| 登封市| 剑川县| 新丰县| 九寨沟县| 鹤峰县| 长兴县| 宜川县| 山东省| 景宁| 安丘市| 沈丘县| 珠海市| 榆中县| 平果县| 思南县| 东方市| 宣威市| 贡觉县| 大化| 图木舒克市| 三门峡市| 陆川县| 洪湖市| 北碚区| 锡林浩特市| 平昌县| 永宁县| 平谷区| 浙江省| 石河子市| 旅游| 新津县| 涟水县| 滦南县| 九台市| 略阳县| 建湖县| 桂林市| 东乌珠穆沁旗| 长兴县|