推荐使用Form Request进行数据验证,可通过artisan命令生成类并定义规则,在Controller中注入实现自动验证;也可在Service类中用Validator门面手动验证,或创建独立验证类封装逻辑;此外可借助中间件做前置校验,但复杂业务建议结合Service与Validator,确保错误响应统一。

在 Laravel 中,数据验证不仅限于 Controller,你可以在 Service 类、Form Request、自定义验证类甚至中间件中完成。下面介绍几种常见的在 Controller 之外进行数据验证的方法。
1. 使用 Form Request 验证(推荐)
Form Request 是 Laravel 提供的专门用于处理表单验证的类,适合将验证逻辑从 Controller 中解耦。
步骤:
- 使用 Artisan 命令生成 Form Request: php artisan make:request StoreUserRequest
- 在生成的类中定义规则: public function rules()
- 在 Controller 中注入该请求类,Laravel 会自动验证: public function store(StoreUserRequest $request)
{
return [
'name' => 'required|string|max:255',
'email' => 'required|email|unique:users',
];
}
{
// 数据已通过验证
}
优点是验证逻辑独立,可复用,并支持 authorize、自定义消息等。
2. 在 Service 类中手动验证
如果你使用了 Service 模式,可以在 Service 类中调用 Validator Facade 进行验证。
示例:
use Illuminate\Support\Facades\Validator;class UserService
{
public function createUser(array $data)
{
$validator = Validator::make($data, [
'name' => 'required',
'email' => 'required|email',
]);
if ($validator->fails()) {
throw new \InvalidArgumentException($validator->errors()->first());
}
// 继续处理逻辑
}
}
这种方式适合复杂业务逻辑中嵌入验证,但需手动处理错误抛出。
3. 创建独立的验证类
对于更复杂的场景,可以创建一个专门的验证类,封装验证逻辑。
例如:
class UserValidator{
public static function validate(array $data)
{
$rules = [
'name' => 'required|min:2',
'email' => 'required|email',
];
$validator = \Validator::make($data, $rules);
if ($validator->fails()) {
return $validator->errors();
}
return true;
}
}
在 Controller 或 Service 中调用:UserValidator::validate($input)。
4. 使用中间件进行前置验证
虽然不常见,但你可以编写自定义中间件,在请求到达 Controller 前验证某些参数。
注意:这种方式更适合通用校验(如 API 签名、字段存在性),不适合复杂业务规则。
基本上就这些常用方式。最推荐的是 Form Request,它结构清晰、易于维护,也符合 Laravel 的设计哲学。如果业务复杂,结合 Service + Validator 更灵活。不复杂但容易忽略的是错误响应的一致性处理,建议统一异常格式。










