我在我的数据库中存储了一个字符串数组(db列类型是JSON)。有一个表单允许用户向此数组添加值。我想确保此数组中没有重复项。 notIn验证规则似乎是防止重复的最简单的解决方案,但它区分大小写。因此,当使用notIn时,我无法阻止具有不同大小写的相同字符串。
$this->validate(request(), [
'choice' => [
'required',
Rule::notIn($choices)
]
]);
有没有人建议如何修复此验证,以便字符串比较不区分大小写?
答案 0 :(得分:2)
您可以小写输入数据以及当前数据,如下所示:
$input = request()->all();
$input['choice'] = array_map("strtolower", $input['choice']);
$this->validate($input, [
'choice' => [
'required',
Rule::notIn(array_map("strtolower", $choices))
]
]);
答案 1 :(得分:1)
感谢Ramy Herria,我能够扩展他的答案,也可以在FormRequest课程中工作:
protected function validationData()
{
$all = parent::validationData();
//Convert request value to lowercase
$all['choice'] = strtolower($all['choice']);
return $all;
}
public function rules()
{
$choices = $this->route('modelName')->choices;
return [
'choice' => [
'required',
//Also convert array to lowercase
Rule::notIn(array_map('strtolower', $choices))
]
];
}
答案 2 :(得分:0)
您可以编写自己的验证规则类:
use Illuminate\Contracts\Validation\Rule;
use Illuminate\Validation\Concerns\ValidatesAttributes;
use Illuminate\Validation\Rules\In;
class CaseInsensitiveInRule extends In implements Rule
{
use ValidatesAttributes;
private const FORMAT_FUNCTION = 'strtoupper';
public function __construct(array $values)
{
$this->values = array_map(self::FORMAT_FUNCTION, $values);
}
public function passes($attribute, $value)
{
$value = call_user_func(self::FORMAT_FUNCTION, $value);
return $this->validateIn($attribute, $value, $this->values);
}
public function message()
{
return __('validation.invalid_value');
}
}
接下来,您可以在请求类中创建一个对象
public function rules(): array
{
return [
'status' => new CaseInsensitiveInRule(['active', 'deleted'])
];
}