浅谈laravel数据验证规则和实例
Admin 2021-06-01 群英技术资讯 379 次浏览
本文主要给大家分享的是关于laravel数据验证的内容,下文是小编整理的一些laravel数据验证规则,具有一定的参考借鉴价值,有这个方面学习需要的朋友可以参考学习。
如下所示:
return [ 'accepted' => '必须为yes,on,1,true', 'active_url' => '是否是一个合法的url,基于PHP的checkdnsrr函数,因此也可以用来验证邮箱地址是否存在', 'after:date' => '验证字段必须是给定日期后的值,比如required|date|after:tomorrow,通过PHP函数strtotime来验证', 'after_or_equal:date' => '大于等于', 'alpha' => '验证字段必须全是字母', 'alpha_dash' => '验证字段可能具有字母、数字、破折号、下划线', 'alpha_num' => '验证字段必须全是字母和数字', 'array' => '数组', 'before:date' => '小于', 'before_or_equal:date' => '小于等于', 'between:min,max' => '给定大小在min,max之间,字符串,数字,数组或者文件大小都用size函数评估', 'boolean' => '必须为能转化为布尔值的参数,比如:true,false,1,0,"1","0"', 'confirmed' => '字段必须与foo_confirmation字段值一致,比如,要验证的是password,输入中必须存在匹配的password_confirmation字段', 'date' => '通过strtotime校验的有效日期', 'date_equals:date' => '等于', 'date_format:format' => 'date和date_format不应该同时使用,按指定时间格式传值', 'different:field' => '验证的字段值必须与字段field的值相同', 'digits:value' => '必须是数字,并且有确切的值', 'digits_between:min,max' => '字段长度必须在min,max之间', 'dimensions' => '验证的文件是图片并且图片比例必须符合规则,比如dimensions:min_width=100,min_height=200,可用 的规则有min_width,max_width,min_height,max_height,width,height,ratio', 'distinct' => '无重复值', 'email' => '符合e-mail地址格式', 'exists:table,column' => '必须存在于指定的数据库表中', 'file' => '成功上传的文件', 'filled' => '验证的字段存在时不能为空', 'image' => '验证的文件必须是图像,jpeg,png,bmp,gif,svg', 'in:foo,bar,...' => '验证的字段必须包含在给定的值列表中', 'in_array:anotherfield' => '验证的字段必须存在于另一个字段的值中', 'integer' => '整数', 'ip' => 'ip地址', 'ipv4' => 'ipv4地址', 'ipv6' => 'ipv6地址', 'json' => 'json字符串', 'max:value' => '大于', 'mimetypes:text/plain,...' => '验证的文件必须与给定的MIME类型匹配', 'mimes:foo,bar,...' => '验证的文件必须具有列出的其中一个扩展名对应的MIME类型', 'min:value' => '小于', 'nullable' => '可为null,可以包含空值的字符串和整数', 'not_in:foo,bar...' => '不包含', 'numeric' => '必须为数字', 'present' => '验证的字段必须存在于输入数据中,但可以为空', 'regex:pattern' => '验证的字段必须与给定正则表达式匹配', 'required' => '验证的字段必须存在于输入数据中,但不可以为空', //以下情况视为空:1.该值为null,2.空字符串,3.空数组或空的可数对象,4.没有路径的上传文件 'required_if:anotherfield,value,...' => '如果指定的anotherfield等于value时,被验证的字段必须存在且不为空', 'required_unless:anotherfield,value,...' => '如果指定的anotherfield等于value时,被验证的字段不必存在', 'required_with:foo,bar,...' => '只要指定的其它字段中有任意一个字段存在,被验证的字段就必须存在且不为空', 'required_with_all:foo,bar,...' => '当指定的其它字段必须全部存在时,被验证的字段才必须存在且不为空', 'required_without_all:foo,bar,...' => '当指定的其它字段必须全部不存在时,被验证的字段必须存在且不为空', 'required_without:foo,bar,...' => '当指定的其它字段有一个字段不存在,被验证的字段就必须存在且不为空', 'same:field' => '给定字段必须与验证字段匹配', 'size:value' => '验证字段必须具有与给定值匹配的大小,对字符串,value对应字符数;对数字,对应给定的 整数值;对数组,对应count值;对文件,是文件大小(kb)', 'timezone' => '验证字段是有效的时区标识符,根据PHP函数timezone_identifiers_list判断', 'unique:table,column,except,idColumn' => '验证字段必须是数据库中唯一的', 'url' => '有效的url', ];
简单例子
return [ 'title.required' => 'A title is required', 'body.required' => 'A message is required', 'avatar' => [ 'required', Rule::dimensions()->maxWidth(500)->maxHeight(250)->ratio(3/2), //限制图片大小和比例 ], 'foo.*.id' =>'distinct', //不允许重复 'state' =>'exists:states', //指定表 'state1' => 'exists:states,abbreviation', //指定表和字段 'email' => 'exists:connection.staff,email', //指定查询的数据库 'email1' => [ 'required', Rule::exists('staff')->where(function ($query){ $query->where('account_id',1); }), ], 'zones' => [ 'required', Rule::in(['first-zone','second-zone']), ], 'video' => 'mimetypes:video/avi,video/mpeg,video/quicktime', 'photo' => 'mimes:jpeg,bmp,png', //验证文件扩展名,规则上也会验证文件的MIME类型,通过读取文件的内容以猜测它的MIME类型 'toppings' => [ 'required', Rule::notIn(['sprinkles','cherries']), ], //当使用regex时,必须使用数组,而不是|分隔符,特别是正则中有|时 'email2' => 'unique:users,email_address', 'email3' => 'unique:connection.users,email_address', //指定数据库 'email4' => Rule::unique('users')->where(function ($query){ $query->where('account_id',1); }), 'custom' => [ 'person.*.email' => [ 'unique' => 'each person must have a unique e-mail address', ] ], ];
特殊例子
//验证时忽视id Validator::make($data,[ 'email' => [ 'required', Rule::unique('users')->ignore($user->id,'user_id'), ] ]); //在某些情况下,只有在该字段存在于输入数组中时,才可以对字段执行验证检查 $v = Validator::make($data,[ 'email' => 'sometimes|required|email',//email只有在data数组中时才会被验证 ]); $z = Validator::make($data,[ 'email' => 'required|email', 'games' => 'required|numeric', ]); $z->sometimes('reason','required|max:500',function ($input){ return $input->games >= 100; //当值超过100时,reson才必填 }); $z->sometimes(['reson','cost'],'required',function ($input){ return $input->games >= 100; }); $validator = Validator::make($request->all(),[ 'photos.profile' => 'required|image',//验证数组中的某个key的值 ]); $validator = Validator::make($request->all(),[ 'person.*.email' => 'email|unique:users', 'person.*.first_name' => 'required_with:person.*.last_name', ]);//验证指定数组输入字段中的每一个email都是唯一的 $request->validate([ 'name' => ['required', new Uppercase()], ]); $validator = Validator::make($this->request,[ 'title' => 'required|unique:posts|max:255', 'body' => 'required', ])->validate(); $validator->after(function ($validator){ if ($this->somethingElseIsInvalid()) { $validator->errors()->add('field', 'Something is wrong with this field!'); } }); if ($validator->fails()){ } $errors = $validator->errors(); echo $errors->first('email'); //以数组形式获取指定字段的所有错误消息 foreach ($errors->get('email') as $message){ } //验证表单的数组字段,获取数组元素的所欲错误消息 foreach ($errors->get('attachments.*') as $message){ } //查看所有字段的错误消息 foreach ($errors->all() as $message){ } // 检测一个字段是否有错误消息 if ($errors->has('email')){ }
以上就是关于laravel数据验证规则以及laravel数据验证的实例分享,需要的朋友可以参考上述代码,希望能对大家学习或者工作有帮助。更多laravel数据验证的内容,可以关注其他相关文章哦!
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在之前的文章中给大家带来了《怎么拿捏PHP数组的类型》,这篇文章中详细的介绍了PHP数组的基本定义和数组的基本类型,今天继续来看一下一个比较简单的知识点,PHP数组的排序。
需要队列程序,提供加入队列接口和取队列接口。需要存储队列、文件或数据库。需要定期程序取出队列并执行。其它扩展功能:优先级、日志、定时等。
Swoole4为PHP语言提供了强大的CSP协程编程模式,用户可以通过go函数创建一个协程,以达到并发执行的效果。go()函数用于创建协程;Co::yield()使得当前协程让出CPU;Co::resume()可恢复某个协程执行。
php的自动垃圾回收机制是怎样的呢?这个问题我们先这么想,我们都知道php是C语言实现的。你想想如何用C语言实现对一个变量的统计以及释放。C语言是如何实现一个变量,从声明开始到最后没人用了,就把这个变量所占的内存给释放掉(被垃圾回收)。
这篇文章主要给大家介绍了关于如何破解PHP单继承魔咒的相关资料,Trait 是为类似 php 的单继承语言而准备的一种代码复用机制,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008