本文是在request文件中進行驗證,也就是把驗證規(guī)則寫在request文件中獨立出來。
示例 request:UserRequest
1、在控制器中,直接傳入UserRequest參數(shù)
public function del(UserRequest $request){}
2、在app/Providers/AppServiceProvider.php中的boot里面增加要自定義的驗證規(guī)則
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為規(guī)則調用的名稱,$attribute為要驗證的字段,$value為該字段的值,$parameters為傳入的參數(shù)。方法接受布爾返回值。
- 本段代碼意思為創(chuàng)建一個名為check_exists的驗證,當傳入的是id字段,調用 model:: checkIdExist($value) 方法。
3、UserRequest中調用方式
正常的調用方式
public function rules()
{
return 'id' => 'required|numeric|min:0|check_exists:app\Model\User';
}
在UserRequest中的rules直接寫調用規(guī)則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 [];
}
- 該擴展主要是把需要的規(guī)則整合進去原來的規(guī)則里面。
- $this->rules_input_id(User::class) 是生成一個規(guī)則格式,改規(guī)則格式生成如check_exists:app\Model\User方式的格式。
- rules_merge是把原來的規(guī)則required|numeric|min:0跟check_exists:app\Model\User規(guī)則整合在一起生效。最終得到的是required|numeric|min:0|check_exists:app\Model\User規(guī)則。