您好,登錄后才能下訂單哦!
今天小編給大家分享一下Laravel怎么實現(xiàn)重新登錄跳轉(zhuǎn)到登錄前頁面的相關(guān)知識點,內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
一、應(yīng)用場景:
用戶登陸后存在過期時間,超時用戶需重新登錄。例:當(dāng)用戶在/user/2 頁面,登陸過期后跳轉(zhuǎn)到登陸頁面,登陸后用戶還應(yīng)在/user/2而不是home/index。
二、實現(xiàn)原理
在判斷用戶過期后,存儲用戶當(dāng)前的url地址到session中,下次登陸后跳轉(zhuǎn)到此url地址。
三、laravel中的具體實現(xiàn)
路由中間件(判斷登陸狀態(tài)) 這里以cookie是否過期判斷用戶登陸狀態(tài),中間件只判斷登陸相關(guān)判斷和執(zhí)行,不做多余操作(登錄時我使用cookie的值$token作為session的鍵存儲),代碼如下:
public function handle($request, Closure $next) { //判斷cookie是否存在 if ($token = Cookie::get('token')) { //判斷session信息,保持狀態(tài)一致 if ($request->session()->get($token)) { return $next($request); } } //獲取當(dāng)前url,跳轉(zhuǎn)到登陸頁 $returnUrl = urlencode($request->getRequestUri()); return redirect('/login?reurl=' . $returnUrl); }
登陸端(處理與頁面交互以及跳轉(zhuǎn)邏輯)這里做的是跳轉(zhuǎn)到登陸頁,這個可以在中間件實現(xiàn),只有這一句,with實現(xiàn)的是將reurl閃存,提供前端使用。
return redirect('/')->with('reurl', $returnUrl);
頁面端(判斷閃存信息) 判斷閃存的信息,這里分ajax和submit登陸,submit應(yīng)該很少了,ajax下獲取reurl,然后后端登陸判斷reurl。
@if (session('reurl')) <input type="hidden" name="reurl" value="{{ session('reurl') }}"/> @endif
登陸(登陸邏輯) 省略了判斷用戶賬戶密碼,和存儲cookie,session的邏輯,最后前端獲取url,location.href = 'url'
,跳轉(zhuǎn)到原url地址。
$reurl = $request->get('reurl'); $url = empty($reurl) ? '/home/index' : $reurl; return response($url);
注:本文只貼出了實現(xiàn)重新登錄的相關(guān)代碼,實際代碼請按照實際業(yè)務(wù)做對應(yīng)修改。
以上就是“Laravel怎么實現(xiàn)重新登錄跳轉(zhuǎn)到登錄前頁面”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。