是否有内置的方法来验证带有验证规则的UUID?我在“Available Validation Rules”文档中没有发现任何相关内容。
您可以在Laravel中扩展验证器助手以添加自定义验证规则,例如我已创建自己的验证规则以使用正则表达式验证位置,如下所示:
Validator::extend('location', function ($attribute, $value, $parameters, $validator) {
return preg_match('/^-?\d{1,2}\.\d{6,}\s*,\s*-?\d{1,2}\.\d{6,}$/', $value);
});
引用这篇文章:PHP preg_match UUID v4
您可以使用UUID正则表达式创建它,如下所示:
Validator::extend('uuid', function ($attribute, $value, $parameters, $validator) {
return preg_match('/[a-f0-9]{8}\-[a-f0-9]{4}\-4[a-f0-9]{3}\-(8|9|a|b)[a-f0-9]{3}\-[a-f0-9]{12}/', $value);
});
希望这符合您的要求。
Laravel 5.6现在提供开箱即用的ramesey/uuid包。您现在可以使用其“isValid”方法来检查UUID。我注意到上面解决方案中的正则表达式有时会失败。我对Laravel内部使用的软件包还没有任何问题。
Validator::extend('uuid', function ($attribute, $value, $parameters, $validator) {
return \Ramsey\Uuid\Uuid::isValid($value);
});
与问题无关,但您现在也可以使用Laravel的“Str”类生成UUID。这就是ramsey / uuid现在默认包含在内的原因,因此无需包含自己的正则表达式。
\Illuminate\Support\Str::uuid();
实际上,Laravel 5.7支持UUID验证。
$validation = $this->validate($request, [
'uuid_field' => 'uuid'
]);
Laravel 5.7 UUID验证由于某种原因不起作用。至少我明白了
InvalidArgumentException: validation.uuid.
解决此问题的最佳方法是从中创建规则。
php artisan make:rule UUID
这是我的UUID验证规则类:
namespace App\Rules;
use Illuminate\Contracts\Validation\Rule;
use Ramsey\Uuid\Uuid as UuidValidator;
class UUID implements Rule
{
/**
* Validate UUID
*
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
return UuidValidator::isValid($value);
}
/**
* Get the validation error message.
*
* @return string
*/
public function message()
{
return 'Supplied :attribute is not valid UUID!';
}
}
然后你就可以像这样手动使用它
$validator = Validator::make($data->all(), ['uuid' => new UUID]);
if ($validator->fails()) {
// Do whatever
}
或者像这样使用http请求验证
namespace App\Http\Requests;
use App\Rules\UUID;
use Illuminate\Foundation\Http\FormRequest;
class UserRequest extends FormRequest
{
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return [
'uuid' => ['required', new UUID],
'email' => ['required','email']
];
}
}