TP6.0 自定义异常处理类
1. 拷贝框架自带的 应用异常处理类
, 另存一份
复制 app/ExceptionHandle.php
, 另存为 app/ApiExceptionHandle.php
在 ApiExceptionHandle.php
中的 render()
方法中 自定义异常处理机制
public function render($request, Throwable $e): Response
{
// 添加自定义异常处理机制
if (app('http')->getName() === 'api') {
// http请求异常处理
if ($e instanceof HttpException) {
return $this->json($e->getMessage(), $e->getStatusCode());
}
// 无效参数异常
if ($e instanceof \InvalidArgumentException) {
return $this->json($e->getMessage());
}
// 验证器异常处理机制
if ($e instanceof ValidateException) {
fault($e->getMessage());
}
// 其他异常处理(不是自己手动抛出的异常)
if (!empty($e->getMessage())) {
return $this->json($e->getMessage(), $e->getCode());
}
}
// 其他错误交给系统处理
return parent::render($request, $e);
}
/**
* 返回json数据
*
* @param string $msg 描述信息
* @param integer $code 状态码
*/
private function json(string $msg, int $code = 201)
{
return json(compact('code', 'msg'));
}
自定义异常类可放在全局容器Provider定义文件, 也可放在应用目录下
全局容器Provider定义文件: app/provider.php
应用容器Provider定义文件: app/index/provider.php
<?php
// 容器Provider定义文件
return [
// 自定义异常处理
'think\exception\Handle' => app\ApiExceptionHandle::class,
];
2. 自定义抛出异常的函数
/**
* 抛出错误
*
* @param string $msg
* @param integer $code
*/
function fault(string $msg = "", int $code = 201)
{
throw new \Exception($msg, $code);
}
本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!
从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!
本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。
本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。
若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。