• 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 '验证通过';
        }
  • 相关阅读:
    发一弹
    压缩图片
    页面返回并刷新页面
    贤心的WEB弹窗挺不错的
    SMS短信发送API 以后可以弄个短信验证了
    <many-to-one>的fetch属性
    AJAX技术
    中国土地所有权的属性
    Today 's check:mappingResource属性和mappingDirectoryLocations属性的使用
    Pattern类的中文版 菜鸟翻译 有错请纠
  • 原文地址:https://www.cnblogs.com/sun-kang/p/7614766.html
Copyright © 2020-2023  润新知