本文是在request文件中进行验证,也就是把验证规则写在request文件中独立出来。
示例 request:UserRequest
1、在控制器中,直接传入UserRequest参数
public function del(UserRequest $request){}
2、在app/Providers/AppServiceProvider.php中的boot里面增加要自定义的验证规则
Validator::extend('check_exists', function ($attribute, $value,
$parameters, $validator) {
if ($attribute == 'id'){
return call_user_func($parameters[0].'::checkIdExist',
$value) ? true : false;
} else {
return call_user_func($parameters[0].'::checkFieldExist',
$attribute, $value) ? true : false;
}
});
- check_exists为规则调用的名称,$attribute为要验证的字段,$value为该字段的值,$parameters为传入的参数。方法接受布尔返回值。
- 本段代码意思为创建一个名为check_exists的验证,当传入的是id字段,调用 model:: checkIdExist($value) 方法。
3、UserRequest中调用方式
正常的调用方式
public function rules()
{
return 'id' => 'required|numeric|min:0|check_exists:app\Model\User';
}
在UserRequest中的rules直接写调用规则check_exists:app\Model\User即可。
扩展整合调用方式
public function rules()
{
return $this->rules_merge( ['id' => 'required|numeric|min:0'],
$this->rules_input_id(User::class));
}
public function rules_merge($origin, $addition){
$r = collect($origin)->map(function ($value, $key) use(&$addition){
if (array_key_exists($key, $addition)){
array_unshift($addition[$key], $value);
$join = join("|", $addition[$key]);
unset($addition[$key]);
return $join;
} else {
return $value;
}
})->all();
return array_merge($r, $addition);
}
public function rules_input_id($database){
if (!empty($this->input('id'))){
return ['id' => [join(":", ["check_exists", $database])]];
}
return [];
}
- 该扩展主要是把需要的规则整合进去原来的规则里面。
- $this->rules_input_id(User::class) 是生成一个规则格式,改规则格式生成如check_exists:app\Model\User方式的格式。
- rules_merge是把原来的规则required|numeric|min:0跟check_exists:app\Model\User规则整合在一起生效。最终得到的是required|numeric|min:0|check_exists:app\Model\User规则。