首頁 >後端開發 >php教程 >PHP程式設計師遇到的錯誤與異常上篇之錯誤

PHP程式設計師遇到的錯誤與異常上篇之錯誤

不言
不言原創
2018-04-09 15:44:412153瀏覽

本篇文章介紹的內容是PHP程式設計師遇到的錯誤與異常中的錯誤的內容,現在分享給大家,有需要的朋友可以參考一下

一、PHP中錯誤模組簡介

     PHP錯誤與例外是兩個不同的概念

#1.1 錯誤型別

  1. ##文法錯誤,如少分號

  2. 環境錯誤,如權限、開啟檔案失敗、資料庫伺服器不可用

  3. #邏輯錯誤,如a==b 寫成了a=b

#1.2 PHP常見錯誤等級

  1. Depracated最低等級的錯誤(deprecated不建議,不推薦,如舊版的正規 ereg()函數換掉即可,不影響PHP的執行)

  2. #Notice通知層級的錯誤(語法不恰當導致的,不影響PHP的正常運行,如打印一個未定義的變量,所以我們一開始就要養成良好的書寫規範)

  3. Warning警告級別的錯誤(必須修改程式碼)

  4. Fatal error致命等級的錯誤,#程式會停止

  5. Parse error語法解析錯誤,在程式碼執行前檢查,將無法執行程式碼

  6. ##E_USER_相關的錯誤

    由使用者定義的錯誤,手動拋出錯誤時會用到

  7. 1.3 如何設定錯誤等級

#1.3.1 php.ini設定檔

error_reporting=E_ALL & ~E_NOTICE # 显示所有但不显示提醒错误
display_errors = Off|On # 是否显示错误,线上后关闭提高用户体验

1.3.2 動態設定

error_reporting() # 专业php错误处理设置函数,动态设置错误级别
error_reporting(0) # 不显示所有错误,但是解析parse语法错误会显示
error_reporting(-1) # 显示所有错误
Error_reporting(E_ALL|~E_WARING) # 除了警告错误以外的错误级别都报告

1.3.3 運行時設定組態選項的值

ini_set(option,value)

ini_set(error_reporting,0)
ini_set(error_reporting,-1)
ini_set(error_reporting,E_ALL)
ini_set(display_errors,0)
ini_set(display_errors,OFF/0)
error_reporting(-1);

14. trigger_error手動觸發錯發

    

@

錯誤抑制符,放在行首不顯示該行錯誤    手動拋出自訂錯誤訊息:

trigger_error('錯誤提示內容',E_USER_NOTICE)

##    

##  PHP程式設計師遇到的錯誤與異常上篇之錯誤錯誤等級:

E_USER_NOTICE # 继续执行(通知级别)
E_USER_WARNING # 继续执行(警告错误)
E_USER_ERROR # 程序不再执行(致命错误)

#二、處理PHP中的錯誤2.1 將錯誤日誌保存在指定檔案中

ini_set('display_errors','off') # 不显示错误给用户
ini_set("error_log","c:\error.log");       
error_reporting(-1); # 显示所有错误

2.2 錯誤日誌儲存在系統日誌中

ini_set("error_log", 'syslog')

2.3 將錯誤日誌傳送到郵件

error_log("this is a errormsg",1,xxxxx@qq.com);

三、自訂錯誤處理器

3.1 set_error_handler自訂錯誤處理

set_error_handler("自定义函数名",'错误级别(选填)') # 设置一个用户定义的错误处理函数    

restore_error_handler(); # 回收(取消自定义错误函数接管php系统错误)

     

##3.2 自訂錯誤處理器PHP程式設計師遇到的錯誤與異常上篇之錯誤

class MyErrorHandler{
    //错误信息
    public $message = '';
    //错误文件
    public $filename = '';
    //错误行号
    public $line = 0;
    //额外信息
    public $vars = array();
    protected $_noticelog = 'G:\notice\noticeLog.log';

    public function __construct($message, $filename, $line, $vars)
    {
        $this->message = $message;
        $this->filename = $filename;
        $this->line = $line;
        $this->vars = $vars;
    }
    //根据不同错误级别对应不同操作
    //遵循handler错误处理原则,errno:错误代码,line:错误行号
    public static function deal($errno,$errmsg,$filename,$line,$vars)
    {
        $self = new self($errmsg,$filename,$line,$vars);
        switch ($errno)
        {
            case E_USER_ERROR://致命级别
                return $self->dealError();
                break;
            case E_USER_WARNING://警告级别
            case E_WARNING:
                return $self->dealWarning();
                break;
            case E_NOTICE://通知级别
            case E_USER_NOTICE:
                return $self->dealNotice();
                break;
            default:
                return false;
        }
    }

    /**
     * 如何处理致命错误
     */
    public function dealError()
    {
        //开启内存缓冲
        ob_start();
        //回溯上一条信息
        debug_print_backtrace();
        $backtrace = ob_get_flush();
        $errorMsg = <<<EOF
        出现了致命错误,如下:
产生错误的文件:{$this->filename}
产生错误的信息:{$this->message}
产生错误的行号:{$this->line}
追踪信息:{$backtrace}
EOF;
//    error_log($errorMsg,1,&#39;xxxx@qq.com&#39;);
        error_log($errorMsg,3,$this->_noticelog);
        exit(1);
    }

    /**
     * 如何处理警告错误
     */
    public function dealWarning()
    {
        $errorMsg = <<<EOF
        出现了警告错误,如下:
产生警告的文件:{$this->filename}
产生警告的信息:{$this->message}
产生警告的行号:{$this->line}
EOF;
//        return error_log($errorMsg,1,&#39;xxx@qq.com&#39;);
        return error_log($errorMsg,3,$this->_noticelog);
    }

    /**
     * 如何处理通知错误
     */
    public function dealNotice()
    {
        $datetime = date(&#39;Y-m-d H:i:s&#39;,time());
        $errorMsg = <<<EOF
        出现了通知错误,如下:
产生通知的文件:{$this->filename}
产生通知的信息:{$this->message}
产生通知的行号:{$this->line}
产生通知的时间:{$datetime}
EOF;
        return error_log($errorMsg,3,$this->_noticelog);
    }
}
3.3 錯誤處理器測試

require_once &#39;MyErrorHandler.php&#39;;
error_reporting(-1);
//使用MyErrorHandler类直接调用deal方法
/**
 * set_error_handler(array(类名/new 类名,方法名));
 * set_error_handler(函数名);
 */
set_error_handler(array(&#39;MyErrorHandler&#39;,&#39;deal&#39;));

//通知级别错误
echo $test;
//警告级别错误
settype($var,&#39;king&#39;);
//致命错误
//test();

//总结:手动抛出的信息会被显示在浏览器
trigger_error(&#39;我是手动抛出的致命错误&#39;,E_USER_ERROR);

echo &#39;this is a test &#39;;

3.4 register_shutdown_function函數使用

     

##   #  PHP程式設計師遇到的錯誤與異常上篇之錯誤

##  

    頁面強制停止
  1. #程式碼意外終止或逾時
  2.      

PHP程式設計師遇到的錯誤與異常上篇之錯誤     

register_shutdown_function()

函數是從記憶體呼叫#的,也就是PHP語句執行完後(頁面已經不存在了)再來呼叫這個函數,所以寫路徑的時候已經脫離這個腳本了,所以file_put_contents()路徑要用絕對路徑

error_get_last # 得到最后产生的错误
     

注意:

如果在register_shutdown_function() 之前有die/exit則不會被執行

未完!待續下篇:

那些年,PHPer遇到的錯誤與異常:下篇之異常

參考課程影片:那些年你遇到的錯誤與異常


以上是PHP程式設計師遇到的錯誤與異常上篇之錯誤的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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