• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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操作示例
    上一篇:Yii2框架实现登录、退出及自动登录功能的方法详解
    下一篇:OAuth认证协议中的HMACSHA1加密算法(实例)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Laravel学习教程之request validation的编写 Laravel,学习教程,之,request,