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');
    }
}

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

目录
相关文章
|
4月前
|
前端开发 JavaScript Linux
若依修改之后,无法访问前端项目如何解决,只能访问后端的接口,我的接口8083,端不显示咋解决?在vue.config.js文件中的映射路径要跟后端匹配,到软件商店里找到Ngnix配置代理,设80不用加
若依修改之后,无法访问前端项目如何解决,只能访问后端的接口,我的接口8083,端不显示咋解决?在vue.config.js文件中的映射路径要跟后端匹配,到软件商店里找到Ngnix配置代理,设80不用加
|
5月前
|
安全 前端开发 测试技术
安全开发-PHP应用&模版引用&Smarty渲染&MVC模型&数据联动&RCE安全&TP框架&路由访问&对象操作&内置过滤绕过&核心漏洞
安全开发-PHP应用&模版引用&Smarty渲染&MVC模型&数据联动&RCE安全&TP框架&路由访问&对象操作&内置过滤绕过&核心漏洞
|
6月前
thinkphp5.1全局异常类封装
thinkphp5.1全局异常类封装
54 0
thinkphp5.1全局异常类封装
|
6月前
|
中间件
NetCore通过中间件判断接口是否存在 AllowAnonymousAttribute 特性
特性来判断一个接口是否被标记为允许匿名访问。以下是一个简单的中间件示例,用于在请求管道中检查接口是否被。.NET Core中,可以通过检查接口上的。在应用程序中使用此中间件,将其添加到。
84 0
|
6月前
|
JSON 前端开发 Java
SpringBoot - 统一格式封装及高阶全局异常处理
SpringBoot - 统一格式封装及高阶全局异常处理
94 0
|
前端开发 API 数据库
fastadmin框架调用model层的方法
fastadmin框架调用model层的方法
283 0
|
缓存 前端开发 JavaScript
如何优化Yii2视图文件的加载速度?具体步骤是怎样的?底层原理是什么?
如何优化Yii2视图文件的加载速度?具体步骤是怎样的?底层原理是什么?
153 0
|
JSON 前端开发 JavaScript
详细自定义封装Axios请求库,你还不会二次封装吗?(一)
使用Vue的时候,Axios几乎已经是必用的请求库了,但是为了更方便搭配项目使用,很多开发者会选择二次封装,Vue3就很多人选择二次封装elementPlus,那其实,Axios我们也是经常会去封装的。
761 0
|
JavaScript API 开发者
详细自定义封装Axios请求库,你还不会二次封装吗?(二)
使用Vue的时候,Axios几乎已经是必用的请求库了,但是为了更方便搭配项目使用,很多开发者会选择二次封装,Vue3就很多人选择二次封装elementPlus,那其实,Axios我们也是经常会去封装的。
274 0
Yii2的查询构建器是什么?底层原理是什么?
Yii2的查询构建器是什么?底层原理是什么?
104 0