Laravel学習の落とし穴

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-06-23 13:15:28875ブラウズ

問題: 未定義の変数: エラー (ビュー: C:wampwwwStuLaravel5resourcesviewslogin.blade.php)

login.blade.php コード:

@section('content')<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 class="form-horizontal" role="form" method="POST" action="{{ url('/login') }}">                        {!! csrf_field() !!}                        <div class="form-group{{ $errors->has('email') ? ' has-error' : '' }}">                            <label class="col-md-4 control-label">邮 箱</label>                            <div class="col-md-6">                                <input type="email" class="form-control" name="email" value="{{ old('email') }}">                                @if ($errors->has('email'))                                    <span class="help-block">                                        <strong>{{ $errors->first('email') }}</strong>                                    </span>                                @endif                            </div>                        </div>                        <div class="form-group{{ $errors->has('password') ? ' has-error' : '' }}">                            <label class="col-md-4 control-label">密 码</label>                            <div class="col-md-6">                                <input type="password" class="form-control" name="password">                                @if ($errors->has('password'))                                    <span class="help-block">                                        <strong>{{ $errors->first('password') }}</strong>                                    </span>                                @endif                            </div>                        </div>                        <div class="form-group">                            <div class="col-md-6 col-md-offset-4">                                <div class="checkbox">                                    <label>                                        <input type="checkbox" name="remember"> 记住我                                    </label>                                </div>                            </div>                        </div>                        <div class="form-group">                            <div class="col-md-6 col-md-offset-4">                                <button type="submit" class="btn btn-primary">                                    <i class="fa fa-btn fa-sign-in"></i>登陆                                </button>                                <a class="btn btn-link" href="{{ url('/password/reset') }}">忘记密码</a>                            </div>                        </div>                    </form>                </div>            </div>        </div>    </div></div>@endsection

見つかった:

リクエスト入力パラメータが指定されたパラメータを渡さない場合検証ルールはどうすればよいでしょうか?前述したように、Laravel はユーザーを自動的に前の場所にリダイレクトします。さらに、すべての検証エラー メッセージは、一度にセッションに自動的に保存されます。
GET ルートのビューにエラー メッセージを明示的にバインドしていないことに注意してください。これは、Laravel がセッションデータからのエラーメッセージを常にチェックし、エラーメッセージがあれば自動的にビューにバインドするためです。したがって、リクエストごとにすべてのビューに常に $errors 変数が存在し、ビュー内で便利かつ安全に使用できることに注意してください。 $errors 変数は IlluminateSupportMessageBag のインスタンスです。このオブジェクトの詳細については、そのドキュメントを参照してください。

注: $errors 変数は、Web ミドルウェア グループの IlluminateViewMiddlewareShareErrorsFromSession ミドルウェアを通じてビューにバインドされ、このミドルウェアを使用すると、$errors 変数はビュー内で常に有効になるため、便利に使用できます。いつでも。

解決策:

$error を使用する場合はミドルウェアを使用する必要があります:

IlluminateSessionMiddlewareStartSession::class,

IlluminateViewMiddlewareShareErrorsFromSession::class,

この時点で、カーネルにミドルウェアカーネルが登録されます.php、laravel を使用してミドルウェア グループ web

protected $middlewareGroups = [        'web' => [            \App\Http\Middleware\EncryptCookies::class,            \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,            \Illuminate\Session\Middleware\StartSession::class,            \Illuminate\View\Middleware\ShareErrorsFromSession::class,            \App\Http\Middleware\VerifyCsrfToken::class,        ],        'api' => [            'throttle:60,1',        ],    ];

routes.php

Route::group(['middleware' => 'web'], function () {    Route::get('login', ['middleware' => 'guest', 'as' => 'login', 'uses' => 'loginController@loginGet']);Route::post('login', ['middleware' => 'guest', 'uses' => 'loginController@loginPost']);Route::get('logout', ['middleware' => 'auth', 'as' => 'logout', 'uses' => 'loginController@logout']);});


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。