zoukankan      html  css  js  c++  java
  • Laravel5.1 表单验证

    当我们提交表单时 通常会对提交过来的数据进行一些验证、Laravel在Controller类中使用了一个traint:ValidatesRequest。方便我们在控制器中使用验证器。

    下面我们就来看一个验证表单的例子。


     1 准备

     1.1 创建路由

    Route::resource('/post', 'PostController');

     1.2 创建控制器

    php artisan make:controller PostController

     1.3 创建视图

    /views 中创建 /post/create.blade.php 文件,编写如下:

    <!DOCTYPE html>
    <html>
    <head>
        <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css">
    </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视图

        public function create()
        {
            return view('post.create');
        }

     2 开始验证

     2.1 validate

     我们在store方法中验证表单提交过来的数据,语法是这样的:

    validate() 参数:

    1. request:传入请求就好。
    2. 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 显示错误信息

    <!DOCTYPE html>
    <html>
    <head>
        <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css">
    </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

        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 '验证通过';
        }
  • 相关阅读:
    C++ 虚函数在基类与派生类对象间的表现及其分析
    借@阿里巴巴 耍了个帅——HTML5 JavaScript实现图片文字识别与提取
    Dede(织梦) CMS SQL Injection Vulnerability
    dedecms v5.5 final getwebshell exploit(datalistcp.class.php)
    DEDECMS网站管理系统Get Shell漏洞
    织梦(Dedecms)select_soft_post.php页面变量未初始漏洞
    织梦(Dedecms) 5.1 feedback_js.php 注入漏洞
    织梦(DEDE)CMS V5.3 覆盖任意变量导致远程包含漏洞
    dedecms织梦 v5.5 两处跨站漏洞
    dedecms织梦 v5.6 两处跨站漏洞
  • 原文地址:https://www.cnblogs.com/sun-kang/p/7614766.html
Copyright © 2011-2022 走看看