注解验证

注解验证器

ThinkPHP支持使用注解方式定义路由和验证,需要安装额外的扩展:

composer require topthink/think-annotation

然后可以直接在控制器类的方法注释中定义,例如:

<?phpnamespace app\controller;use think\annotation\Route;use think\annotation\route\Validate;use app\validate\IndexValidate;class Index{    /**     * @Validate(IndexValidate::class,scene="create",batch="true")     * @return mixed     * @Route("hello")     */	public function hello()    {    	return 'hello, TP6 Annotation  Validate';    }}

@Route("hello/:name")@Validate(IndexValidate::class) 就是注解路由和验证器的内容,请务必注意注释的规范,不能在注解路由里面使用单引号,否则可能导致注解路由解析失败,可以利用IDE生成规范的注释。如果你使用PHPStorm的话,建议安装PHP Annotations插件:https://plugins.jetbrains.com/plugin/7320-php-annotations,可以支持注解的自动完成。

然后需要声明上面引用验证器类,例如:

<?phpnamespace app\validate;use think\Validate;class IndexValidate extends Validate{    protected $rule = [        'name' => 'require'    ];   protected $message = [       'name.require' => '姓名必须填写',   ];    protected $scene = [        'create' => ['name'],    ];}

该方式定义的路由在调试模式下面实时生效,部署模式则在第一次访问的时候生成注解缓存。

注解验证器参数说明

value参数,可以不写value=,直接抒写值就可以了

参数名参数类型参数默认值参数说明
valuestring验证器
scenestring验证场景
batchbooltrue统一验证:true=是,flase=不是
messagearray[]错误内容

错误访问示例:

http://127.0.0.1:8000/hello

页面输出

正确访问示例:

http://127.0.0.1:8000/hello?name=zhans

页面输出