我们在用thinkphp5.0时候,经常要自定义验证规则,这个写法与tp以前的版本有所区别,小编今天带来大家一起来学习一下5.0下验证规则的使用方法。
在thinkphp5中定义$rule(验证规则)有两种方式
方式一:
$rule = [
// 不可以在此处定义空的验证 如 'name' => '',会导致出现result未定义错误
'name' => 'require|max:25',
'age' => 'number|between:1,120',
];
方式二:
$rule = [
'name' => ['require','max'=>25],
'age' => ['number','between'=>'1,120'],
];
如果方式一自定义验证规则的话,就可以这样写
$rule = [
'name' => 'require|max:25|checkName:',
'age' => 'number|between:1,120',
];
protected function checkNmae($value)
{
$value 是name值,可以在此处进行验证,如正则验证
}
如果是方式二的话,写法如下
$rule = [
'name' => ['require','max'=>25,'checkName'=>'$rule参数'],
'age' => ['number','between'=>'1,120'],
'email' => ['require', 'checkUserEmail'=>'qq.com'],
];
protected function checkName($value, $rule)
{
$vaule 是name值,$rule为上面的$rule参数
}
protected function checkUserEmail($value,$rule)
{
$res = preg_match('/^\w+([-+.]\w+)*@'.$rule.'$/', $value);
if (!$res) {
return '邮箱只能是'.$rule.'域名';
} else {
return true;
}
}
以上就是我们给出的两种方法的代码,如果你有更好的方法或者代码可以在下面的留言区讨论留言。
您可能感兴趣的文章:- ThinkPHP5 验证器的具体使用
- Thinkphp5 微信公众号token验证不成功的原因及解决方法
- tp5(thinkPHP5框架)captcha验证码配置及验证操作示例
- 学习thinkphp5.0验证类使用方法
- thinkPHP5框架自定义验证器实现方法分析
- thinkphp5框架API token身份验证功能示例
- thinkPHP5.0框架验证码调用及点击图片刷新简单实现方法
- thinkphp5使用bootstrapvalidator进行异步验证邮箱的示例
- ThinkPHP5.0框架验证码功能实现方法【基于第三方扩展包】
- Thinkphp5框架使用validate实现验证功能的方法