thinkPHP5框架自定义验证器实现方法分析

实例讲述了thinkPHP5框架自定义验证器实现方法。

普通的验证器手册上已经很详细,我们讲解一下如何自定义一个验证器

首先我们在模块目录下建立validata文件夹

然后在里面建立一个类,取名为IdMustInt.php

代码如下:注意,我的模块名为api,所以命名空间如下

保护属性$rule为官方规定,不能改变,其实验证规则require都是封装好的函数名,所以我们也建立一个方法,方法名填写在验证规则后面即可。

  1. namespace app\api\validate;
  2. use think\Validate;
  3. class IdMustInt extends Validate
  4. {
  5.   protected $rule = [
  6.     'id' => 'require|IsInt'
  7.   ];
  8.   protected function IsInt($value,$rule,$data,$field){
  9.   //参数依次为验证数据,验证规则,全部数据(数组),字段名
  10.   //这里我们要判断的验证的数据要求必须为正整型
  11.     if(is_numeric($value) && is_int($value+0) && ($value+0) > 0){
  12.       return true;
  13.     }else{
  14.   //如果不符合我们的条件,返回错误信息,在控制器中可以用getError()方法输出
  15.       return $field.'不是整型';
  16.     }
  17.   }
  18. }

接下来看我们控制器的对应操作。

  1. public function getBanner($id)
  2. {
  3.     //需要验证的数据
  4.     $data = [
  5.       'id' => $id,
  6.     ];
  7.   //实例化验证器
  8.     $validate = new IdMustInt();
  9.   //如果验证数据较多,条件也较多,需要批量返回所有错误信息的话,可以在check()前加上$validata->batch()
  10.     $result = $validate->check($data);
  11.     if($result){
  12.       //业务逻辑
  13.     }else{
  14.       dump($validate->getError());
  15.     } //phpfensi.com
  16. }
THE END