首頁  >  文章  >  後端開發  >  Laravel5.4重新登入實作跳到登入前頁面代碼分享

Laravel5.4重新登入實作跳到登入前頁面代碼分享

小云云
小云云原創
2018-02-08 09:05:051938瀏覽

我們有時會遇到用戶登陸後存在過期時間,超時用戶需重新登錄,本文主要給大家介紹了關於Laravel 5.4重新登錄實現跳轉到登錄前頁面的原理和方法,希望能幫助到大家。

一、應用程式場景:

使用者登陸後存在過期時間,逾時使用者需重新登入。例:當使用者在/user/2 頁面,登陸過期後跳到登陸頁面,登陸後使用者也應在/user/2而不是home/index。

二、實作原理

在判斷使用者過期後,儲存使用者目前的url位址到session中,下次登陸後跳到此url位址。

三、laravel中的具體實現

路由中間件(判斷登陸狀態) 這裡以cookie是否過期判斷用戶登陸狀態,中間件只判斷登陸相關判斷和執行,不做多餘操作(登入時我使用cookie的值$token作為session的鍵存儲),程式碼如下:

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); }

登陸端(處理與頁面互動以及跳轉邏輯)這裡做的是跳到登陸頁,這個可以在中間件實現,只有這一句,with實現的是將reurl閃存,提供前端使用。

return redirect('/')->with('reurl', $returnUrl);

頁端(判斷閃存訊息) 判斷快閃記憶體的信息,這裡分ajax和submit登陸,submit應該很少了,ajax下獲取reurl,然後後端登陸判斷reurl。

 @if (session('reurl'))
  <input type="hidden" name="reurl" value="{{ session(&#39;reurl&#39;) }}"/>
 @endif

登陸(登陸邏輯) 省略了判斷使用者帳號密碼,和儲存cookie,session的邏輯,最後前端取得url,location.href = 'url',跳到原url位址。

$reurl = $request->get('reurl');

$url = empty($reurl) ? '/home/index' : $reurl;

return response($url);

附註:本文只貼了實作重新登入的相關程式碼,實際程式碼請依照實際業務做對應修改。

相關建議:

thinkphp還是登陸後跳到登入前頁面的問題

以上是Laravel5.4重新登入實作跳到登入前頁面代碼分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn