zoukankan      html  css  js  c++  java
  • tp5 ThinkPhp5 自定义异常处理类

    在项目的开发过程中异常抛出尤为重要不仅能够做出友好提示帮助掩盖我们伟大的程序员们尴尬的瞬间,还能做到提示开发人员代码白编写的错误,下面进行自定义异常抛出类,纯属个人理解,希望大家指正

    首先在框架中我们可以自定义目录结构用来做异常类的存储位置例如文件目录为以下红框中

    定义目录结构后阐述一下我理解的异常类的工作流程,见名知意既然是异常抛出那么只有在代码出现问题的时候或者是逻辑出现异常的时候会进行抛出,那么我认为这就会出现两种情况,

    第一种是用户传输的参数或者用户操作的流程有问题这种情况下并不是我们的开发的代码或者是业务逻辑出现的致命错误,直白的将这种情况就是用户的请求没有返回相应的数据

    第二种是我们的代码存在问题,或者是服务器上面的问题,但是这个问题我们是不需要用户知道的,在这种情况下我们即需要给出用户的友好提示,还需要知道我们的代码具体是哪里出现了问题所以这种情况下我们就需要记录日志

    分析了两种情况之后首先创建应对第一种情况的类,命名为BaseException.php在这个类中需要定义的很简单就是对应第一种情况的友好信息

    信息中包括的是抛出异常的http状态码、异常的信息、自定义异常的状态码(可选)

    但是BaseException.php需要继承Exception虽然我们是自己定义的异常类但是还是需要遵循规律,既然要抛出异常,就需要有捕获异常,BaseException.php代码如下

    下面看一下官方手册

    很明显官方已经指出我们接下来要做的

    定义Z_Exception.php用来继承Handle类并且重写render方法,这样我们就可以将我们自定义的信息进行抛出,并且在这个类中穿插判断用来应对第二种异常的情况

    至此存在一个值得注意的问题在config.php中的问题

    本身此处为空但我们已经自己定义了异常类,如果没有更改的话会导致致命错误这里大家应该值得注意一下

    处理之后继续下一步添加日志

    通过入口文见index.php可以追踪到框架的核心文件start.php打开之后看到加载base.php然后打开base.php就可以看到文件的配置项找到log查看文件的路径

    由此可以定位到log文件的路径

    由此我们更改一下log的路径方便我们以后管理,在index.php中重新定义LOG_PATH的路径

    更改文件的路径后我们应该将框架中默认的记录日志的方式进行更改可以参考官方的文档

    https://www.kancloud.cn/manual/thinkphp5/118126

    更改框架中的日志的记录方式就是在config.php查找Log模块,将日志的type由File更改为test

    既然日志是为了应对生产环境下的问题那么我在代码编写的时候就应该在

    之后进行日志的记录,但是要是进行日志的记录我们就应该使用框架中的Log类

    在Z_Exception.php中定义方法用来写入日志

    然后再调用

    这样就完成了自定义的类和自定义的日志文件

    以上纯属个人理解,不足之处望大家见谅!!!!

  • 相关阅读:
    【Java并发基础】安全性、活跃性与性能问题
    【Java并发基础】使用“等待—通知”机制优化死锁中占用且等待解决方案
    【NS-3学习】ns3-模拟基础:关键概念,日志,命令行参数
    【Java并发基础】死锁
    【Java并发基础】加锁机制解决原子性问题
    【Java并发基础】Java内存模型解决有序性和可见性问题
    【Java并发基础】并发编程bug源头:可见性、原子性和有序性
    【NS-3学习】ns-3模拟基础:目录结构,模块,仿真流程
    TCP和UDP的优缺点及区别
    七层协议与网络配置
  • 原文地址:https://www.cnblogs.com/mzli/p/7374306.html
Copyright © 2011-2022 走看看