本文主要讲了thinkphp5.0版本中自定义验证规则的使用方法和一些注意事项。
我们在用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.0自定义验证规则使用方法
基础教程推荐
猜你喜欢
- PHP中的错误及其处理机制 2023-06-04
- PHP实现Redis单据锁以及防止并发重复写入 2022-10-12
- PHP获取MySQL执行sql语句的查询时间方法 2022-11-09
- thinkphp3.2.3框架动态切换多数据库的方法分析 2023-03-19
- laravel 解决多库下的DB::transaction()事务失效问题 2023-03-08
- php array分组,PHP中array数组的分组排序 2022-08-01
- PHP命名空间简单用法示例 2022-12-01
- 在Laravel中实现使用AJAX动态刷新部分页面 2023-03-02
- 使用PHP开发留言板功能 2023-03-13
- laravel ORM关联关系中的 with和whereHas用法 2023-03-02