重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
使用Laravel框架怎么实现表单验证操作?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
成都创新互联公司秉承实现全网价值营销的理念,以专业定制企业官网,做网站、成都网站设计,重庆小程序开发公司,网页设计制作,手机网站制作设计,成都全网营销帮助传统企业实现“互联网+”转型升级专业定制企业官网,公司注重人才、技术和管理,汇聚了一批优秀的互联网技术人才,对客户都以感恩的心态奉献自己的专业和所长。public function create(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' => '性别', ]); //方法2 Validator类验证 $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()){ return redirect()->back()->withErrors($validator)->withInput(); } //如果验证通过,则继续执行下面的代码 $data = $request->input('Student'); if(Student::create($data)){ return redirect('student/index')->with('success','添加成功'); }else{ return redirect()->back(); } } return view('student.create'); }
注意Laravel的create方法,需要在model中
设置允许批量赋值:
protected $fillable = ['name','age'];
web中间件有个作用是防止xss攻击,即csrf,需要在页面的表单中增加{{ csrf_field() }},
会生成一个隐藏的input表单,带个token字段。
错误信息的显示:
控制器中的with方法,可以把信息放入session中
return redirect('Student/index')->with('success','添加成功');
页面中的显示:
@if(Session::has('success')){{ Session::get('success') }}@endif @if(count($errors))@endif@foreach($errors->all() as $val)
- {{$val}}
@endforeach
{{$errors->first()}}
可以显示第一条错误信息
数据保持:
return redirect()->back()->withErrors($validator)->withInput();
这段代码中的withInput可以把表单提交的信息带回去,
页面中使用old方法:
姓名 : 性别 : @foreach($student->user_sex() as $ind=>$val) {{$val}} @endforeach
看完上述内容,你们掌握使用Laravel框架怎么实现表单验证操作的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!