ThinkPHP 类似 AOP 思想的参数验证

ThinkPHP 参数验证

思路讲解:不管是在开发API还是做后台项目的时候,后端永远不要相信前端传输的参数,通常要做的是验证参数的合法性和安全性。那么在实际项目开发的时候,怎么简便的验证参数呢。TP提供了好几种参数验证的方式,比如验证器,独立验证,又或者在继承Controller基类的情况下使用validate方法。相比而言,验证器还是最佳选择。一个控制器有多个方法,也就表示有多个请求,也就表示有多个场景。一个项目不止一个控制器,那就表示不止需要建立一个验证器。面向对象的思想,就需要我们建立一个基类验证器,然后让子类继承就行了。那么怎么实现参数验证呢,下面我就介绍下类似AOP思想的参数验证的实现。

定义验证器基类

定义基类app\common\validator\BaseValidator.php

<?php

namespace app\common\validator;

use app\common\exception\ParamException;
use think\Validate;

class BaseValidator extends Validate
{
    /**
     * @param string $scene
     * @return bool
     * @throws ParamException
     */
    public function checkParams($scene='')
    {
        $params = input('param.');
        $res = $this->scene($scene)->check($params);

        if( ! $res ){
            $error = $this->error;
            if(is_array($error)){
                $error = implode(',',$error);
            }
            throw new ParamException(['errMsg'=>$error,]);
        }
        return $res;
    }

    //自定义验证规则

}

定义验证器

<?php

namespace app\common\validator\user;

use app\common\validator\BaseValidator;

class UserValidator extends BaseValidator
{
    protected $rule =   [
        'name'  => 'require|max:25',
        'age'   => 'number|between:1,120',
        'email' => 'email',
    ];

    protected $message  =   [
        'name.require' => '名称必须',
        'name.max'     => '名称最多不能超过25个字符',
        'age.number'   => '年龄必须是数字',
        'age.between'  => '年龄只能在1-120之间',
        'email'        => '邮箱格式错误',
    ];

    protected $scene = [
        'register'  =>  ['name','email'],
    ];
}

验证参数

User.php控制器register方法,实例化验证器,并进行场景验证。

    public function register(Request $request){
        $validator = new UserValidator();
        $validator->checkParams('register');
        .
        .
        .
    }    

至此,类似于AOP思想的参数验证就完成了。

本作品采用《CC 协议》,转载必须注明作者和本文链接
趁还没掉光,赶紧给每根头发起个名字吧~
zs4336
讨论数量: 1

为什么现在写代码 都不喜欢使用验证类呢?就是不喜欢去创建一个文件 感觉会慢 直接就在控制器验证了

3个月前 评论
zs4336 (楼主) 3个月前
steven4 (作者) 2个月前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!