Laravel的Form Request用于分离验证与授权逻辑。1. 使用artisan命令生成请求类;2. 在authorize中设置权限,rules中定义规则;3. 可自定义messages错误信息;4. 控制器直接注入使用,自动验证;5. 可通过prepareForValidation预处理数据如文件上传。

在 Laravel 中,Form Request 是一种专门用于处理表单验证和授权的类。它将验证逻辑从控制器中抽离出来,使代码更清晰、可维护性更强。下面详细介绍如何使用 Laravel 的表单请求。
创建 Form Request 类
使用 Artisan 命令可以快速生成一个 Form Request 类:
php artisan make:request StoreUserRequest该命令会在 app/Http/Requests 目录下生成 StoreUserRequest.php 文件(如果目录不存在,Laravel 会自动创建)。
定义验证规则和授权逻辑
打开生成的请求类,主要修改两个方法:authorize() 和 rules()。
authorize():决定当前用户是否有权限发起此请求。返回布尔值。
rules():返回验证规则数组。
public function authorize(){
return true; // 或根据用户角色判断,如 return $this->user()->isAdmin();
}
public function rules()
{
return [
'name' => 'required|string|max:255',
'email' => 'required|email|unique:users',
'password' => 'required|min:6|confirmed'
];
}
你也可以重写 messages() 方法来自定义错误提示信息:
{
return [
'name.required' => '姓名不能为空',
'email.email' => '邮箱格式不正确',
];
}
在控制器中使用 Form Request
在控制器的方法中,将 Form Request 类作为参数注入,Laravel 会自动进行验证。
use App\Http\Requests\StoreUserRequest;public function store(StoreUserRequest $request)
{
// 验证已通过,可以直接使用数据
$data = $request->validated();
// 保存用户等操作
User::create($data);
return redirect()->route('users.index');
}
如果验证失败,Laravel 会自动重定向回上一页,并将错误信息存入 session,前端可通过 $errors 变量获取提示。
处理文件上传或其他预处理
有时你需要在验证前对请求数据做处理,比如上传文件。可以在 Form Request 中添加 prepareForValidation() 方法:
protected function prepareForValidation(){
if ($this->hasFile('avatar')) {
$this->merge([
'avatar_path' => $this->avatar->store('avatars')
]);
}
}
这样就可以在 rules() 中验证 avatar_path,并在控制器中直接使用。
基本上就这些。Form Request 让验证逻辑更集中,控制器更简洁,推荐在中大型项目中使用。










