前言
Laravel提供了多种方法来验证应用输入数据。默认情况下,Laravel的控制器基类使用ValidatesRequests trait,该trait提供了便利的方法通过各种功能强大的验证规则来验证输入的HTTP请求。
Laravel中通过ValidatesRequests这个trait来验证requests非常的方便,并且在BaseController类中它被自动的引入了。 exitsts()和unique()这两个规则非常的强大和便利。
它们在使用的过程中需要对数据库中已有的数据进行验证,通常它们会像下面这样来写:
// exists example email = exists:staff,account_id,1 // unique example email = unique:users,email_address,$user- id,id,account_id,1
上面这种写法的语法很难记,我们几乎每次使用时,都不得不去查询一下文档。但是从 Laravel 的5.3.18版本开始这两个验证规则都可以通过一个新的Rule类来简化。
我们现在可以使用下面这样的熟悉的链式语法来达到相同的效果:
email = [ required , Rule::exists( staff )- where(function ($query) { $query- where( account_id , 1);],
email = [ required , Rule::unique( users )- ignore($user- id)- where(function ($query) { $query- where( account_id , 1);],
这两个验证规则还都支持下面的链式方法:
where
whereNot
whereNull
whereNotNull
unique验证规则除此之外还支持ignore方法,这样在验证的时候可以忽略特定的数据。
好消息是现在仍然完全支持旧的写法,并且新的写法实际上就是通过formatWheres方法在底层将它转换成了旧的写法:
protected function formatWheres() return collect($this- wheres)- map(function ($where) { return $where[ column ]. , .$where[ html' target='_blank'>value })- implode( , }
相关推荐:
php 判断IP为有效IP地址的方法php实例
php实现的AES加密类定义与用法示例php技巧
PHP实现的防止跨站和xss攻击代码php技巧
以上就是Laravel中unique和exists验证规则的优化详解php实例的详细内容,PHP教程
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
新闻热点
疑难解答