您现在的位置是:首页 > thinkphp6教程thinkphp6教程
thinkphp6验证规则失效 thinkphp6Validate验证器使用方法注意事项
上善若水2020-07-17 15:06:55【thinkphp6教程】 6227人已围观
简介今天在使用thinkphp6验证规则时遇到一些坑,导致验证规则始终无法生效,要不就重复验证,要不就验证失效简直心态爆炸,可能是自己用法不正确吧,来看看使用心得吧. 首先来看看正确的验证写法class
今天在使用thinkphp6验证规则时遇到一些坑,导致验证规则始终无法生效,要不就重复验证,要不就验证失效简直心态爆炸,可能是自己用法不正确吧,来看看使用心得吧.
首先来看看正确的验证写法
class CollectTask extends Validate
{
protected $rule = [
'name|采集任务名' => 'require|unique:collect_task|max:255',
'urls|采集任务列表' => 'require',
];
protected $scene = [
'add_type1' => ['name','urls'],
'edit' => ['name'],
];
public function sceneEditType1()
{
return $this->only(['name', 'urls'])
->remove('name', 'unique|max:255');
}
}
这里name|采集任务名
这种写法就是相当于给name
起了一个中文名用于验证显示,就可以不用再定义类似消息规则,唯一的缺陷就是这样写就不能国际化了.
protected $message = [
'name.require' => '名称必须',
'name.max' => '名称最多不能超过25个字符',
'age.number' => '年龄必须是数字',
'age.between' => '年龄只能在1-120之间',
'email' => '邮箱格式错误',
];
验证添加
$v=new \app\admin\validate\collect\CollectTask();
if (!$v->scene('add_type1')->check($data)) {
echo $->getError();
}
验证编辑
$v=new \app\admin\validate\collect\CollectTask();
if (!$v->scene('editType1')->check($data)) {
echo $->getError();
}
以上为正确写法,说下我这里遇到的坑..
我将这里的规则写成$v->scene('edit_type1')->check($data)
这里应该是驼峰写法,写成下划线后竟然还能验证,是验证的全字段,我当时就以为是用下线写法,实际上的用驼峰写法,不然会验证全部,这里按道理没找到验证场景应该就不验证,结果非得验证全字段,导致排斥错误用了很久.
第二个坑就是remove()的用法,官方文档有说明.
如果对同一个字段进行多次规则补充(包括移除和追加),必须使用下面的方式:
remove('field', ['rule1','rule2'])
// 或者
remove('field', 'rule1|rule2')
下面的方式会导致rule1规则remove不成功
remove('field', 'rule1')
->remove('field', 'rule2')
奇怪的写法,但是还得遵循,(官方验证器传送门)[https://www.kancloud.cn/manual/thinkphp6_0/1037627]
很赞哦! (40)
相关文章
随机图文
-
jetbrains-agent.jar激活失败原因 phpstorm永久破解
phpstorm破解有两种方式,一种是激活码方式另一种就是jetbrains-agent.jar,激活码时不时会抽风失效,那么就需要使用jetbrains-agent.jar方式,初次使用本人也激活失 -
thinkphp6软删除 destroy与delete区别
thinkphp6软删除还是比较坑的,使用delete()无法删除触发模型事件,无法触发软删除,destroy与delete两者在使用上有有区别,来看看正确的使用软删除的操作,以及需要注意事项. 配置 -
thinkphp异常处理 修改thinkphp默认报错样式
用的现成的框架,报错太不友好了,就一个提示massage,通过调试找到报错位置还原官方报错页面,如果你也是shipXO直接过来产考方法修改.env开启debug [APP] THINK_ENV= -
shiro1.7 使用springboot 登录 笔记
目前在权限这块shiro和Spring Security是比较热门的两个框架,本篇主要使用shiro实现基本的登录功能,供大家学习使用. 1.引入pom依赖在maven仓库中查找shiro-sprin