好的。此验证的逻辑在YourFormRequest
接下来是:
- 让我们根据需要标记所有字段并
document_num
字段附加为整数。您可以添加其他附加约束 - 这并不重要。
- In
rules
的方法YourFormRequest
检查循环“给定的用户是否存在document_num
?".
- 如果它不存在,则确定 - 该字段的验证成功。
- 如果存在,则检查“用户全名是否等于给定的
fullname
。如果等于则确定 - 该字段验证成功。否则,如果失败,则将始终失败的自定义规则附加到此字段。
让我们通过一个工作示例来看看这种方法。
您的表单请求.php
public function rules()
{
$rules = [
'fullname.*' => 'required',
'document_num.*' => 'required|integer',
];
$documentNums = request()->get('document_num');
$fullnames = request()->get('fullname');
for ($i = 0; $i < count($documentNums); $i++) {
$user = User::where('document_num', $documentNums[$i])->first();
if ($user && ($user->fullname != $fullnames[$i]) {
$rules['document_num.' . $i] = "document_num_fail:$i"; //some rule that always fails. As argument we pass a row number of field that fails
}
}
return $rules;
}
CustomValidator.php(例如将其放置在 App\Services 文件夹中)
namespace App\Services;
class CustomValidator {
public function documentNumFailValidate($attribute, $value, $parameters, $validator) {
return false;
}
public function documentNumFailReplacer($message, $attribute, $rule, $parameters) {
return str_replace([':index'], $parameters[0], $message);
}
}
在这里你可以看到两个函数。首先 - 验证规则(我们总是传递错误,因为我们需要它)。其次 - 它只是错误消息的替代品。您想知道此错误出现在哪个字段行(例如,分别在第三行和字段:fullname[2] 和 document_num[2] 上)。正如我在上面关于附加失败规则的评论中所写的那样,我们给出了验证方法失败的行数(documentNumFailReplacer
方法将用给定值替换错误消息中的占位符:index)
下一步 - 在 AppServiceProvider.php 中注册此方法
public function boot()
{
Validator::extend('document_num_fail', 'App\Services\CustomValidator@documentNumFailValidate');
Validator::replacer('document_num_fail', 'App\Services\CustomValidator@documentNumFailReplacer');
}
最后一步 - 在validation.php中定义您的自定义消息
'custom' => [
'document_num.*' => [
'document_num_fail' => 'Input-ed user name doesn`t match his/her name in DB for specified :attribute (field position/number: :index)',
]
],
'attributes' => [
'document_num.*' => 'document number',
],