本文实例讲述了thinkPHP5框架自定义验证器实现方法。分享给大家供大家参考,具体如下:
普通的验证器手册上已经很详细,我们讲解一下如何自定义一个验证器
首先我们在模块目录下建立validata文件夹
然后在里面建立一个类,取名为IdMustInt.php
代码如下:注意,我的模块名为api,所以命名空间如下
保护属性$rule为官方规定,不能改变,其实验证规则require都是封装好的函数名,所以我们也建立一个方法,方法名填写在验证规则后面即可
namespace app\api\validate;
use think\Validate;
class IdMustInt extends Validate
{
protected $rule = [
'id' => 'require|IsInt'
];
protected function IsInt($value,$rule,$data,$field){
//参数依次为验证数据,验证规则,全部数据(数组),字段名
//这里我们要判断的验证的数据要求必须为正整型
if(is_numeric($value) is_int($value+0) ($value+0) > 0){
return true;
}else{
//如果不符合我们的条件,返回错误信息,在控制器中可以用getError()方法输出
return $field.'不是整型';
}
}
}
接下来看我们控制器的对应操作
public function getBanner($id)
{
//需要验证的数据
$data = [
'id' => $id,
];
//实例化验证器
$validate = new IdMustInt();
//如果验证数据较多,条件也较多,需要批量返回所有错误信息的话,可以在check()前加上$validata->batch()
$result = $validate->check($data);
if($result){
//业务逻辑
}else{
dump($validate->getError());
}
}
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
您可能感兴趣的文章:- ThinkPHP5 验证器的具体使用
- Thinkphp5 微信公众号token验证不成功的原因及解决方法
- thinkphp5.0自定义验证规则使用方法
- tp5(thinkPHP5框架)captcha验证码配置及验证操作示例
- 学习thinkphp5.0验证类使用方法
- thinkphp5框架API token身份验证功能示例
- thinkPHP5.0框架验证码调用及点击图片刷新简单实现方法
- thinkphp5使用bootstrapvalidator进行异步验证邮箱的示例
- ThinkPHP5.0框架验证码功能实现方法【基于第三方扩展包】
- Thinkphp5框架使用validate实现验证功能的方法