Laravel+Dingo/Api 自定义响应的实现
在最近的开发开发项目中,我使用了Dingo/Api这个第三方Api库。
Dingo是个很强大的Api库, 但在开发的过程中,需要自定义响应字段。
刚开始使用Ding/Api时,返回如下:
{ "message": "422 Unprocessable Entity", "errors": { "mobile": [ "手机号格式不正确" ] }, "status_code": 422 }
这是输入字段验证错误时,Dingo返回的结果。
这样看上去没什么问题。因为这边 status_code 是比较规范的。对于 PHP 来说,直接 json_decode 之后,并没有什么难办的地方。但是对面安卓和 IOS 则是使用的强类型语言。尤其是 Java,需要对每一个 Json 对象进行新建,然后序列化。所以,这种格式不统一的返回结果,是无法接受的
解决方法: 我们需要将所有的异常信息归总到一个地方,在AppServiceProvider的boot()方法中添加
// 将所有的 Exception 全部交给 App\Exceptions\Handler 来处理 app('api.exception')->register(function (Exception $exception) { $request = Illuminate\Http\Request::capture(); return app('App\Exceptions\Handler')->render($request, $exception); });
然后在App\Exceptions\Handler.php中的render()方法中:
$class = get_class($exception); switch ($class) { case 'Dingo\Api\Exception\ValidationHttpException': if ($request->expectsJson()) return $this->errorRespond($exception->getErrors()->first(), $exception->getStatusCode()); break; default: if ($request->expectsJson()) return $this->errorRespond('系统休息了', 500000); break; }
再次访问接口:
{ "response_status_code": 422, "response_message": "请填写手机号", "data": [] }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- laravel框架中表单请求类型和CSRF防护实例分析
- Laravel 解决419错误 -ajax请求错误的问题(CSRF验证)
- 对laravel的csrf 防御机制详解,及form中csrf_token()的存在介绍
- laravel 实现关闭CSRF(全部关闭、部分关闭)
- laravel csrf排除路由,禁止,关闭指定路由的例子
- Laravel框架中VerifyCsrfToken报错问题的解决
- 在 Laravel 中动态隐藏 API 字段的方法
- laravel框架 api自定义全局异常处理方法
- 让Laravel API永远返回JSON格式响应的方法示例
- 基于laravel制作APP接口(API)
- Laravel5.3+框架定义API路径取消CSRF保护方法详解
相关文章
Python干货实战之逆向登录世界上最大的游戏平台Stream
有些网页中的数据进行了算法加密 这些算法代码是JavaScript 加密的地方就是在js文件里,我们需要破解这些算法加密 就需要了解这加密的过程 获取加密过程中的代码 然后进行后续的反反爬虫操作2021-10-10pytho matplotlib工具栏源码探析一之禁用工具栏、默认工具栏和工具栏管理器三种模式的差异
这篇文章主要介绍了pytho matplotlib工具栏源码探析一之禁用工具栏、默认工具栏和工具栏管理器三种模式的差异,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-02-02python使用matplotlib绘制图片时x轴的刻度处理
在使用matplotlib绘制图片时,x轴的刻度可能比较密集,特别是以日期作为x轴时,则最后会显示不出来。这篇文章主要介绍了python使用matplotlib绘制图片时x轴的刻度处理,需要的朋友可以参考下2021-08-08
最新评论