简介 目录 评价 推荐
  • 度伊人董事长 2024-08-23

    /**
     * 给观察者定义规范
     *
     * Interface Exception_Observer
     */
    interface Exception_Observer
    {
        public function update(Observable_Exception $e);
    }


    /**
     * 定义观察者
     * Class Observable_Exception
     */
    class Observable_Exception extends Exception
    {
        //保存观察者信息
        public static $_observers = array();
        public static function attach(Exception_Observer $observer)
        {
            self::$_observers[] = $observer;
        }
        public function __construct($message = "", $code = 0, Throwable $previous = null)
        {
            parent::__construct($message, $code, $previous);
            $this->notify();
        }
        public function notify()
        {
            foreach (self::$_observers as $observer) {
                $observer->update($this);
            }
        }
    }

    /**
     * 记录错误日志
     */
    class Logging_Exception_Observer implements Exception_Observer
    {
        protected $_filename = __DIR__.'/error_observer.log';
        public function __construct($filename = null)
        {
            if ($filename!==null && is_string($filename)){
                $this->_filename = $filename;
            }
        }

        public function update(Observable_Exception $e)
        {
            $message = "时间:".date('Y:m:d H:i:s',time()).PHP_EOL;
            $message.= "信息:".$e->getMessage().PHP_EOL;
            $message.= "追踪信息:".$e->getTraceAsString().PHP_EOL;
            $message.= "文件:".$e->getFile().PHP_EOL;
            $message.= "行号:".$e->getLine().PHP_EOL;
            error_log($message,3,$this->_filename);//写到日志中
        }
    }

    /**
     * 测试
     */
    header('content-type:text/html;charset=utf-8');
    require_once 'Exception_Observer.php';
    require_once 'Logging_Exception_Observer.php';
    require_once 'Observable_Exception.php';

    Observable_Exception::attach(new Logging_Exception_Observer());

    class MyException extends Observable_Exception{
        public function test1()
        {
            echo 'this is a test';
        }
    }

    try{
        throw new MyException('出现了异常!');
    }catch (MyException $exception){
        echo $exception->getMessage();
    }

    0赞 · 0采集
  • weixin_慕神7086185 2022-08-17
    Trigger_error 手动触发PHP错误,并自定义错误提示及错误级别。
    0赞 · 0采集
  • qq__afhpOX 2020-06-06
    开始
    0赞 · 0采集
  • 碰磁王110 2019-05-15

    PHP配置文件中与错误相关选项

    1.error_reporting 设置错误报告级别

    2.display_errors 是否显示错误

    3.log_errors 设置是否将错误信息记录到日志或者error_log中

    4.error_log 设置脚本错误将记录到的文件

    5.log_errors_max_len 设置log_errors的最大字节数

    6.ignore_repeated_errors 是否忽略重复的错误信息

    7.ignore_repeated_source 是否忽略重复错误消息的来源

    8.track_errors 如果开启此选项,最后一个错误将永远保存在$php_errormsg中


    PHP中的错误级别

    1.E_ERROR 致命的运行错误,将终止程序执行

    2.E_WARNING 运行时警告

    3.E_PARSE 语法解析错误

    4.E_NOTICE 通知注意,表示可能表现为错误的情况

    5.E_CORE_ERROR 在PHP初始化启动过程中发生的警告

    6.E_CORE_WARNING PHP初始化启动过程中发生的警告

    7.E_COMPILE_ERROR 致命编译错误

    8.E_COMPILE_WARNGING 编译时警告

    9.E_USER_EORROR 用户产生的错误信息,类似E_ERROR,但是是由用户自己在代码中使用trigger_error()函数产生的。

    10.U_USER_WARNING 用户产生的警告信息,类似E_WARNING,但是是由用户自己在代码中使用trigger_error()函数产生的

    11.E_USER_NOTICE 用户产生的通知信息,类似E_NOTICE,但是是由用户自己在代码中使用trigger_error()函数产生的

    12.E_STRICT 启动PHP对代码的修改建议,以确保代码具有最佳的互操作性和向前的兼容性。

    13.E_DEPRECATED 运行时通知,启动后将会对在未来版本中可能无法正常工作的代码给出警告。

    14.E_USER_DEPRECATED 用户产生的警告信息,类似E_DEPRECATED,但是是通过trigger_error()函数产生的

    15.E_ALL 所有错误和警告信息

    16.E_RECOVERABLE_ERROR 可被捕获的指明错误,它表示发生了一个可能非常危险的错误,但是还没有导致PHP引擎处于不稳定的状态。如果该错误没有被用户自定义句柄捕获(参见set_error_handler()),将成为一个E_ERROR从而脚本会终止运行

    0赞 · 0采集
  • 碰磁王110 2019-05-14

    <?php

    class shutdown{

    public function endScript(){

    if(error_get_last()){

    echo '<pre>';

    print_r(error_get_last());

    echo '</pre>';

    }

    file_put_contents('E:\www\error_log\test.txt','This is a test.');

    die('end script');


    }

    }

    //md6();

    settype($arr, 'hello');

    register_shutdown_function([new shutdown(),'endScript']);

    ?>


    0赞 · 0采集
  • 碰磁王110 2019-05-14

    <?php

    error_reporting(-1);

    set_error_handler(function($errno,$errmsg,$file,$line){

    echo "<hr /><b>错误代码:</b>[{$errno}] {$errmsg}<br />".PHP_EOL;

    echo "<b>错误行号:</b>{$file}文件中的第{$line}行<br />".PHP_EOL;

    echo "<b>PHP版本:</b>".PHP_VERSION."(".PHP_OS.")".PHP_EOL;

    });

    echo $test;

    settype($arr,'aaa');

    //取消接管

    restore_error_handler();

    ?>

    通过回调函数显示错误信息:

    set_error_handler();

    set_exception_handler();


    0赞 · 0采集
  • 碰磁王110 2019-05-14

    <?php

    ini_set('display_errors', 0);

    error_reporting(-1);

    ini_set('log_errors', 1);

    ini_set('error_log','E:\www\error_log\test.log');

    $date = date('Y-m-d H:i:s',time());

    $message = "用户名:username,密码:123456,时间:{$date},IP地址:{$_SERVER['REMOTE_ADDR']}。";

    error_log($message);

    ?>

    PHP错误类型

    1、语法错误

    2、环境错误

    3、逻辑错误

    Deprecated 最低级别错误,不推荐使用的函数等。

    Notice 通知级别错误,未声明的变量,或数组value等。

    Warning 警告级别的错误,不存在的变量类型等。

    Fatal 致命级别错误,不存在的函数等。

    Parse 语法解析错误,缺少“;”等。

    E_USER_相关的错误。


    display_errors 是否显示错误

    error_reporting(E_ALL~E_NOTICE) 函数设置错误

    error_reporting(0);不显示所有错误,“-1”显示所有错误。

    ini_set('error_reporting',0); 设置为不显示。


    trigger_error()函数触发错误,手动抛出错误。

    trigger_error('错误提示',E_USER_ERROE);


    error_log = "E:\www\error_log\test.log" 在.ini中设置,错误日志保存路径


    0赞 · 0采集
  • qq_我还记得_0 2019-04-14

    Error_log函数有2个功能 1将消息写入log文件error_log($message) 2发邮件

    0赞 · 0采集
  • qq_我还记得_0 2019-04-14

    PHP配置文件中的错误相关选项;5982914d0001cc2912800720.jpg

    0赞 · 0采集
  • qq_我还记得_0 2019-04-14

    Trigger_error用于抛出自定义错误 If(!numberic($num1)){ Trigger_error("必须是合法数字",E_USER_NOTICE)

    0赞 · 0采集
  • qq_我还记得_0 2019-04-14

    请输入笔记内容.error_reporting():专业php错误处理设置函数

    error_reporting(0);不显示所有错误,但是解析parse语法错误会显示;

    Error_reporting(E_ALL|~E_WARING)除了警告错误以外的错误级别都报告

    显示错误

    ini_set(Option,value):可以配置php.ini里的选项,当然包括错误处理部分的选项了

    设置错误级别..

    ini_set('error_reporting',0)=>不显示所有错误;

    ini_set('error_reporting',-1)=>显示所有错误;

    php配置文件php.ini设置error_reporting;

    通过error_reporting()函数设置


    0赞 · 0采集
  • 夏日柠檬tea 2019-02-28

    display_errors指定程序运行时现不显示错误

    error_reporting指定错误级别

    截图
    0赞 · 0采集
  • 夏日柠檬tea 2019-02-27

    PHP中所有的错误级别

    截图
    0赞 · 0采集
  • qq_J_116 2019-02-25

    php配置文件中与错误相关选项

    截图
    0赞 · 0采集
  • qq_J_116 2019-02-25

    php中年的错误级别(致命错误)

    截图
    0赞 · 0采集
  • qq_J_116 2019-02-25

    php中的错误级别

    截图
    0赞 · 0采集
  • 唐成勇 2018-04-14

    笔记:自定义异常处理器

    0赞 · 0采集
  • 唐成勇 2018-04-14

    笔记:自定义异常类

    0赞 · 0采集
  • 唐成勇 2018-04-14

    笔记:PHP中的异常简介及使用

    0赞 · 0采集
  • 唐成勇 2018-04-14
    /**
     * 方式二:自定义异常类
     * Class ErrorToException
     */
    //显示所有的错误
    error_reporting(-1);
    class ErrorToException extends Exception{
        public static function handle($errno,$errstr)
        {
            throw new self($errstr,0);
        }
    }
    
    set_error_handler(array('ErrorToException','handle'));
    set_error_handler(array('ErrorToException','handle'),E_USER_WARNING|E_WARNING);
    
    try{
        echo $test;//notice,不会被处理
        echo gettype();//warning
        //手动触发错误
        trigger_error('test',E_USER_WARNING);
    }catch (Exception $exception){
        echo $exception->getMessage();
    }


    0赞 · 0采集
  • 唐成勇 2018-04-14
    /**
     * 方式一:ErrorException错误异常类
     * @param $errno
     * @param $errstr
     * @param $errfile
     * @param $errline
     * @throws ErrorException
     */
    function exception_error_handler($errno,$errstr,$errfile,$errline){
    
        throw new ErrorException($errstr,0,$errno,$errfile,$errline);
    }
    
    set_error_handler('exception_error_handler');
    
    try{
        echo gettype();
    }catch (Exception $exception){
        echo $exception->getMessage();
    }


    0赞 · 0采集
  • 唐成勇 2018-04-14
    /**
     * 自定义异常类处理器
     * Class ExceptionHandler
     */
    
    class ExceptionHandler
    {
     protected $_exception;
     protected $_logFile = __DIR__.'/exception_handle.log';
     public function __construct(Exception $e)
        {
     $this->_exception = $e;
     }
     public static function handle(Exception $e)
        {
     $self = new self($e);
     $self->log();
     echo $self;
     }
     public function log()
        {
            error_log($this->_exception->getMessage().PHP_EOL,3,$this->_logFile);
     }
    
     /**
         * 魔术方法__toString()
         * 快速获取对象的字符串信息的便捷方式,直接输出对象引用时自动调用的方法。
     * @return string
         */
     public function __toString()
        {
     $message = <<<EOF
            <!DOCTYPE html>
            <html>
            <head>
                <meta charset="UTF-8">
                <title>Title</title>
            </head>
            <body>
                <h1>出现异常了啊啊啊啊</h1>
            </body>
            </html>
    EOF;
     return $message;
     }
    
    }
    set_exception_handler(array('ExceptionHandler','handle'));
    /**
     * try catch不会被自定义异常处理!!!!
     */
    try{
     throw new Exception('this is a test');
    }catch (Exception $exception) {
     echo $exception->getMessage();
    }
    throw new Exception('测试自定义的异常处理器');


    0赞 · 1采集
  • 唐成勇 2018-04-14
    /**
     * 自定义异常函数处理器
     */
    header('content-type:text/html;charset=utf-8');
    function exceptionHandler_1($e)
    {
        echo '自定义异常处理器1<br/>函数名:'.__FUNCTION__.PHP_EOL;
        echo '异常信息:'.$e->getMessage();
    }
    function exceptionHandler_2($e)
    {
        echo '自定义异常处理器2<br/>函数名:'.__FUNCTION__.PHP_EOL;
        echo '异常信息:'.$e->getMessage();
    }
    
    set_exception_handler('exceptionHandler_1');
    //set_exception_handler('exceptionHandler_2');
    //恢复到上一次定义过的异常处理函数,即exceptionHandler_1
    //restore_exception_handler();
    //致命错误信息
    //restore_exception_handler();
    throw new Exception('测试自定义异常处理器');
    
    //自定义异常处理器,不会向下继续执行;异常被捕获之后,会继续执行
    //回顾:自定义错误处理器会继续执行代码,而手动抛出的错误信息不会继续执行
    echo 'test';


    0赞 · 0采集
  • 唐成勇 2018-04-14
    header('content-type:text/html;charset=utf-8');
    require_once 'Exception_Observer.php';
    require_once 'Logging_Exception_Observer.php';
    require_once 'Observable_Exception.php';
    
    Observable_Exception::attach(new Logging_Exception_Observer());
    //Observable_Exception::attach(new Logging_Exception_Observer('test.log'));
    
    class MyException extends Observable_Exception{
        public function test1()
        {
            echo 'this is a test';
        }
    }
    
    try{
        throw new MyException('出现了异常!');
    }catch (MyException $exception){
        echo $exception->getMessage();
    }


    0赞 · 0采集
  • 唐成勇 2018-04-13
    /**
     * 给观察者定义规范
     *
     * Interface Exception_Observer
     */
    interface Exception_Observer
    {
        public function update(Observable_Exception $e);
    }
    
    
    /**
     * 定义观察者
     * Class Observable_Exception
     */
    class Observable_Exception extends Exception
    {
        //保存观察者信息
        public static $_observers = array();
        public static function attach(Exception_Observer $observer)
        {
            self::$_observers[] = $observer;
        }
        public function __construct($message = "", $code = 0, Throwable $previous = null)
        {
            parent::__construct($message, $code, $previous);
            $this->notify();
        }
        public function notify()
        {
            foreach (self::$_observers as $observer) {
                $observer->update($this);
            }
        }
    }
    
    /**
     * 记录错误日志
     */
    class Logging_Exception_Observer implements Exception_Observer
    {
        protected $_filename = __DIR__.'/error_observer.log';
        public function __construct($filename = null)
        {
            if ($filename!==null && is_string($filename)){
                $this->_filename = $filename;
            }
        }
    
        public function update(Observable_Exception $e)
        {
            $message = "时间:".date('Y:m:d H:i:s',time()).PHP_EOL;
            $message.= "信息:".$e->getMessage().PHP_EOL;
            $message.= "追踪信息:".$e->getTraceAsString().PHP_EOL;
            $message.= "文件:".$e->getFile().PHP_EOL;
            $message.= "行号:".$e->getLine().PHP_EOL;
            error_log($message,3,$this->_filename);//写到日志中
        }
    }
    
    /**
     * 测试
     */
    header('content-type:text/html;charset=utf-8');
    require_once 'Exception_Observer.php';
    require_once 'Logging_Exception_Observer.php';
    require_once 'Observable_Exception.php';
    
    Observable_Exception::attach(new Logging_Exception_Observer());
    
    class MyException extends Observable_Exception{
        public function test1()
        {
            echo 'this is a test';
        }
    }
    
    try{
        throw new MyException('出现了异常!');
    }catch (MyException $exception){
        echo $exception->getMessage();
    }


    1赞 · 1采集
  • 唐成勇 2018-04-09
    try
    {
        // 需要进行异常处理的代码段;
        throw 语句抛出异常;
    }catch( Exception $e )
    {
        ... 
    }
    catch( Exception $e )
    {
        // 处理异常
    }
    contine.....
    
    //未被捕获
        Fatal error:Uncaught exception.....

    什么时异常?异常和错误有什么区别?

    异常:程序运行与预期不太一致,与错误是两个不同的概念


    0赞 · 0采集
  • 唐成勇 2018-04-09

    1. 什么时异常?异常和错误有什么区别?

    2. 异常的基本语法结构

    3. 如何自定义异常类

    4. 如何自定义异常处理器

    5. 如何像处理异常一样处理PHP的错误

    6. 在发生错误的时候将用户重定向到另一个页面


    0赞 · 0采集
  • 唐成勇 2018-04-09

    https://segmentfault.com/a/1190000014254189#articleHeader12

    0赞 · 0采集
  • 唐成勇 2018-04-09

    笔记链接:处理PHP中的错误

    0赞 · 0采集
  • 唐成勇 2018-04-09

    https://segmentfault.com/a/1190000014254189#articleHeader3

    0赞 · 0采集
数据加载中...
开始学习 免费