使laravel的notin验证规则不区分大小写

f45qwnt8  于 2021-06-25  发布在  Mysql
关注(0)|答案(3)|浏览(547)

我正在数据库中存储一个字符串数组(db column type是json)。有一个窗体允许用户向该数组添加值。我要确保这个数组中没有重复项。notin验证规则似乎是防止重复的最简单解决方案,但它区分大小写。因此,当使用notin时,我无法阻止具有不同大小写的相同字符串。

$this->validate(request(), [
    'choice' => [
        'required',
        Rule::notIn($choices)
    ]
]);

是否有人建议我如何修复此验证,以便字符串比较不区分大小写?

z8dt9xmd

z8dt9xmd1#

感谢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))
        ]
    ];
}
cld4siwp

cld4siwp2#

您可以将输入数据和当前数据小写如下:

$input = request()->all();
$input['choice'] = array_map("strtolower", $input['choice']);
$this->validate($input, [
    'choice' => [
        'required',
        Rule::notIn(array_map("strtolower", $choices))
    ]
]);
1sbrub3j

1sbrub3j3#

您可以编写自己的验证规则类:

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'])
    ];
}

相关问题