基于 Laravel 封装参数传输层

基于 Laravel 8.x 封装参数传输层,处理函数参数过多传参麻烦问题。

创建 Input 基类

<?php


namespace App\Inputs;


use App\Exceptions\ParametersException;
use Illuminate\Support\Facades\Validator;

class Input
{
    /**
     * 对外暴露提供的参数获取方法
     * @param  array|null  $data 外部传参
     * @return Input|static
     * @throws ParametersException
     */
    public static function new(array $data = null)
    {
        return (new static())->fill($data);
    }

    /**
     * 数据填充、校验
     * @param  array|null  $data 外部传参
     * @return $this
     * @throws ParametersException
     */
    protected function fill(array $data = null)
    {
        // 获取所有参数
        if (is_null($data)) {
            $data = request()->input();
        }

        // 参数校验
        $validator = Validator::make($data, $this->rules());
        if ($validator->fails()) {
            throw new ParametersException($validator->errors()->first());
        }

        // 通过反射完成成员变量的数据填充
        $map = get_object_vars($this);
        $keys = array_keys($map);
        collect($data)->map(function ($v, $k) use ($keys) {
            // 过滤掉除成员变量外其他参数
            if (in_array($k, $keys)) {
                $this->$k = $v;
            }
        });

        return $this;
    }

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

子类继承

<?php


namespace App\Inputs;


use Illuminate\Validation\Rule;

class GoodsListInput extends Input
{
    // 定义所需要的参数
    public $categoryId;
    public $brandId;
    public $keyword;
    public $isNew;
    public $isHot;
    public $page = 1;
    public $limit = 10;
    public $sort = 'add_time';
    public $order = 'desc';

    /**
     * 参数校验规则
     * @return array
     */
    protected function rules()
    {
        return [
            'categoryId' => 'integer|digits_between:1,20',
            'brandId' => 'integer|digits_between:1,20',
            'keyword' => 'string',
            'isNew' => 'boolean',
            'isHot' => 'boolean',
            'page' => 'integer',
            'limit' => 'integer|max:100',
            'sort' => Rule::in(['add_time', 'retail_price', 'name']),
            'order' => Rule::in(['desc', 'asc']),
        ];
    }
}

控制器调用

$input = GoodsListInput::new();
$keyword = $input->keyword;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值