前言
本文主要給大家介紹的是關于Laravel5.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('reurl') }}"/> @endif
登陸(登陸邏輯) 省略了判斷用戶賬戶密碼,和存儲cookie,session的邏輯,最后前端獲取url,location.href = 'url'
,跳轉到原url地址。
$reurl = $request->get('reurl'); $url = empty($reurl) ? '/home/index' : $reurl; return response($url);
注:本文只貼出了實現重新登錄的相關代碼,實際代碼請按照實際業務做對應修改。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對的支持。
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。