前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Laravel5.1 框架表单验证操作实例详解

Laravel5.1 框架表单验证操作实例详解

作者头像
砸漏
发布2020-10-20 10:43:28
9130
发布2020-10-20 10:43:28
举报
文章被收录于专栏:恩蓝脚本

本文实例讲述了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() 参数:

  1. request:传入请求就好。
  2. rule:规则数组,把我们的验证逻辑写在这里面。
代码语言:javascript
复制
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程序设计有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 准备
    • 1.1 创建路由
      • 1.2 创建控制器
        • 1.3 创建视图
          • 1.4 在PostController中返回create视图
          • 2 开始验证
            • 2.1 validate
              • 2.2 显示错误信息
              • 3 手动创建Validator
              相关产品与服务
              数据库
              云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档