在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
简介数据的验证(validation)是经常用的一个操作,通常是使用正则表达式的方式进行验证。但是,“当你尝试使用正则表达式解决一个问题时候,那么,现在你有两个问题了。”
PHP在5.2.0以后内置了一个filter 扩展可以用于数据的过滤和净化,这个内置扩展的最大问题是功能太弱,能验证的东西太少。基本上就是验证一下ip url 邮件地址,别的就没有了,简单用用还是可以可以的,复杂的功能就别指望了。
这里将要介绍的respect/validation是一个PHP的验证库,在github和composer的packagist上都是同类中星星最多的。 特点: 1 使用简单,支持链式操作,可以组合不同的验证规则,支持对对象、数组等组合数据形式的验证。 2 内容丰富,可以验证的数据类型非常多,包含了大部分的常见验证:
安装Composer 安装respect/validation 已经提交到Packagist,可以直接使用composer下载: composer require respect/validation Packagist国内慢的几乎不能用,可以换一个镜像或者搭高速 梯@@子 。 基本使用Helloword创建一个验证类的实例,然后调用validate方法,validate方法返回true或者false。 验证数字: use Respect\Validation\Validator as v; $number = 123;v::numeric()->validate($number); //true 链式验证(awesome)最方便强大的feature就是链式的验证操作:
验证日期处于某个范围内 v::date('Y-m-d')->between('1980-02-02', 'now')->validate('1988-08-08'); Date 和 between 是不同的rule,第一个date('Y-m-d')负责验证日期格式正确,后面的between负责验证在区间内。
验证一个不包含空格,长度在1-15之间的字符串: $usernameValidator = v::alnum()->noWhitespace()->length(1,15); $usernameValidator->validate('alganet'); //true
等等。
Input optional
注意,默认情况下,除非文档特别说明,验证函数默认参数是可选的,所以空输入都会得到true的验证结果。可以使用notEmpty()来禁止这个行为。验证字符串不为空: v::alnum()->notEmpty()->validate(''); //false
实际上在这里你可能需要更加的小心的验证,例如domain这个rule,就不符合: v::domain()->validate(''); //true 上面的验证结果会是true,而不是false。 规则反转v::not(v::int())->validate(10); //false, input must not be integer
获取验证失败信息验证一共有3个可用的函数validate,assert,check,validate返回true或者false,assert和check则能够抛出异常,异常信息中携带具体的错误信息。 如果验证通过,assert函数返回true,验证不通过则抛出异常。 具体使用参考文档。 参考1 Github:Respect/Validation 2 官网:http://respect.li/Validation/ |
2022-08-18
2022-08-17
2022-11-06
2022-08-17
2022-07-29
请发表评论