laravel框架使用FormRequest进行表单验证,验证异常
本文实例讲述了laravel框架使用FormRequest进行表单验证,验证异常返回JSON操作.分享给大家供大家参考,具体如下:
通常在项目中,我们会对大量的前端提交过来的表单进行验证,如果不通过,则返回错误信息。
前端为了更好的体验,都使用ajax进行表单提交,虽然 validate()
方法能够根据前端的不同请求方式,返回不同的结果。
但是返回的json格式并不是我们想要的,这个时候,我们就需要自定义返回错误结果。
先创建一个表单请求类:
php artisan make:request TestRequest
然后在 rules()
和 messages()
方法里填写自已的验证规则和消息
<?php namespace App\Http\Requests; use Illuminate\Foundation\Http\FormRequest; use Illuminate\Contracts\Validation\Validator; use Illuminate\Http\Exceptions\HttpResponseException; class TestRequest extends FormRequest { /** * 控制访问权限 */ public function a【本文来源:http://www.1234xp.coml转载请保留出处】uthorize() { //注意,默认是false,改成true return true; } /** * 验证规则 */ public function rules() { return [ 'name' => 'required', 'pwd' => 'required', ]; } /** * 验证消息 */ public function messages() { return [ 'name.required' => '姓名必填', 'pwd.required' => '密码必填', ]; } }
注意,父类 FormRequest中的 failedValidation()
方法用来处理验证失败,我们重写父类方法,来实现自已的返回。
public function failedValidation(Validator $validator) { throw (new HttpResponseException(response()->json([ 'status_code' => 500, 'message' => '请求错误', 'data' => $validator->errors()->first(), ], 200))); }
注意 failedValidation()
方法的 $validator 参数是 Illuminate\Contracts\Validation\Validator 对象,不是 Illuminate\Validation\Validator,不要搞错了。
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
【本文来源:荆门网站推广 转载请保留连接】