thinkphp6 FormRequest,laravel 表单验证

7 篇文章 0 订阅
4 篇文章 0 订阅

参考laravel的

表单验证

#安装

composer require death_satan/thinkphp-form-request -vvv

##创建验证器


# 执行下面的指令可以生成index应用的Blog表单验证器类库文件
php think make:request index@IndexRequest
# app/index/FormRequest/IndexRequest

#如果是单应用模式,则无需传入应用名
php think make:request IndexRequest
# app/FormRequest/IndexRequest

#如果需要生成多级表单验证器,可以使用
php think make:controller index@test/IndexRequest
# app/index/test/Blog/IndexRequest


默认生成的是一个基础表单验证器,类文件如下


<?php

namespace app\FormRequest;

use SaTan\Think\Request\FormRequest;
use think\Validate;

class IndexRequest extends FormRequest
{
    /*
     *初始化
     */
    protected function initialization ():void
    {

    }

    /**
     * @var Validate|string 验证器
     */
    protected $validate;

    /**
     *
     * @var bool $batch 批量验证
     */
    protected $batch = false;

    /**
     * 验证权限
     * @return bool
     */
    protected  function check ():bool
    {
        return true;
    }

    /**
     * 验证规则
     * @return array
     */
    protected function rules():array
    {
        return [
        ];
    }

    /**
     * 错误消息
     * @return array
     */
    protected function messages():array
    {
        return [

        ];
    }

    /**
     * 验证前置操作
     * @param Validate $validate
     */
    protected function withValidate(Validate $validate):void
    {

    }

}

结合validate验证器使用

生成验证器 Test


php think make:validate Test
#会在 app/validate/目录下生成一个 Test验证器

再生成一个表单验证器


php think make:request TestRequest
#会在 app/FormRequest目录下生成一个TestRequest表单验证器类库

修改表单验证器中的validate属性



    /**
     * @var Validate|string 验证器
     */
    protected $validate = \app\validate\Test::class;

在控制器中使用


class Index extends BaseController
{
    public function index(TestRequest $request)
    {
        //验证成功后数据处理...
        dd($request->all());
    }
}

不与validate结合

重写 rules messages方法 以及batch属性


    /**
     *
     * @var bool $batch 批量验证
     */
    protected $batch = false;

    /**
     * 验证权限
     * @return bool
     */
    protected  function check ():bool
    {
        return true;
    }

    /**
     * 验证规则
     * @return array
     */
    protected function rules():array
    {
        return [

        ];
    }

    /**
     * 错误消息
     * @return array
     */
    protected function messages():array
    {
        return [

        ];
    }

验证

验证失败
  • form验证器验证失败的话会进行判断,如果是ajax请求那将会返回一个JsonResponse对象

{
  "message":"this fields errors!",
  "errors": [
    "id不能为空"
  ]
}

  • 如果不是ajax则会返回一个redirect到上一页,并且在session内写入 键名errors的错误消息,以便调用

接管自定义验证

  • 在生成的form request验证器内重写 withValidate 方法
 
    /**
     * 验证前置操作
     * @param Validate $validate
     */
    protected function withValidate(Validate $validate):void
    {
            //验证数据
            $check = $validate->check($this->param());

            if ($check!==true)
            {
                //接管自定义的验证
//                $this->throwCheckError((array)$validate->getError());
            }
    }
  • 其实就是参考laravel的表单验证用tp结合validate写了一个
  • 目的是把数据验证和业务处理分离出来
  • 会laravel的话应该很容易上手
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值