本文实例讲述了Laravel5.1 框架表单验证操作。分享给大家供大家参考,具体如下:
当我们提交表单时 通常会对提交过来的数据进行一些验证、Laravel在Controller类中使用了一个traint:ValidatesRequest。方便我们在控制器中使用验证器。
下面我们就来看一个验证表单的例子。
1 准备
1.1 创建路由
代码语言:javascript复制Route::resource('/post', 'PostController');
1.2 创建控制器
代码语言:javascript复制php artisan make:controller PostController
1.3 创建视图
在 /views 中创建 /post/create.blade.php 文件,编写如下:
代码语言:javascript复制<!DOCTYPE html
<html
<head
<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow"
</head
<body
<div class="container"
<div class="row"
<div class="col-md-8 col-md-offset-2"
<div class="panel panel-default"
<div class="panel-heading"
创建文章
</div
<div class="panel-body"
<form action="{{ url("/post") }}" method="POST" class="form-horizontal"
<input type="hidden" name="_token" value="{{ csrf_token() }}"
<div class="form-group"
<label class="col-md-4 control-label" 标题</label
<div class="col-md-6"
<input type="text" class="form-control" name="title"
</div
</div
<div class="form-group"
<label class="col-md-4 control-label" 内容</label
<div class="col-md-6"
<textarea rows="10" class="form-control" name="content" </textarea
</div
</div
<div class="form-group"
<div class="col-md-6 col-md-offset-4"
<button class="btn btn-primary" type="submit" Submit</button
</div
</div
</form
</div
</div
</div
</div
</div
</body
</html
1.4 在PostController中返回create视图
代码语言:javascript复制public function create()
{
return view('post.create');
}
2 开始验证
2.1 validate
我们在store方法中验证表单提交过来的数据,语法是这样的:
validate() 参数:
- request:传入请求就好。
- rule:规则数组,把我们的验证逻辑写在这里面。
public function store(Request $request)
{
$this- validate($request, [
'title' = 'required|min:3',
'content' = 'required|min:10',
]);
echo '验证通过';
}
↑ 上面的例子如果验证通过 则显示”验证通过” 如果验证没有通过的话Laravel会自动跳转到表单提交页面 并把错误信息闪存到Session中,我们可以修改create.balde.php文件 添加显示错误代码
2.2 显示错误信息
代码语言:javascript复制<!DOCTYPE html
<html
<head
<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow"
</head
<body
<div class="container"
<div class="row"
<div class="col-md-8 col-md-offset-2"
<div class="panel panel-default"
<div class="panel-heading"
创建文章
</div
<div class="panel-body"
@if (count($errors) 0)
<div class="alert alert-danger"
<ul
@foreach ($errors- all() as $error)
<li {{ $error }}</li
@endforeach
</ul
</div
@endif
<form action="{{ url("/post") }}" method="POST" class="form-horizontal"
<input type="hidden" name="_token" value="{{ csrf_token() }}"
<div class="form-group"
<label class="col-md-4 control-label" 标题</label
<div class="col-md-6"
<input type="text" class="form-control" name="title"
</div
</div
<div class="form-group"
<label class="col-md-4 control-label" 内容</label
<div class="col-md-6"
<textarea rows="10" class="form-control" name="content" </textarea
</div
</div
<div class="form-group"
<div class="col-md-6 col-md-offset-4"
<button class="btn btn-primary" type="submit" Submit</button
</div
</div
</form
</div
</div
</div
</div
</div
</body
</html
3 手动创建Validator
代码语言:javascript复制 public function store(Request $request)
{
// $this- validate($request, [
// 'title' = 'required|min:3',
// 'content' = 'required|min:10',
// ]);
$validator = Validator::make($request- all(), [
'title' = 'required|min:3',
'content' = 'required|min:10',
]);
if ($validator- fails()) {
return redirect('post/create')
- withErrors($validator)
- withInput();
}
echo '验证通过';
}
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。