thinkphp6使用自定义验证规则validate

在应用目录下面新建一个validate目录
在目录创建一个BaseValidate文件
在这里插入图片描述

继承Thinkphp6的validate层

<?php


namespace app\api\validate;


use app\common\exception\lib\ParameterException;
use think\facade\Request;
use think\Validate;

class BaseValidate extends Validate
{
        public function gocheck()
        {
         //获取http传入的参数
            $request=Request::instance();
            $params=$request->param();
            $result=$this->batch()->check($params);
            if(!$result){
                $e=new ParameterException([
                    'msg'=>is_array($this->error) ? implode(
                        ';', $this->error) : $this->error,
                ]);
                throw $e;
            }
            else{
                return true;
            }
        }


    //检测变量是否是正整数数字,
    protected function isPositiveInteger($value,$rule='',$data='',$field=''
    )
    {
        if(is_numeric($value)&&is_int($value +0)&&($value +0)>0){
            return true;
        }else{
            return false;
        }
    }

    //检测变量是否为空值
    protected function isNotEmpty($value,$rule='',$data='',$field=''){
            if(empty($value)){
                return false;
            }else{
                return true;
            }
    }


    //检测是否是正确手机号码
    protected function isMobile($value)
    {
        $rule = '^1(3|4|5|7|8)[0-9]\d{8}$^';
        $result = preg_match($rule, $value);
        if ($result) {
            return true;
        } else {
            return false;
        }
    }


    public function getDataByRule($arrays)
    {
        if (array_key_exists('user_id', $arrays) | array_key_exists('uid', $arrays)) {
            // 不允许包含user_id或者uid,防止恶意覆盖user_id外键
            throw new ParameterException([
                'msg' => '参数中包含有非法的参数名user_id或者uid'
            ]);
        }
        $newArray = [];
        foreach ($this->rule as $key => $value) {
            $newArray[$key] = $arrays[$key];
        }
        return $newArray;
    }
}

自定义规则 在目录下的创建一个文件LoginValidate 并且继承BaseValidate

namespace app\api\validate\user;


use app\api\validate\BaseValidate;

class LoginValidate extends BaseValidate
{
    protected $rule =[
        "phone_number"=>"require|isMobile",
        "password" => "require|",
    ];

    protected $message =[
        "phone_number"=>'请输入手机号码',
        "password" =>'请传入密码',
    ];

}

在控制层进行使用

use app\api\validate\user\LoginValidate;
use app\BaseController;

class Login extends BaseController
{
    /**
     * 登录
     * 时间: 2020/7/17 0017 16:43
     * @author: marry a wife
     * @return mixed 登录成功
     * @Route("login",method="post")
     */
    public function login(){
        (new LoginValidate())->gocheck();


    }
    }

如若没输入phone_number或者password 会返回错误

好的,下面是一个示例的ThinkPHP6验证类,其中包含自定义验证规则的实现: ```php <?php namespace app\validate; use think\Validate; class User extends Validate { // 定义验证规则 protected $rule = [ 'username' => 'require|checkUsername', 'password' => 'require', 'email' => 'require|email', ]; // 定义验证规则的错误提示信息 protected $message = [ 'username.require' => '用户名不能为空', 'password.require' => '密码不能为空', 'email.require' => '邮箱不能为空', 'email.email' => '邮箱格式不正确', ]; // 自定义验证规则函数 protected function checkUsername($value, $rule, $data = []) { // 检查用户名是否符合规范,例如不能包含特殊字符等 return preg_match('/^[a-zA-Z0-9_-]{4,16}$/', $value) ? true : '用户名格式不正确'; } } ``` 在上述代码中,我们创建了一个名为`User`的验证类,定义了三个验证规则,分别是`username`、`password`和`email`。其中,`username`的验证规则使用自定义的验证函数`checkUsername`,其余两个规则使用了框架提供的内置规则。同时,我们还为每个验证规则定义了错误提示信息,以便在验证失败时给用户提示。 通过这个示例,我们可以看到如何在ThinkPHP6中实现自定义验证规则,以及如何使用框架提供的验证机制实现表单数据验证。需要注意的是,这仅是一个示例,实际项目中的验证规则应该根据具体需求进行定义。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值