Laravel框架表单验证操作实例分析
本文实例讲述了Laravel框架表单验证操作。分享给大家供大家参考,具体如下:
publicfunctioncreate(Request$request){ if($request->isMethod('POST')){ //验证通过后继续进行 //方法1控制器验证 $this->validate($request,[ 'Student.name'=>'required|min:2|max:20', 'Student.age'=>'required|integer', 'Student.sex'=>'required|integer', ],[ 'required'=>':attribute为必填项', 'min'=>':attribute长度不符合要求', 'integer'=>':attribute必须是一个整形', ],['Student.name'=>'姓名', 'Student.age'=>'年龄', 'Student.sex'=>'性别', ]); //方法2Validator类验证 $validator=\Validator::make($request->input(),[ 'Student.name'=>'required|min:2|max:20', 'Student.age'=>'required|integer', 'Student.sex'=>'required|integer', ],[ 'required'=>':attribute为必填项', 'min'=>':attribute长度不符合要求', 'integer'=>':attribute必须是一个整形', ],['Student.name'=>'姓名', 'Student.age'=>'年龄', 'Student.sex'=>'性别', ]); if($validator->fails()){ returnredirect()->back()->withErrors($validator)->withInput(); } //如果验证通过,则继续执行下面的代码 $data=$request->input('Student'); if(Student::create($data)){ returnredirect('student/index')->with('success','添加成功'); }else{ returnredirect()->back(); } } returnview('student.create'); }
注意Laravel的create方法,需要在model中
设置允许批量赋值:
protected$fillable=['name','age'];
web中间件有个作用是防止xss攻击,即csrf,需要在页面的表单中增加{{csrf_field()}},
会生成一个隐藏的input表单,带个token字段。
错误信息的显示:
控制器中的with方法,可以把信息放入session中
returnredirect('Student/index')->with('success','添加成功');
页面中的显示:
@if(Session::has('success')){{Session::get('success')}}@endif @if(count($errors))@foreach($errors->all()as$val)
- {{$val}}
@endforeach
{{$errors->first()}}可以显示第一条错误信息
数据保持:
returnredirect()->back()->withErrors($validator)->withInput();
这段代码中的withInput可以把表单提交的信息带回去,
页面中使用old方法:
姓名:性别: @foreach($student->user_sex()as$ind=>$val) {{$val}} @endforeach
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。