ユーザーのログイン後に有効期限が発生し、タイムアウト後に再度ログインする必要がある場合があります。この記事では主に、Laravel 5.4 でログイン前ページにジャンプするための原則と方法を紹介します。皆さんのお役に立てれば幸いです。
1. アプリケーションシナリオ:
ユーザーのログイン後には有効期限があり、タイムアウト後に再度ログインする必要があります。例: ユーザーが /user/2 ページにいて、ログインの有効期限が切れた後にログイン ページにリダイレクトされる場合、ユーザーは home/index ではなく /user/2 ページにまだいるはずです。
2. 実装原則
ユーザーの有効期限が切れたと判断した後、ユーザーの現在の URL アドレスをセッションに保存し、次回ログイン後にこの URL アドレスにジャンプします。
3. laravelでの具体的な実装
ルーティングミドルウェア(ログイン状態の判定) ここでは、ミドルウェアはCookieの有効期限が切れているかどうかでユーザーのログイン状態を判定しており、ログインに関する判定と実行のみを判定しています。操作 (ログイン時に Cookie を使用します) 値 $token がセッションのキーとして保存されます)、コードは次のとおりです:
public function handle($request, Closure $next) { //判断cookie是否存在 if ($token = Cookie::get('token')) { //判断session信息,保持状态一致 if ($request->session()->get($token)) { return $next($request); } } //获取当前url,跳转到登陆页 $returnUrl = urlencode($request->getRequestUri()); return redirect('/login?reurl=' . $returnUrl); }
ログイン側 (ページとジャンプ ロジックとの対話を処理します) ここで行われることは次のとおりです。ミドルウェアで実装できるのは、reurlをフラッシュしてフロントエンド用に提供するだけです。
return redirect('/')->with('reurl', $returnUrl);
ページ側(フラッシュメモリ情報の判定) フラッシュメモリ情報を判定するには、ajaxログインとsubmitログインがあり、ajaxでreurlを取得し、バックエンドにログインしてreurlを判定します。 。
@if (session('reurl')) <input type="hidden" name="reurl" value="{{ session('reurl') }}"/> @endif
Login (ログイン ロジック) では、ユーザー アカウントのパスワードを決定し、Cookie とセッションを保存するロジックが省略されます。最後に、フロントエンドは URL (location.href = 'url') を取得し、元の URL アドレスにジャンプします。
$reurl = $request->get('reurl'); $url = empty($reurl) ? '/home/index' : $reurl; return response($url);
注: この記事では、再ログインを実装するための関連コードのみを掲載しています。実際のコードは実際の業務に応じて変更してください。
関連する推奨事項:
Thinkphp では、ログイン後にログイン前ページにジャンプする際に依然として問題が発生します
以上がLaravel5.4の再ログインでログイン前ページのコード共有へのジャンプを実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。