Lar*el的表单验证怎么写_Lar*el内置Validator验证器用法

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

laravel的表单验证怎么写_laravel内置validator验证器用法

如果您在 Lar*el 中需要对用户提交的表单数据进行合法性校验,可以使用框架内置的 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、在控制器方法中类型提示该请求类,Lar*el 会自动执行验证:

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'

五、使用验证规则对象

Lar*el 支持以面向对象的方式定义复杂规则,提高复用性和测试性。

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]

以上就是Lar*el的表单验证怎么写_Lar*el内置Validator验证器用法的详细内容,更多请关注php中文网其它相关文章!

本文转自网络,如有侵权请联系客服删除。