>백엔드 개발 >PHP 튜토리얼 >PHP 프로그래머가 직면한 오류 및 예외 1부 오류

PHP 프로그래머가 직면한 오류 및 예외 1부 오류

不言
不言원래의
2018-04-09 15:44:412141검색

이 글은 PHP 프로그래머들이 겪는 오류와 예외를 소개합니다. 이제 여러분과 공유합니다. 도움이 필요한 친구들이 참고할 수 있습니다

1. PHP의 오류 모듈 소개

PHP 오류와 예외는 서로 다른 개념입니다

1.1 오류 유형

  1. 세미콜론 누락과 같은 구문 오류

  2. 권한, 파일 열기 실패, 데이터베이스 서버 사용 불가와 같은 환경 오류

  3. a= =b와 같은 논리 오류는 다음과 같이 기록됩니다. a=b

1.2 PHP 일반 오류 수준

  1. Deprecated최하위 수준 오류(비추천, 권장되지 않음, 예를 들어 일반 ereg( )의 이전 버전) 함수는 대체될 수 있으며 PHP 실행에는 영향을 미치지 않습니다) Depracated最低级别的错误 (deprecated不建议,不推荐,如老版本的正则ereg()函数换掉即可,并不影响PHP的执行)

  2. Notice通知级别的错误(语法不恰当导致的,不影响PHP的正常运行,如打印一个未定义的变量,所以我们一开始就要养成良好的书写规范)

  3. Warning警告级别的错误(必须修改代码)

  4. Fatal error致命级别的错误,程序会停止

  5. Parse error语法解析错误,在代码运行前检查,将无法执行代码

  6. E_USER_相关的错误 由用户定义的错误,手动抛出错误时会用到

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 프로그래머가 직면한 오류 및 예외 1부 오류

  错误级别:

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系统错误)

     PHP 프로그래머가 직면한 오류 및 예외 1부 오류

3.2 自定义错误处理器

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부 오류

     使用场景:

  1. 页面强制被停止

  2. 程序代码意外终止或超时

     PHP 프로그래머가 직면한 오류 및 예외 1부 오류

     register_shutdown_function()函数是从内存中调用的,也就是PHP语句执行完之后(页面已不存在了)再调用这个函数,所以写路径的时候已经脱离这个脚本了,所以file_put_contents()路径要用绝对路径

error_get_last # 得到最后产生的错误

     注意:如果在register_shutdown_function() 之前有die/exit则不会被执行

未完!待续下篇:那些年,PHPer遇到的错误与异常:下篇之异常

알림알림 수준 오류(부적절한 구문으로 인해 발생하며 다음과 같은 PHP의 정상적인 작동에 영향을 미치지 않습니다) 인쇄 정의되지 않은 변수이므로 처음부터 좋은 작성 습관을 개발해야 합니다)


경고경고 수준 오류(코드를 수정해야 함)


치명적 오류치명적 수준 오류, 🎜<code>프로그램이 중지됩니다🎜🎜🎜🎜🎜분석 오류 구문 분석 오류, 코드를 실행하기 전에 확인하세요, 🎜가 실행되지 않습니다. 🎜🎜🎜🎜🎜E_USER_관련 오류 사용자가 정의한 오류, 수동으로 오류를 던질 때 사용🎜🎜🎜🎜1.3 오류 수준 설정 방법🎜

1.3 .1 php.ini 구성 file

rrreee

1.3.2 동적 설정

rrreee

1.3.3 런타임 시 구성 옵션 값 설정

rrreee🎜14.trigger_error 수동 트리거 오류 🎜🎜 @ 오류 억제자를 줄의 시작 부분에 배치하여 줄에 오류를 표시하지 않습니다. 🎜🎜 사용자 정의 오류 메시지를 수동으로 발생시킵니다: trigger_error('error Prompt content',E_USER_NOTICE) 코드 >🎜🎜 <span class="img-wrap"><img src="https://img.php.cn/upload/article/000/153/291/bc95c4ca7986535b3f43e1931936f826-0.png" alt="PHP 프로그래머가 직면한 오류 및 예외 1부 오류" ></span> 🎜🎜 🎜오류 수준: 🎜🎜rrreee🎜 2. PHP에서 오류 처리 🎜🎜2.1 지정된 파일에 오류 로그 저장 🎜rrreee🎜2.2 시스템 로그에 오류 로그 저장 🎜rrreee🎜2.3 오류 로그를 이메일로 보내기 🎜 rrreee🎜3. 사용자 정의 오류 처리기🎜🎜3.1 set_error_handler 사용자 정의 오류 처리🎜rrreee🎜  <span class="img-wrap"><img src="https://img.php.cn/upload/article/000%20/153%20/291/bc95c4ca7986535b3f43e1931936f826-1.png" alt="PHP 프로그래머가 직면한 오류 및 예외 1부 오류" ></span>🎜🎜3.2 사용자 정의 오류 핸들러🎜rrreee🎜3.3 오류 핸들러 테스트🎜rrreee🎜3.4 Register_shutdown_function 사용법🎜🎜 pan class="img-wrap "><img src="https://img.php.cn/upload/article/000/153/291/343353203eb64e8381aa8c57bde2c869-2.png" alt="PHP 프로그래머가 직면한 오류 및 예외 1부 오류" >🎜🎜  🎜사용 시나리오: 🎜🎜🎜🎜🎜 페이지가 강제로 중지되었습니다. 🎜🎜🎜🎜프로그램 코드가 예기치 않게 종료되거나 시간이 초과되었습니다🎜🎜🎜🎜                                                               /291/343353203eb64e8381aa8c57bde2c869-3.png"/>🎜🎜 <code>register_shutdown_function()함수는 🎜 메모리에서 호출🎜, 즉 PHP 문이 실행됩니다. 이 함수는 나중에 호출되므로(페이지가 더 이상 존재하지 않음) 경로를 작성할 때 이미 스크립트에서 벗어났으므로 file_put_contents( )🎜경로는 절대 경로를 사용해야 합니다🎜🎜 rrreee🎜  🎜참고: 🎜register_shutdown_function() 앞에 <code>die/exit가 있는 경우 code>, 실행되지 않습니다🎜🎜🎜아직 끝나지 않았습니다! 다음 기사에서 계속: 🎜해당 기간 동안 PHPer에서 발생한 오류 및 예외: 다음 기사의 예외🎜🎜🎜참조 과정 비디오: 해당 기간 동안 발생한 오류 및 예외🎜🎜🎜🎜 🎜🎜 🎜🎜

위 내용은 PHP 프로그래머가 직면한 오류 및 예외 1부 오류의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.