概述
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');