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

如果您在 Laravel 中需要对用户提交的表单数据进行合法性校验,可以使用框架内置的 Validator 门面来实现数据验证。以下是几种常用的实现方式:
一、在控制器中使用 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); }
二、使用请求类(Form Request)进行验证
将验证逻辑封装到独立的请求类中,提升代码可维护性,适用于复杂表单场景。
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]









