Laravel通过validate()方法实现表单验证,失败时自动重定向并闪存错误信息。示例中在控制器使用$request->validate()定义规则,如'name'必填、'email'唯一等,验证通过后保存数据。视图中用@error指令显示字段错误,结合old('field')保留输入值。可自定义错误消息数组或在语言文件中配置多语言。复杂场景推荐使用Form Request类封装验证逻辑,通过artisan命令生成请求类,在rules()方法定义规则,控制器中类型提示注入,自动验证。整个流程提升用户体验,关键在于合理运用验证方法、保留输入、定制提示及拆分复杂逻辑到Form Request。
在Laravel中处理表单验证和错误信息非常直观且强大。框架内置了灵活的验证机制,能快速校验用户输入,并将错误信息传递到视图中提示用户。下面介绍常用方法和最佳实践。
Laravel推荐在控制器中使用validate()方法来处理表单数据校验。当验证失败时,Laravel会自动重定向回上一页并闪存错误信息。
示例:
public function store(Request $request)
{
$validated = $request->validate([
'name' => 'required|string|max:255',
'email' => 'required|email|unique:users',
'password' => 'required|min:8'
]);
// 验证通过后执行保存逻辑
User::create($validated);
return redirect()->route('users.index');
}
Laravel自动将验证错误存入session,并通过$errors变量在模板中可用。你可以在表单字段下方展示对应提示。
使用 @error 指令精准输出某个字段的错误:
@error('name')
{{ $message }}
@enderror
你可以为验证规则提供更友好的提示语。在 validate 方法中传入第三个参数作为自定义消息数组。
$request->validate([
'email' => 'required|email',
], [
'email.required' => '
邮箱地址不能为空。',
'email.email' => '请输入有效的邮箱格式。'
]);
也可在语言文件 lang/en/validation.php 中全局修改,实现多语言支持。
对于复杂的表单逻辑,建议创建专门的请求类(Form Request)。它将验证规则和授权逻辑封装起来,让控制器更简洁。
生成请求类:
php artisan make:request StoreUserRequest
在生成的类中定义规则:
public function rules()
{
return [
'name' => 'required|string|max:255',
'email' => 'required|email|unique:users',
];
}
在控制器中直接类型提示使用:
public function store(StoreUserRequest $request)
{
// 自动验证通过后执行
User::create($request->validated());
return redirect()->route('users.index');
}
基本上就这些。Laravel的表单验证流程清晰,配合视图中的错误展示,能有效提升用户体验。关键是合理使用 validate 方法、保留旧输入、定制提示语,并在必要时拆分出 Form Request 类。