TP5接口开发之异常处理接管
前几天在开发的时候用到了第三方的扩展包,使用过程中第三方扩展包抛出了异常
因为这边是接口开发,需要返回错误代码以及提示信息等,所以就需要接管异常处理。
此文章只做笔记,有不对或不详细的地方欢迎大家留言交流。
首先先在application下创建目录exception
然后创建BaseException类,此类为自定义异常类基类,继承框架异常类或php异常类都可。
<?php /** * BaseException.php * 文件描述:自定义异常类基类,继承框架异常类 */ namespace app\common\exception; use think\Exception; use Throwable; /** * Class BaseException * 自定义异常类的基类 * @package app\common\exception */ class BaseException extends Exception { public function __construct($message = "", $code = 0, Throwable $previous = null) { parent::__construct($message, $code, $previous); } }
这里重写父类的构造方法,然后调用父类的构造方法,这块我看的有点迷,欢迎大家留言分享。
手册上写了,框架支持异常页面由开发者自定义类进行处理,需要配置参数exception_handle
// 异常处理handle类 留空使用 \think\exception\Handle 'exception_handle' => '\\app\\common\\exception\\Http',
自定义类需要继承Handle
并且实现render
方法,手册参考:https://www.kancloud.cn/manual/thinkphp5/126075
<?php /** * ExceptionHandler.php * 文件描述:重写后的异常处理类 */ namespace app\common\exception; use DawnApi\exception\UnauthorizedException; use Exception; use think\exception\Handle; use think\Log; class ExceptionHandler extends Handle { private $code;//http状态码 private $msg;//异常消息 private $errorCode;//异常状态码 public function render(Exception $e) { if ($e instanceof BaseException) { //使用instanceof判断异常是否为自定义异常 $this->code = 200; $this->msg = $e->getMessage(); $this->errorCode = $e->getCode(); } elseif ($e instanceof UnauthorizedException) { //使用instanceof判断异常是否为第三方扩展包异常 $this->code =200; $this->errorCode = 401; $this->msg = '授权失败'; } else { //其他异常 $this->errorCode = 10003; $this->msg = '操作失败'; } $this->recordErrorLog($e);//将异常写入日志,方便查看 return json(['code'=>$this->errorCode,'msg'=>$this->msg]); } /** * Notes:将异常写入日志 * @param Exception $e */ private function recordErrorLog(Exception $e) { Log::init([ 'type' => 'File', 'path' => LOG_PATH, 'level' => ['error'], ]); Log::record([ '错误文件' => $e->getFile(), '错误行数' => $e->getLine(), '错误代码' => empty($this->code) ? $e->getCode() : $this->code, '错误消息' => empty($this->message) ? $e->getMessage() : $this->message, ], 'error'); } }
本文来自博客园,作者:郭德纲又打人了嘿,转载请注明原文链接:https://www.cnblogs.com/blibli/p/11168916.html