本文实例讲述了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')) <div> {{ Session::get('success') }} </div> @endif @if(count($errors)) <div class="alert alert-danger"> <ul> @foreach($errors->all() as $val) <li>{{$val}}</li> @endforeach </ul> </div> @endif
{{$errors->first()}}
可以显示第一条错误信息
数据保持:
return redirect()->back()->withErrors($validator)->withInput();
这段代码中的withInput可以把表单提交的信息带回去,
页面中使用old方法:
姓名 :<input type="text" name="Student[name]" value="{{ old('Student')['name'] }}" /> 性别 : @foreach($student->user_sex() as $ind=>$val) <input type="radio" name="Student[sex]" value="{{$ind}}" {{ old('Student')['sex']==$ind"_blank" href="//www.jb51.net/Special/583.htm">Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
Laravel,表单验证
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。