如何使用thinkphp 5内置验证功能及自定义验证方法

<?php
namespace app\admin\validate;

use think\Validate;

class Grade extends Validate
{
    protected $rule = [
        'name'    => 'require|unique:StoreGrade,name|min:5|max:50' ,
        'grade'   => 'array|checkNumber' ,
        'number'  => 'array|checkNumber' ,
        'consume' => 'array|checkNumber' ,
    ];

    protected $message = [
        'name.require' => '名称不得为空' ,
        'name.unique'  => '名称必须唯一' ,
        'name.min'     => '最少5位字符' ,
        'name.max'     => '最多50位字符' ,
    ];

    protected function checkNumber ( $array )
    {
        $error = 0;
        foreach ( $array as $key => $value ) {
            if ( (integer) ( $value ) === 0 ) {
                $error += 1;
            }
        }
        if ( $error > 0 ) {
            return '必须整数';
        } else {
            return true;
        }
    }
}

格式验证类

require

验证某个字段必须,例如:

'name'=>'require'

number 或者 integer

验证某个字段的值是否为数字(采用filter_var验证),例如:

'num'=>'number'

float

验证某个字段的值是否为浮点数字(采用filter_var验证),例如:

'num'=>'float'

boolean

验证某个字段的值是否为布尔值(采用filter_var验证),例如:

'num'=>'boolean'

email

验证某个字段的值是否为email地址(采用filter_var验证),例如:

'email'=>'email'

array

验证某个字段的值是否为数组,例如:

'info'=>'array'

accepted

验证某个字段是否为为 yes, on, 或是 1。这在确认"服务条款"是否同意时很有用,例如:

'accept'=>'accepted'

date

验证值是否为有效的日期,例如:

'date'=>'date'

会对日期值进行strtotime后进行判断。

alpha

验证某个字段的值是否为字母,例如:

'name'=>'alpha'

alphaNum

验证某个字段的值是否为字母和数字,例如:

'name'=>'alphaNum'

alphaDash

验证某个字段的值是否为字母和数字,下划线_及破折号-,例如:

'name'=>'alphaDash'

chs

验证某个字段的值只能是汉字,例如:

'name'=>'chs'

chsAlpha

验证某个字段的值只能是汉字、字母,例如:

'name'=>'chsAlpha'

chsAlphaNum

验证某个字段的值只能是汉字、字母和数字,例如:

'name'=>'chsAlphaNum'

chsDash

验证某个字段的值只能是汉字、字母、数字和下划线_及破折号-,例如:

'name'=>'chsDash'

activeUrl

验证某个字段的值是否为有效的域名或者IP,例如:

'host'=>'activeUrl'

url

验证某个字段的值是否为有效的URL地址(采用filter_var验证),例如:

'url'=>'url'

ip

验证某个字段的值是否为有效的IP地址(采用filter_var验证),例如:

'ip'=>'ip'

支持验证ipv4和ipv6格式的IP地址。

dateFormat:format

验证某个字段的值是否为指定格式的日期,例如:

'create_time'=>'dateFormat:y-m-d'

长度和区间验证类

in

验证某个字段的值是否在某个范围,例如:

'num'=>'in:1,2,3'

notIn

验证某个字段的值不在某个范围,例如:

'num'=>'notIn:1,2,3'

between

验证某个字段的值是否在某个区间,例如:

'num'=>'between:1,10'

notBetween

验证某个字段的值不在某个范围,例如:

'num'=>'notBetween:1,10'

length:num1,num2

验证某个字段的值的长度是否在某个范围,例如:

'name'=>'length:4,25'

或者指定长度

'name'=>'length:4'

如果验证的数据是数组,则判断数组的长度。
如果验证的数据是File对象,则判断文件的大小。

max:number

验证某个字段的值的最大长度,例如:

'name'=>'max:25'

如果验证的数据是数组,则判断数组的长度。
如果验证的数据是File对象,则判断文件的大小。

min:number

验证某个字段的值的最小长度,例如:

'name'=>'min:5'

如果验证的数据是数组,则判断数组的长度。
如果验证的数据是File对象,则判断文件的大小。

after:日期

验证某个字段的值是否在某个日期之后,例如:

'begin_time' => 'after:2016-3-18',

before:日期

验证某个字段的值是否在某个日期之前,例如:

'end_time'   => 'before:2016-10-01',

expire:开始时间,结束时间

验证当前操作(注意不是某个值)是否在某个有效日期之内,例如:

'expire_time'   => 'expire:2016-2-1,2016-10-01',

allowIp:allow1,allow2,...

验证当前请求的IP是否在某个范围,例如:

'name'   => 'allowIp:114.45.4.55',

该规则可以用于某个后台的访问权限

denyIp:allow1,allow2,...

验证当前请求的IP是否禁止访问,例如:

'name'   => 'denyIp:114.45.4.55',

字段比较类

confirm

验证某个字段是否和另外一个字段的值一致,例如:

'repassword'=>'require|confirm:password'

5.0.4+版本开始,增加了字段自动匹配验证规则,如password和password_confirm是自动相互验证的,只需要使用

'password'=>'require|confirm'

会自动验证和password_confirm进行字段比较是否一致,反之亦然。

different

验证某个字段是否和另外一个字段的值不一致,例如:

'name'=>'require|different:account'

eq 或者 = 或者 same

验证是否等于某个值,例如:

'score'=>'eq:100'
'num'=>'=:100'
'num'=>'same:100'

egt 或者 >=

验证是否大于等于某个值,例如:

'score'=>'egt:60'
'num'=>'>=:100'

gt 或者 >

验证是否大于某个值,例如:

'score'=>'gt:60'
'num'=>'>:100'

elt 或者 <=

验证是否小于等于某个值,例如:

'score'=>'elt:100'
'num'=>'<=:100'

lt 或者 <

验证是否小于某个值,例如:

'score'=>'lt:100'
'num'=>'<:100'

验证字段比较支持对比其他字段(V5.0.8+)

验证对比其他字段大小(数值大小对比),例如:

'price'=>'lt:market_price'
'price'=>'<:market_price'

filter验证

支持使用filter_var进行验证,例如:

'ip'=>'filter:validate_ip'

正则验证

支持直接使用正则验证,例如:

'zip'=>'\d{6}',
// 或者
'zip'=>'regex:\d{6}',

如果你的正则表达式中包含有|符号的话,必须使用数组方式定义。

'accepted'=>['regex'=>'/^(yes|on|1)$/i'],

也可以实现预定义正则表达式后直接调用,例如在验证器类中定义regex属性

    protected $regex = [ 'zip' => '\d{6}'];

然后就可以使用

'zip'	=>	'regex:zip',

上传验证

file

验证是否是一个上传文件

image:width,height,type

验证是否是一个图像文件,width height和type都是可选,width和height必须同时定义。

fileExt:允许的文件后缀

验证上传文件后缀

fileMime:允许的文件类型

验证上传文件类型

fileSize:允许的文件字节大小

验证上传文件大小

'require'     => ':attribute不能为空',
'number'      => ':attribute必须是数字',
'float'       => ':attribute必须是浮点数',
'boolean'     => ':attribute必须是布尔值',
'email'       => ':attribute格式不符',
'array'       => ':attribute必须是数组',
'accepted'    => ':attribute必须是yes、on或者1',
'date'        => ':attribute格式不符合',
'file'        => ':attribute不是有效的上传文件',
'image'       => ':attribute不是有效的图像文件',
'alpha'       => ':attribute只能是字母',
'alphaNum'    => ':attribute只能是字母和数字',
'alphaDash'   => ':attribute只能是字母、数字和下划线_及破折号-',
'activeUrl'   => ':attribute不是有效的域名或者IP',
'chs'         => ':attribute只能是汉字',
'chsAlpha'    => ':attribute只能是汉字、字母',
'chsAlphaNum' => ':attribute只能是汉字、字母和数字',
'chsDash'     => ':attribute只能是汉字、字母、数字和下划线_及破折号-',
'url'         => ':attribute不是有效的URL地址',
'ip'          => ':attribute不是有效的IP地址',
'dateFormat'  => ':attribute必须使用日期格式 :rule',
'in'          => ':attribute必须在 :rule 范围内',
'notIn'       => ':attribute不能在 :rule 范围内',
'between'     => ':attribute只能在 :1 - :2 之间',
'notBetween'  => ':attribute不能在 :1 - :2 之间',
'length'      => ':attribute长度不符合要求 :rule',
'max'         => ':attribute长度不能超过 :rule',
'min'         => ':attribute长度不能小于 :rule',
'after'       => ':attribute日期不能小于 :rule',
'before'      => ':attribute日期不能超过 :rule',
'expire'      => '不在有效期内 :rule',
'allowIp'     => '不允许的IP访问',
'denyIp'      => '禁止的IP访问',
'confirm'     => ':attribute和确认字段:2不一致',
'different'   => ':attribute和比较字段:2不能相同',
'egt'         => ':attribute必须大于等于 :rule',
'gt'          => ':attribute必须大于 :rule',
'elt'         => ':attribute必须小于等于 :rule',
'lt'          => ':attribute必须小于 :rule',
'eq'          => ':attribute必须等于 :rule',
'unique'      => ':attribute已存在',
'regex'       => ':attribute不符合指定规则',
'method'      => '无效的请求类型',
'token'       => '令牌数据无效',
'fileSize'    => '上传文件大小不符',
'fileExt'     => '上传文件后缀不符',
'fileMime'    => '上传文件类型不符',
'tele'        => '电话格式不正确',
'mobile'      => '手机号格式不正确

好的,下面是一个示例的ThinkPHP6验证类,其中包含自定义验证规则的实现: ```php <?php namespace app\validate; use think\Validate; class User extends Validate { // 定义验证规则 protected $rule = [ 'username' => 'require|checkUsername', 'password' => 'require', 'email' => 'require|email', ]; // 定义验证规则的错误提示信息 protected $message = [ 'username.require' => '用户名不能为空', 'password.require' => '密码不能为空', 'email.require' => '邮箱不能为空', 'email.email' => '邮箱格式不正确', ]; // 自定义验证规则函数 protected function checkUsername($value, $rule, $data = []) { // 检查用户名是否符合规范,例如不能包含特殊字符等 return preg_match('/^[a-zA-Z0-9_-]{4,16}$/', $value) ? true : '用户名格式不正确'; } } ``` 在上述代码中,我们创建了一个名为`User`的验证类,定义了三个验证规则,分别是`username`、`password`和`email`。其中,`username`的验证规则使用自定义验证函数`checkUsername`,其余两个规则使用了框架提供的内置规则。同时,我们还为每个验证规则定义了错误提示信息,以便在验证失败时给用户提示。 通过这个示例,我们可以看到如何在ThinkPHP6中实现自定义验证规则,以及如何使用框架提供的验证机制实现表单数据验证。需要注意的是,这仅是一个示例,实际项目中的验证规则应该根据具体需求进行定义。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值