Laravel学习教程之request validation的编写
前言
本文主要给大家介绍了关于Laravel之request validation编写的相关内容,在用laravel写api时,当前端传进来的request是POST/PUT/PATH等method时,那需要做request validation,尽管对于前后端分离程序,前端程序Angular/Vue已经做了validation,但是ajax传过来的json input,在后端也需要做validation。
那该如何优雅的编写request validation呢?laravel官方文档已经包含了这个feature: Form Request Validation
实现方法如下
这里可以写一个JsonRequest:
class JsonRequest extends Illuminate\Foundation\Http\FormRequest { public function rules() { $method = $this->method(); assert(in_array($method, [static::METHOD_POST, static::METHOD_PUT, static::METHOD_PATCH], true)); $controller = $this->route()->getController(); $rules = $controller::RULES; return ($rules[$this->method()] ?? []) + ($rules['*'] ?? []); } public function authorize() { return true; } }
这样就可以在众多Model Controller里使用JsonRequest就行,如:
use Illuminate\Http\Request; final class AccountController extends \App\Http\Controllers\Controller { public const RULES = [ Request::METHOD_POST => [ 'bank_account' => 'required_if:type,bank', 'loan_account' => 'required_if:type,loan', ], Request::METHOD_PUT => [ // ... ], '*' => [ // ... ], ]; }
这样就可以校验前端传进来的json input是否合法。
(1)如果前端传进来的json input是:
{ "name": "lx1036", "type": "loan", "bank_account": { "source": "bank", } }
那就validation失败,不合法。
(2) 如果前端传进来的json input是:
{ "name": "lx1036", "type": "bank", "loan_account": { "source": "loan", } }
那就validation失败,不合法。
这样就可以校验json input,不合法就直接弹回throw 一个HttpException,不再用在进入下一步逻辑。对于这样嵌套的json input,使用request validation来校验对象间关系很重要,可以看做是进入核心业务逻辑前的初步校验。。当然最后写表时还有model validation,避免坏数据进入db。
最后一点,laravel文档只是说了用法,没有说明原理。代码在\Illuminate\Foundation\Providers\FormRequestServiceProvider::class:
public function boot() { // \Illuminate\Foundation\Http\FormRequest use 了 ValidatesWhenResolvedTrait,extends 了 \Illuminate\Contracts\Validation\ValidatesWhenResolved $this->app->afterResolving(ValidatesWhenResolved::class, function ($resolved) { $resolved->validate(); }); // ... }
所以当从容器中resolve完\Illuminate\Foundation\Http\FormRequest后就会立即执行\Illuminate\Foundation\Http\FormRequest::validate()方法,具体不详述,可看laravel源码。
OK,总之,在写程序时,validation很重要,需要去写,包括request validation和model validation。。。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
- 跟我学Laravel之请求(Request)的生命周期
- 三个思路解决laravel上传文件报错:413 Request Entity Too Large问题
- 跟我学Laravel之视图 & Response
- 关于扩展 Laravel 默认 Session 中间件导致的 Session 写入失效问题分析
- Laravel中的Sessionid处理机制详解
- Laravel5.2使用Captcha生成验证码实现登录(session巨坑)
- laravel获取不到session的三种解决办法【推荐】
- Laravel如何使用Redis共享Session
- Laravel 5.4.36中session没有保存成功问题的解决
- Laravel框架Request、Response及Session操作示例
相关文章
Laravel 实现Controller向blade前台模板赋值的四种方式小结
今天小编就为大家分享一篇Laravel 实现Controller向blade前台模板赋值的四种方式小结,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-10-10laravel ORM 只开启created_at的几种方法总结
下面小编就为大家分享一篇laravel ORM 只开启created_at的几种方法总结,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-01-01ThinkPHP水印功能实现修复PNG透明水印并增加JPEG图片质量可调整
这篇文章主要介绍了ThinkPHP水印功能实现修复PNG透明水印并增加JPEG图片质量可调整,包含了对多层水印设置代码的修改,修改的部分在注释里有较为详细的说明,非常具有实用价值,需要的朋友可以参考下2014-11-11
最新评论