时间:2021-05-26
本文实例讲述了laravel框架使用FormRequest进行表单验证,验证异常返回JSON操作.分享给大家供大家参考,具体如下:
通常在项目中,我们会对大量的前端提交过来的表单进行验证,如果不通过,则返回错误信息。
前端为了更好的体验,都使用ajax进行表单提交,虽然 validate() 方法能够根据前端的不同请求方式,返回不同的结果。
但是返回的json格式并不是我们想要的,这个时候,我们就需要自定义返回错误结果。
先创建一个表单请求类:
php artisan make:request TestRequest然后在 rules() 和 messages() 方法里填写自已的验证规则和消息
<?phpnamespace App\Http\Requests;use Illuminate\Foundation\Http\FormRequest;use Illuminate\Contracts\Validation\Validator;use Illuminate\Http\Exceptions\HttpResponseException;class TestRequest extends FormRequest{ /** * 控制访问权限 */ public function authorize() { //注意,默认是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程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
介绍在后端项目里比如我们的Laravel框架对于表单验证有自己的一套validation机制他将验证集成在FormRequest我们只需要在我们的方法中依赖注入
本文实例讲述了Laravel5.1框架表单验证操作。分享给大家供大家参考,具体如下:当我们提交表单时通常会对提交过来的数据进行一些验证、Laravel在Cont
前言在我们使用laravel框架的验证器,有的时候需要对表单等进行数据验证,当然laravel也为我们提供了Illuminate\Http\Request对象提
laravel框架中默认的validate验证,在处理错误的时候,默认是返回上一页,当为ajax的时候才会返回Json。如果我们要一直返回Json的话,那么需要
flask_wtf是flask框架的表单验证模块,可以很方便生成表单,也可以当做json数据交互的验证工具,支持热插拔。安装pipinstallFlask-WT