thinkphp5.1全局验证层封装

简介: thinkphp5.1全局验证层封装
1.在很多场景下我们都要对表单提交的数据进行验证,那么如何实现一个验证的重复使用呢,那就让我们来封装一个全局的验证层吧!首先我们创建validate,如下图

这样,我们文件夹下就出现了一个文件夹。

2.我们来编写CeshiValidate.php
<?php
namespace app\common\validate;
use think\Validate;
class CeshiValidate extends BaseValidate
{
    /**
     * 定义验证规则
     * 格式:'字段名' =>  ['规则1','规则2'...]
     *
     * @var array
     */ 
  protected $rule = [
        'username'=>'require',
        'email'=>'require|email',
    ];
    
    /**
     * 定义错误信息
     * 格式:'字段名.规则名' =>  '错误信息'
     *
     * @var array
     */ 
    protected $message = [
        'username.require'=>'用户名不能为空',
        'email.require'=>'邮箱不能为空',
        'email.email'=>'邮箱格式不正确'
    ];
    // 验证场景
    protected $scene = [
        'login'=>['username','email'],
    ];
}
3.由于CeshiValidate.php继承BaseValidate类,所以,BaseValidate.php代码如下所示。
<?php 
namespace app\common\validate;
use think\Validate;
use app\lib\exception\BaseException;
/**
*  
*/
class BaseValidate extends Validate
{
  
  public function goCheck($scene='')
  {
    // 获取用户请求过来的所有数据
      $param = request()->param();
      // 开始验证
      if(empty($param)){
        $check = $this->check($param);
      }else{
      $check = $this->scene($scene)->check($param);
      }
      if(!$check){
        throw new BaseException(['msg'=>$this->getError(),'errorCode'=>10000,'code'=>400]);
      }
      return true;
  }
}
4. 那么我们如何调用呢,请看下面代码。
<?php
namespace app\Index\controller;
use think\Controller;
use think\Request;
use app\lib\exception\BaseException;
use app\common\validate\CeshiValidate;
class Index extends Controller
{
    /**
     * 显示资源列表
     *
     * @return \think\Response
     */
    public function index()
    {
      (new CeshiValidate())->goCheck('login');
    }
}

简单几步,我们封装了验证类,以后不用每次都重复写了。

目录
相关文章
|
12天前
|
JSON 前端开发 API
构建前端防腐策略问题之更新getMemoryUsagePercent函数以适应新的API返回格式的问题如何解决
构建前端防腐策略问题之更新getMemoryUsagePercent函数以适应新的API返回格式的问题如何解决
构建前端防腐策略问题之更新getMemoryUsagePercent函数以适应新的API返回格式的问题如何解决
|
3月前
|
安全 前端开发 测试技术
安全开发-PHP应用&模版引用&Smarty渲染&MVC模型&数据联动&RCE安全&TP框架&路由访问&对象操作&内置过滤绕过&核心漏洞
安全开发-PHP应用&模版引用&Smarty渲染&MVC模型&数据联动&RCE安全&TP框架&路由访问&对象操作&内置过滤绕过&核心漏洞
|
11月前
|
数据安全/隐私保护
fastadmin中写接口是时Validate规则验证自定义如何用
fastadmin中写接口是时Validate规则验证自定义如何用
150 0
|
4月前
thinkphp5.1全局异常类封装
thinkphp5.1全局异常类封装
45 0
thinkphp5.1全局异常类封装
|
4月前
|
JSON 前端开发 Java
SpringBoot - 统一格式封装及高阶全局异常处理
SpringBoot - 统一格式封装及高阶全局异常处理
85 0
|
10月前
|
前端开发 API 数据库
fastadmin框架调用model层的方法
fastadmin框架调用model层的方法
201 0
|
11月前
75 # koa 基本逻辑实现以及属性的扩展
75 # koa 基本逻辑实现以及属性的扩展
18 0
|
缓存 前端开发 JavaScript
如何优化Yii2视图文件的加载速度?具体步骤是怎样的?底层原理是什么?
如何优化Yii2视图文件的加载速度?具体步骤是怎样的?底层原理是什么?
140 0
Yii2的查询构建器是什么?底层原理是什么?
Yii2的查询构建器是什么?底层原理是什么?
|
PHP 开发工具 数据库
Yii2 修改框架入口增加配置适应开发生产环境
Yii2 修改框架入口增加配置适应开发生产环境
114 0
Yii2 修改框架入口增加配置适应开发生产环境