insolita / yii2-array-structure-validator
验证复杂结构的数组
2.0.0
2021-07-29 10:28 UTC
Requires
- php: ^7.1|^8.0
- yiisoft/yii2: ~2.0.15
Requires (Dev)
- cebe/indent: *
- phpunit/phpunit: ^7.0|^8.0|^9.0
This package is auto-updated.
Last update: 2024-08-29 05:31:16 UTC
README
用于复杂数组结构的Yii2验证器
验证数组属性,与内置的“each”验证器不同,后者仅支持一个规则,此验证器可以
- 验证多个数组属性,甚至嵌套数据结构
- 必须在数组中存在的所有键必须被描述,对于可选键应设置默认值
- 当输入数组不包含规则中定义的键时,此键会自动添加并带有null值
- 当输入数组包含规则中未定义的键时,将定义“意外的项目”错误
安装
composer require insolita/yii2-array-structure-validator
用法
对于具有已知键的简单数组,例如['id'=>1, 'name'=>'John Doe']
;
public function rules() { return [ //... ['simpleArray', ArrayStructureValidator::class, 'rules'=>[ 'id'=>[['required'], ['integer','min'=>0]], 'name'=>[['required'], ['string', 'max'=>100]], 'sex'=>[['default', 'value'=>'male'], ['in','range'=>['male','female']] ]] ], ]; }
对于多维数组,如 [ ['id'=>1, 'name'=>'John Doe'], ['id'=>2, 'name'=>'Jane Doe','sex'=>'female'], ... ]
设置each = true
public function rules() { return [ //... [['multiArray', 'some', 'attrs'], 'required'], ['multiArray', ArrayStructureValidator::class, 'each'=>true, 'rules'=>[ 'id'=>[['required'], ['integer','min'=>0]], 'name'=>[['required'], ['string', 'max'=>100]], 'sex'=>[['default', 'value'=>'male'], ['in','range'=>['male','female']] ]] ] ]; }
对于嵌套结构
[
'user'=>['id'=>1, 'name'=>'John Doe'],
'coords'=>[['x'=>1, 'y'=>2],['x'=>3,'y'=>4]]
]
public function rules() { return [ //... ['complexArray', ArrayStructureValidator::class, 'rules'=>[ 'user'=>[[ArrayStructureValidator::class, 'rules'=>[ 'id'=>[['required'], ['integer','min'=>0]], 'name'=>[['required'], ['string', 'max'=>100]], ]]], 'coords'=>[[ArrayStructureValidator::class, 'each'=>true, 'rules'=>[ 'x'=>[['required'], ['integer','min'=>0]], 'y'=>[['required'], ['integer','min'=>0]], ], 'min'=>1, 'max'=>5]], ], 'min'=>2, 'max'=>2] ]; }
支持模型场景
public function rules() { return [ //... ['conditional', ArrayStructureValidator::class, 'rules'=>[ 'a'=>[['integer','min'=>0]], //will be checked on any scenario 'b'=>[ ['default', 'value'=>1, 'on'=>['create']], ['integer', 'max'=>10, 'except'=>['create']], ['required', 'on'=>['update']], ['integer', 'max'=>1000, 'on'=>['update']], ] ] ] ]; }
支持闭包和内联验证器,但签名与默认不同
模型类中的内联方法
public function rules() { return [ ['array', ArrayStructureValidator::class, 'rules'=>[ 'item'=>[['required'], ['customValidator']] ]] ]; } public function customValidator($attribute, $model, $index, $baseModel, $baseAttribute){ /** * $model - Dynamic model with attributes equals value data, or value row, if used with each=>true * $attribute - current keyName * $index - current array index for multidimensional arrays, or null * $baseModel - instance of initial model, where validator was attached * $baseAttribute - name of initial attributed, where validator was attached * access to validated value - $model->$attribute * access to whole validated array $baseModel->$baseAttribute * $model->addError($attribute, '[{index}][{attribute}] Error message', ['index'=>$index]); */ }
当支持条件时(但不支持whenClient!)
public function rules() { return [ ['conditional', ArrayStructureValidator::class, 'rules'=>[ 'x'=>[['safe']], 'y'=>[ ['default', 'value'=>1, 'when'=>fn(DynamicModel $model) => $model->x < 10], [ 'default', 'value'=>5, 'when'=>function($model, $attribute, $index, $baseModel, $baseAttribute){ return count($baseModel->$baseAttribute) > 5; }], ] ]] ]; }
注意
数据库相关验证器(exists、unique)尚未通过测试,也不受支持