tp5.1 API 自定义全局异常处理(上)

探讨了在ThinkPHP 5.1框架中,如何针对API接口设计统一的错误返回消息,避免直接返回HTML页面,确保客户端能正确解析错误信息。通过示例展示了错误的复用性差的直白写法,强调了重构代码的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们接着重构 tp5.1 参数校验层的项目进行下面的演示。
现在我们来假设这一种情况,客户端传来了 id 为 50,由于 50 是正整数,所以通过了参数校验,但我们的数据库中没有 id 号为 50 的user,这时候我们就需要进行相应的异常处理。注:在Restful API开发中,查询不到数据也可认为是异常
为了演示,我们手动在User控制器中手动抛出一个异常:

public function getUserById($id)
{
   
   
        (new IDMustBePositiveInt())->
ThinkPHP 6 (TP6) 中,自定义异常处理是一个重要的实践,它允许开发者创建自己的错误和异常处理器,以便更好地控制程序流程和提供更友好的错误信息。以下是TP6中自定义异常处理的基本步骤: 1. **创建异常类**:首先,你需要创建一个继承自`Illuminate\Foundation\Exceptions\Handler`的类,例如`App\Exceptions\CustomExceptionHandler`。在这个类中,你可以定义具体的异常处理逻辑。 ```php namespace App\Exceptions; use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler; use Throwable; class CustomExceptionHandler extends ExceptionHandler { // ... 自定义处理方法 ... public function render($request, Throwable $exception) { return parent::render($request, $exception); } // 添加其他处理方法,如记录日志、返回特定错误页面等 } ``` 2. **注册异常处理类**:在`app/Http/Kernel.php`文件中,你需要将你的自定义异常处理器注册到`$container->resolve('Illuminate\Contracts\Http\Kernel')->setException_handler()`函数里。 ```php protected $exception_handlers = [ // 其他已存在的异常处理... \App\Exceptions\CustomExceptionHandler::class, ]; ``` 3. **异常响应**:在`render`方法中,你可以定制异常的响应格式,比如使用JSON格式返回错误信息,或者渲染特定的视图。 ```php public function render($request, Throwable $exception) { if ($exception instanceof CustomException) { // 对于自定义异常,可以有专门的处理逻辑 return response()->json([ 'message' => $exception->getMessage(), 'code' => $exception->getCode(), ], $exception->getStatusCode()); } // 使用默认的异常处理逻辑 return parent::render($request, $exception); } // ... 其他自定义处理逻辑... ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值