首页 > 作文

为你的 Laravel 验证器加上多验证场景的实现

更新时间:2023-04-08 16:53:08 阅读: 评论:0

前言

在我们使用 laravel 框架的验证器,有的时候需要对表单等进行数据验证,当然 laravel 也为我们提供了
illuminate\http\request 对象提供的 validate 方法 以及 formrequest 和 validator。

formrequest 通过新建文件将我们的验证部分单独分开,来避免控制器臃肿。如果验证失败,就会生成一个让用户返回到先前的位置的重定向响应。这些错误也会被闪存到 ssion 中,以便这些错误都可以在页面中显示出来。如果传入的请求是 ajax,会向用户返回具有 422 状态代码和验证错误信息的 json 数据的 http 响应。如果是接口请求或 ajax, 那么我们可能还需要将返回的 json 数据修改成我们想要的格式。

当我们实际开发中,可能一个模块需要有多个验证场景,如果为每一个验证场景都新建一个 formrequest 不就太过繁琐了。
那么给 laravel 加上一个验证场景通过一个验证类一个模块或多个模块来适应不同的场景不就方便很多了。

开始

首先 我们封装了一个基类 bavalidate.php 并将其放在 app\validate 下,当然你也可以放在其他地方,只要修改好命名空间就好。

<?phpnamespace app\validate;u illuminate\support\facades\validator;/** * 扩展验证器 */class bavalidate {  /**   * 当前验证规则   * @var array   */  protected $rule = [];  /**   * 验证提示信息   * @var array   */  protected $message = [];  /**   * 验证场景定义   * @var array   */  protected $scene = [];  /**   * 设置当前验证场景   * @var array   */  protected $currentscene = null;  /**   * 验证失败错误信息   * @var array   */  protected $error = [];  /**   * 场景需要验证的规则   * @var array   */  protected $only = [];  /**   * 设置验证场景   * @access public   * @param string $name 场景名   * @return $this   */  public function scene($name)  {    // 设置当前场景    $this->currentscene = $name;    return $this;  }  /**   * 数据验证   * @access public   * @param array   $data 数据   * @param mixed   $rules 验证规则   * @param array  $message 自定义验证信息   * @param string  $scene 验证场景   * @return bool   */  public function check($data, $rules = [], $message = [],$scene = '')  {    $this->error =[];    if (empty($rules)) {      //读取验证规则      $rules = $this->rule;    }    if (empty($message)) {      $message = $this->message;    }    //读取场景    if (!$this->getscene($scene)) {      return fal;    }    //如果场景需要验证的规则不为空    if (!empty($this->only)) {      $new_rules = [];      foreach ($this->only as $key => $value) {        if (array_key_exists($value,$rules)) {          $new_rules[$value] = $rules[$value];        }        }      $rules = $new_rules;    }    // var_dump($rules);die;    $validator = validator::make($data,$rules,$message);    //验证失败    if ($validator->fails()) {      $this->error = $validator->errors()->first();      return fal;    }    return !北京小学择校费empty($this->error) ? fal : true;  }  /**   * 获取数据验证的场景   * @access protected   * @param string $scene 验证场景   * @return void   */  protected function getscene($scene = '')  {    if (empty($scene)大数据技术有哪些) {      // 读取指定场景      $scene = $this->currentscene;    }    $this->only = [];    if (empty($scene)) {      return true;    }    if (!ist($this->scene[$scene])) {      //指定场景未找到写入error      $this->error = "scene:".$scene.'is not found';      return fal;    }    // 如果设置了验证适用场景    $scene = $this->scene[$scene];    if (is_string($scene)) {      $scene = explode(',', $scene);    }    //将场景需要验证的字段填充入only    $this->only = $scene;    return true;  }  // 获取错误信息  public function geterror()  {    return $this->error;  } }

使用

接下来我们来验证一个文章的提交信息,首先我们新建一个文章验证类 articlevalidate.php 并填充一些内容

<?phpnamespace app\validate;u app\validate\bavalidate;/** * 文章验证器 */class articlevalidate extends bavalidate {  //验证规则  protected $rule =[    'id'=>'required',    'title' => 'required|max:255',    'content' => 'required',  ];  //自定义验证信息  protected $message = [    'id.required'=>'缺少文章id',    'title.required'=>'请输入title',    'title.max'=>'title长度不能大于 255',    'content.required'=>'请输入内容',  ];  //自定义场景  protected $scene = [    'add'=>"title,content",    'edit'=>素数是什么; ['id','title','content'],  ];}

如上所示,在这个类中我们定义了验证规则 rule,自定义验证信息 message,以及验证场景 scene

非场景验证

我们只需要定义好规则

public function update(){    $articlevalidate = new articlevalidate;    $request_data = [      'id'=>'1',      'title'=>'我是文章的标题',      'content'=>'我是文章的内容',    ];    if (!$articlevalidate->check($request_data)) {      var_dump($articlevalidate->geterror());    }  }

check 方法中总共有四个参数,第一个要验证的数据,第二个验证规则,第三个自定义错误信息,第四个验证场景,其中 2,3,4 非必传。
如果验证未通过我们调用 geterror() 方法来输出错误信息,geterror()暂不支持返回所有验证错误信息 。

场景验证

我们需要提前在验证类中定义好验证场景

如下,支持使用字符串或数组,使用字符串时,要验证的字段需用 , 隔开

//自定义场景  protected $scene = [    'add'=>"title,content",    'edit'=> ['id郭沫若代表作','title','content'],  ];

然后在我们的控制器进行数据验证

public function add(){    $articlevalidate = new articlevalidate;    $request_data = [      'title'=>'我是文章的标题',      'content'=>'我是文章的内容'汽车服务专业,    ];    if (!$articlevalidate->scene('add')->check($request_data)) {      var_dump($articlevalidate->geterror());    }  }

控制器内验证

当然我们也允许你不创建验证类来验证数据,

public function add(){    $validate = new bavalidate;    $request_data = [      'title'=>'我是文章的标题',      'content'=>'我是文章的内容',    ];    $rule =[      'id'=>'required',      'title' => 'required|max:255',      'content' => 'required',    ];    //自定义验证信息    $message = [      'id.required'=>'缺少文章id',      'title.required'=>'请输入title',      'title.max'=>'title长度不能大于 255',      'content.required'=>'请输入内容',    ];    if (!$validate->check($request_data,$rule,$message)) {      var_dump($validate->geterror());    }  }

通过验证场景,既减少了控制器代码的臃肿,又减少了 formrequest 文件过多,还可以自定义 json 数据是不是方便多了呢,

参考文档

laravel 表单验证 :表单验证《laravel 5.5 中文文档》
thinkphp 验证场景 :

到此这篇关于为你的 laravel 验证器加上多验证场景的实现的文章就介绍到这了,更多相关laravel 验证器内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文为杨攀遥原创文章,如若转载,无需和我联系,但请注明出处 [杨攀遥的博客]:https://www.yangpanyao.com/archives/120.html

本文发布于:2023-04-08 16:53:06,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/855f576f5472727eff13919f8361d173.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:为你的 Laravel 验证器加上多验证场景的实现.doc

本文 PDF 下载地址:为你的 Laravel 验证器加上多验证场景的实现.pdf

下一篇:返回列表
标签:场景   我是   自定义   文章
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图