thinkphp5.1 中使用自定义异常处理类进行接管

配置文件修改

config/app.php
自定义异常接管类出处
'exception_handle' => ‘\app\common\exception\ExceptionHandle',

自定义处理异常方法
寡人的存放目录为 app/common/exception

ApiException.php

namespace app\common\exception;
use Exception;
class ApiException extends Exception
{
	/**
	 * 构造函数
	 */
	public function __construct(array $ApiErrConst, Throwable $previous = null)
	{
		$code = $ApiErrConst[0];
		$message = $ApiErrConst[1];
		parent::__construct($message, $code, $previous);
	}
}

ExceptionHandle.php

namespace app\common\exception;
use Exception;
use think\exception\Handle;
use app\common\exception\ApiException;
use app\common\err\ApiErrCode;
class ExceptionHandle extends Handle
{
	// 引入复用模块:JSON返回格式
	use \app\common\traits\ResponseJson;
	public function render(Exception $e)
	{
		if($e instanceof ApiException) {
			$code = $e->getCode();
			$message = $e->getMessage();
		}else{
			$code = $e->getCode();
			if(!$code || $code < 0) {
				$code = ApiErrCode::ERROR_UNKNOW[0];
			}
			$message = $e->getMessage() ? $e->getMessage() : ApiErrCode::ERROR_UNKNOW[1];
		}
		echo $this->jsonErrorData($code,$message); //该方法在下方
		// 其他错误交给系统处理
       // return parent::render($e);
	}
}

错误码文件

存放目录:app/common/err

namespace app\common\err;
class ApiErrCode
{
	/**
	 * API通用错误码 const 定义常量
	 * error_code < 1000
	 */
    const ERROR_UNKNOW = [0, "未知错误"];
    const ERROR_URL = [1, "接口不存在"];
    .......
}

复用模块

针对API接口返回格式
存放目录:app/common/traits

namespace app\common\traits;
trait ResponseJson
{
	/**
	 * API接口出现业务异常时时返回
	 * @author Leo
	 */
	public function jsonErrorData($code,$message,$data = [])
	{
		return $this->jsonResponse($code, $message, $data);
	}

	/**
	 * API接口请求成功时返回
	 * @author Leo
	 */
	public function jsonSuccessData($data = [])
	{
		return $this->jsonResponse(200, "Sucess", $data);
	}

	/**
	 * 返回一个JSON
	 * @author Leo
	 */
	private function jsonResponse($code,$message,$data)
	{
		$content = [
			'code' => $code,
			'msg' => $message,
			'data' => $data
		];
		return json_encode($content);
	}
}

页面调用

// 文件头部引入
use app\common\exception\ApiException;
use app\common\err\ApiErrCode;
// 引入复用模块:JSON返回格式
use \app\common\traits\ResponseJson;

// 示例
public function index() {
	throw new ApiException(ApiErrCode::ERROR_URL);		// 自定义异常抛出
}

到此这篇关于thinkphp5.1 中使用自定义异常处理类进行接管的文章就介绍到这了,更多相关thinkphp5.1 自定义异常处理类内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • thinkPHP5.1框架使用SemanticUI实现分页功能示例

    本文实例讲述了thinkPHP5.1框架使用SemanticUI实现分页功能.分享给大家供大家参考,具体如下: 1.config目录下新建paginate.php,下面是文件的内容 <?php //分页配置 return [ 'type' => 'Semantic', 'var_page' => 'page', ]; 2.thinkphp\library\think\paginator\driver\下新建Semantic.php,下面是文件的内容 <?php /** * Crea

  • thinkphp5.1框架中容器(Container)和门面(Facade)的实现方法分析

    本文实例讲述了thinkphp5.1框架中容器(Container)和门面(Facade)的实现方法.分享给大家供大家参考,具体如下: tp5.1中引入了容器(Container)和门面(Facade)这两个新的类 官方文档已经给出了定义: 容器(Container)实现类的统一管理,确保对象实例的唯一性. 门面(Facade)为容器(Container)中的类提供了一个静态调用接口,相比于传统的静态方法调用, 带来了更好的可测试性和扩展性,你可以为任何的非静态类库定义一个facade类. 深入

  • ThinkPHP5.1框架数据库链接和增删改查操作示例

    本文实例讲述了ThinkPHP5.1框架数据库链接和增删改查操作.分享给大家供大家参考,具体如下: 一.数据库的链接方式 <?php namespace app\index\controller; use think\Db; class Demo { //1.全局配置 config/database.php配置 public function dbTest() { return Db::table('pzq_article') ->where('id','29') ->value('ti

  • thinkphp5.1框架实现格式化mysql时间戳为日期的方式小结

    本文实例讲述了thinkphp5.1框架实现格式化mysql时间戳为日期的方式.分享给大家供大家参考,具体如下: 方式一 使用mysql函数FROM_UNIXTIME(unix_timestamp,format)直接转换 select FROM_UNIXTIME(o.create_time,'%Y-%m-%d') create_time from table 方式二 使用模型获取器 withAttr, 在该方法中用date函数格式化 ->field('*') ->withAttr('creat

  • thinkPHP5.1框架中Request类四种调用方式示例

    本文实例讲述了thinkPHP5.1框架中Request类四种调用方式.分享给大家供大家参考,具体如下: 1. 传统调用 访问方式:http://127.0.0.1/demo/demo3/test?name=kk&age=22 <?php /** * Created by PhpStorm. * User: 10475 * Date: 2018/8/27 * Time: 22:59 */ namespace app\demo\controller; use think\Request; cl

  • thinkphp5.1 中使用自定义异常处理类进行接管

    配置文件修改 config/app.php 自定义异常接管类出处 'exception_handle' => '\app\common\exception\ExceptionHandle', 自定义处理异常方法 寡人的存放目录为 app/common/exception ApiException.php namespace app\common\exception; use Exception; class ApiException extends Exception { /** * 构造函数

  • thinkphp5框架实现的自定义扩展类操作示例

    本文实例讲述了thinkphp5框架实现的自定义扩展类操作.分享给大家供大家参考,具体如下: 1.在extend目录下新建要定义的扩展类:如下图所示 2.定义扩展类的内容 <?php namespace org; /** * */ class Auth { public function __construct() { # code... } public function xx() { echo 'xxxxxxxxxxxxxx'; } } 3.在控制器中调用自定义的扩展类 <?php nam

  • python中让自定义的类使用加号"+"

    目录 1.python的魔法方法__add__() 2.对CartoonImage重载“+” 2.1实现CartoonImage类 3.测试“+”是否能实现图像拼接 3.1对CartoonImage对象使用“+”操作 如果代码是“1+1”,那么python控制台必然输出2,这很符合我们对“数值类”的认识,“+”运算符必然能对数值进行加法. 假设自己现在想设计一个称为“动漫图片CartoonImage类”,能不能实现它的对象之间的“+”操作呢?比如想要对两个动漫图像对象cartoon_1和cart

  • 浅谈SpringBoot 中关于自定义异常处理的套路

    在 Spring Boot 项目中 ,异常统一处理,可以使用 Spring 中 @ControllerAdvice 来统一处理,也可以自己来定义异常处理方案.Spring Boot 中,对异常的处理有一些默认的策略,我们分别来看. 默认情况下,Spring Boot 中的异常页面 是这样的: 我们从这个异常提示中,也能看出来,之所以用户看到这个页面,是因为开发者没有明确提供一个 /error 路径,如果开发者提供了 /error 路径 ,这个页面就不会展示出来,不过在 Spring Boot 中

  • SpringMVC 异常处理机制与自定义异常处理方式

    目录 SpringMVC默认处理的几种异常 @ResponseStatus 异常处理的顺序 自定义异常类(SpringMVC的异常处理) ①:自定义异常类 ②:自定义异常处理器 ③:配置我们的异常处理器 本节介绍SpringMVC的异常处理机制 首先介绍SpringMVC默认提供了一些HTTP错误类似码的默认异常处理 如何给一个Controller自定义异常处理 如何为项目做一个全局异常处理 提到异常处理,就不得不提HandlerExceptionResolvers,我们的DispatcherS

  • ThinkPHP5.0框架控制器继承基类和自定义类示例

    本文实例讲述了ThinkPHP5.0框架控制器继承基类和自定义类.分享给大家供大家参考,具体如下: 继承系统控制器基类: <?php namespace app\index\controller; use think\Controller; class Index extends Controller { public function hello() { return 'hello,world'; } } 或者自定义一个基础控制器类Base: <?php namespace app\inde

  • Flask和Django框架中自定义模型类的表名、父类相关问题分析

    本文实例分析了Flask和Django框架中自定义模型类的表名.父类相关问题.分享给大家供大家参考,具体如下: 一. Flask和Django中定义表名(执行迁移后生成)的方式和flask是不同的: 1. Django中表名的定义方式,以代码为例说明 class User(AbstractUser): # 继承自认证系统模型类 """用户模型类""" mobile = modles.CharField(max_length=11, mix_len

  • Java中自定义注解类及使用实例解析

    这篇文章主要介绍了Java中自定义注解类并使用过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 在Java框架中,经常会使用注解,而且还可以省很多事,来了解下自定义注解. 注解是一种能被添加到java代码中的元数据,类.方法.变量.参数和包都可以用注解来修饰.注解对于它所修饰的代码并没有直接的影响 先写一个自己的注解类 @Documented //会被javadoc命令识别 @Retention(RetentionPolicy.RUNTI

  • Android在自定义类中实现自定义监听器方式

    监听器可以说是Android开发中最常用的东西之一.我们通过监听器可以监听对象的各种变化事件,并进行一些需要的处理,相当有用,而且使用起来也很简单.其实,监听器就相当于C++中的回调函数,达到条件就回调执行. 很多时候,我们在自定义控件类中也需要实现一些属性变化的监听器,实现跟原生控件监听器一样的功能.以下分几个步骤说明自定义监听器实现和使用(以自定义类MyClass加载完成监听器为例): 一.自定义监听器的实现: 1. 定义一个加载完成监听接口 //加载监听接口 public static i

  • thinkPHP5项目中实现QQ第三方登录功能

    本文实例讲述了thinkPHP5项目中实现QQ第三方登录功能.分享给大家供大家参考,具体如下: 最近用thinkPHP 5框架做了一个婚纱店的项目,在开发过程中需要用到第三方登录,腾讯官方给的案例是几个文件相互包含实现的,放到tp5里面很悲催的发现在控制器中不能通过include或者require完成预期功能,想要用腾讯官方封的类就必须对其进行修改,修改如下: 1. 找到官方SDK里面的核心文件 框架外使用的时候是include 'qqConnectAPI.php',打开这个文件可以看到它是包含

随机推荐