概述

ThinkPHP5.0验证使用独立的\think\Validate类或者验证器进行验证。
tp5修改的时候 验证不通过的情况下返回 会把表单中的数据给清空。还没有找到办法解决。

独立验证

任何时候,都可以使用Validate对控制器文件中的字段进行独立的验证操作,例如:
use think\Validate;

$validate = new Validate([
    'name'  => 'require|max:25',
    'email' => 'email'
]);
$data = [
    'name'  => 'thinkphp',
    'email' => 'thinkphp@qq.com'
];
if (!$validate->check($data)) {
    dump($validate->getError());
}

自定义验证器

这是5.0推荐的验证方式,为具体的验证场景或者数据表定义好验证器类,直接调用验证类的check方法即可完成验证,下面是一个例子:

我们定义一个\app\index\validate\User验证器类用于User的验证。

namespace app\index\validate;

use think\Validate;

class User extends Validate
{
    protected $rule = [
        'name'  =>  'require|max:25',
        'age'   =>  'number|between:1,120',
        'email' =>  'email',
    ];
    protected $message = [
       'name.require' => '名称必须填写',
       'name.max'     => '名称最多不能超过25个字符',
       'age.number'   => '年龄必须是数字',
       'age.between'  => '年龄只能在1-120之间',
       'email'        => '邮箱格式错误',
    ];
}

在需要进行User验证的控制器文件中,添加如下代码即可:

user app\index\validate\User as UserValidate
$data = [
    'name'=>'thinkphp',
    'email'=>'thinkphp@qq.com'
];

$validate = Loader::validate('User');
//$validate = validate('User');

if(!$validate->check($data)){
    dump($validate->getError());
}

或者使用助手函数实例化验证器

$validate = validate('User');