摘要:创建验证任何时候,都可以直接使用think\Validate类而不需要定义验证器类进行独立的验证操作,例如:$validate = Validate::make([ 'name' => 'require|max:25', 'email' => 'email']
创建验证
任何时候,都可以直接使用think\Validate类而不需要定义验证器类进行独立的验证操作,例如:
$validate = Validate::make([
    'name'  => 'require|max:25',
    'email' => 'email']);$data = [
    'name'  => 'thinkphp',
    'email' => 'thinkphp@qq.com'];if (!$validate->check($data)) {
    dump($validate->getError());}
make方法直接传入验证规则(数组),check方法传入需要验证的数据(数组)。
设置规则
也可以使用rule方法设置单个或者批量验证规则,例如:
Validate::make()
    ->rule('zip', '/^\d{6}$/')
    ->rule('email', 'email')
    ->check($data);
支持数组方式
Validate::make()
    ->rule(['zip' => '/^\d{6}$/', 'email' => 'email'])
    ->check($data);
验证规则可以使用think\validate\ValidateRule对象定义
Validate::make()
    ->rule('zip', ValidateRule::regex('/^\d{6}$/'))
    ->rule('email', ValidateRule::must()->isEmail())
    ->check($data);
ValidateRule类可以静态化调用所有的内置验证方法(支持二个参数:验证规则和错误信息)
下面是指定错误信息及验证字段的名称示例:
Validate::make()
    ->rule('zip', ValidateRule::regex('/^\d{6}$/', '邮编错误'))
    ->rule('email', ValidateRule::must()->isEmail()->title('邮箱'))
    ->rule('name', ValidateRule::min(5, '最少5个字符')->max(20, '不得超过20个字符'))    
    ->check($data);
同样在数组方式中也支持:
Validate::make()
    ->rule([
        'zip'   => ValidateRule::regex('/^\d{6}$/'),
        'email' => ValidateRule::email(),
    ])
    ->check($data);
验证数据
下面是一个典型的验证数据的例子:
$rule = [
    'name'  => 'require|max:25',
    'age'   => 'number|between:1,120',
    'email' => 'email',];$msg = [
    'name.require' => '名称必须',
    'name.max'     => '名称最多不能超过25个字符',
    'age.number'   => '年龄必须是数字',
    'age.between'  => '年龄只能在1-120之间',
    'email'        => '邮箱格式错误',];$data = [
    'name'  => 'thinkphp',
    'age'   => 10,
    'email' => 'thinkphp@qq.com',];$validate   = Validate::make($rule,$msg);$result = $validate->check($data);if(!$result) {
    dump($validate->getError());}
如果需要批量验证,可以使用:
$result   = Validate::make($rule,$msg)->batch()->check($data);
						批改老师:韦小宝批改时间:2018-12-09 11:11:40		
						
老师总结:恩!写的很不错!thinkphp中的验证还是很简单好用的!