侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

php 自定义错误日志实例详解

php  /  管理员 发布于 7年前   144

php 自定义错误日志

 项目中需要对定义错误日志及时处理, 那么就需要修改自定义错误日志的输出方式(写日志、发邮件、发短信)

  一. register_shutdown_function(array('phperror','shutdown_function')); //定义PHP程序执行完成后执行的函数

    函数可实现当程序执行完成后执行的函数,其功能为可实现程序执行完成的后续操作。程序在运行的时候可能存在执行超时,或强制关闭等情况,但这种情况下默认的提示是非常不友好的,如果使用register_shutdown_function()函数捕获异常,就能提供更加友  好的错误展示方式,同时可以实现一些功能的后续操作,如执行完成后的临时数据清理,包括临时文件等。

 可以这样理解调用条件:

    1、当页面被用户强制停止时
    2、当程序代码运行超时时
    3、当PHP代码执行完成时,代码执行存在异常和错误、警告

  二. set_error_handler(array('phperror','error_handler')); // 设置一个用户定义的错误处理函数

    通过 set_error_handler() 函数设置用户自定义的错误处理程序,然后触发错误(通过 trigger_error()):

 三. set_exception_handler(array('phperror','appException')); //自定义异常处理

    定义异常抛出的数据格式。

class phperror{    //自定义错误输出方法  public static function error_handler($errno, $errstr, $errfile, $errline){    $errtype = self::parse_errortype($errno);    $ip = $_SERVER['REMOTE_ADDR'];//这里简单的获取客户端IP    //错误提示格式自定义    $msg = date('Y-m-d H:i:s')." [$ip] [$errno] [-] [$errtype] [application] {$errstr} in {$errfile}:{$errline}";    //自定义日志文件的路径    $logPath = 'logs/app.log';    //写操作,注意文件大小等控制    file_put_contents($logPath, $msg, FILE_APPEND);  }  //系统运行中的错误输出方法  public static function shutdown_function(){    $lasterror = error_get_last();//shutdown只能抓到最后的错误,trace无法获取    $errtype = self::parse_errortype($lasterror['type']);    $ip = $_SERVER['REMOTE_ADDR'];//这里简单的获取客户端IP    //错误提示格式自定义    $msg = date('Y-m-d H:i:s')." [$ip] [{$lasterror['type']}] [-] [$errtype] [application] {$lasterror['message']} in {$file}:{$lasterror['line']}";    //自定义日志文件的路径    $logPath = 'logs/app.log';    //写操作,注意文件大小等控制    file_put_contents($logPath, $msg,FILE_APPEND);  } //自定义异常输出  public static function appException($exception) {    echo " exception: " , $exception->getMessage(), "/n";   }   private static function parse_errortype($type){    switch($type){      case E_ERROR: // 1         return 'Fatal Error';      case E_WARNING: // 2         return 'Warning';      case E_PARSE: // 4         return 'Parse error';      case E_NOTICE: // 8         return 'Notice';      case E_CORE_ERROR: // 16         return 'Core error';      case E_CORE_WARNING: // 32         return 'Core warning';      case E_COMPILE_ERROR: // 64         return 'Compile error';      case E_COMPILE_WARNING: // 128         return 'Compile warning';      case E_USER_ERROR: // 256         return 'User error';      case E_USER_WARNING: // 512         return 'User warning';      case E_USER_NOTICE: // 1024         return 'User notice';      case E_STRICT: // 2048 //        return 'Strict Notice';      case E_RECOVERABLE_ERROR: // 4096         return 'Recoverable Error';      case E_DEPRECATED: // 8192         return 'Deprecated';      case E_USER_DEPRECATED: // 16384         return 'User deprecated';    }    return $type;  }  }

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

您可能感兴趣的文章:

  • 浅谈php自定义错误日志
  • PHP防止图片盗用(盗链)的方法小结
  • PHP数据的提交与过滤基本操作实例详解
  • thinkPHP多语言切换设置方法详解
  • php使用高斯算法实现图片的模糊处理功能示例
  • PHP实现的方程求解示例分析
  • php5.3后静态绑定用法详解
  • php基于curl实现的股票信息查询类实例
  • PHP中STDCLASS用法实例分析
  • php遍历替换目录下文件指定内容的方法
  • php实现有序数组打印或排序的方法【附Python、C及Go语言实现代码】


  • 上一条:
    php获取flash尺寸详细数据的方法
    下一条:
    PHP上传图片、删除图片简单实例
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客