Laravel中可通过Validator门面在控制器中验证表单数据,使用Validator::make定义规则并用fails()处理错误。还可通过创建Form Request类封装验证逻辑,提升可维护性。支持自定义错误消息和扩展验证规则,如在AppServiceProvider中用extend注册新规则。此外,可创建实现Rule接口的规则对象,以面向对象方式复用复杂验证逻辑。

如果您在 Laravel 中需要对用户提交的表单数据进行合法性校验,可以使用框架内置的 Validator 门面来实现数据验证。以下是几种常用的实现方式:
通过引入 Illuminate\Support\Facades\Validator,可以在控制器方法中直接创建验证器实例,对请求数据进行规则匹配。
1、在控制器方法中导入 Validator:use Illuminate\Support\Facades\Validator;
2、调用 Validator::make 方法并传入数据、规则:
Validator::make($request->all(), [ 'email' => 'required|email', 'password' => 'required|min:6' ])
3、如果验证失败,可通过 fails() 方法判断,并返回错误信息:
if ($validator->fails()) { return redirect('back')->withErrors($validator); }
将验证逻辑封装到独立的请求类中,提升代码可维护性,适用于复杂表单场景。
1、使用 Artisan 命令生成请求类:php artisan make:request StoreUserRequest
2、在生成的请求类的 rules() 方法中定义验证规则:
public function rules() { return [ 'name' => 'required|string|max:255', 'email' => 'required|email|unique:users' ]; }
3、在控制器方法中类型提示该请求类,Laravel 会自动执行验证:
public function store(StoreUserRequest $request) { // 数据已通过验证 }
为验证规则提供更友好的提示信息,可在创建验证器时传入第三个参数作为自定义消息数组。
1、在 Validator::make 的第三个参数中定义消息:
$messages = [ 'email.required' => '邮箱字段不能为空', 'password.min' => '密码长度不能小于6位' ];
2、将消息数组传入验证器:
Validator::make($data, $rules, $messages)
当内置规则无法满足需求时,可通过扩展 Validator 实现自定义规则。
1、在服务提供者(如 AppServiceProvider)的 boot 方法中使用 extend 方法注册规则:
Validator::extend('uppercase', function ($attribute, $value, $parameters, $validator) { return strtoupper($value) === $value; });
2、在验证规则中使用自定义规则名:
'name' => 'required|uppercase'
Laravel 支持以面向对象的方式定义复杂规则,提高复用性和测试性。
1、创建一个实现 Illuminate\Contracts\Validation\Rule 接口的类:
php artisan make:rule Uppercase
2、在类的 passes 方法中编写验证逻辑:
public function passes($attribute, $value) { return $value === strtoupper($value); }
3、在验证规则中使用该对象:
'name' => [new Uppercase]
以上就是Laravel的表单验证怎么写_Laravel内置Validator验证器用法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号