|
項(xiàng)目需求
訪問網(wǎng)站頁面時(shí),有的頁面需要授權(quán)才能訪問,這時(shí)候就會(huì)要求用戶登錄,跳轉(zhuǎn)到登錄頁面login.php,怎么實(shí)現(xiàn)登錄后返回到剛才訪問的頁面。
解決思路1:
在跳轉(zhuǎn)到登錄頁面之前要將當(dāng)前訪問頁面的url保存到cookie里面,登錄驗(yàn)證授權(quán)通過后,從cookie中取出這個(gè)url值,跳轉(zhuǎn)到該url指定的頁面。
具體實(shí)現(xiàn)
我現(xiàn)在的程序是基于Thinkphp框架的,我們會(huì)有一個(gè)父類控制器,下面我就把這個(gè)設(shè)置cookie的代碼加到這個(gè)BaseAction里面的_initialize()函數(shù)中,這樣程序就大大簡(jiǎn)化工作量了。
復(fù)制代碼 代碼如下:
$refer = 'http://' . $_SERVER ['HTTP_HOST'] . $_SERVER['REQUEST_URI'];
Cookie::set('refer', $refer);
登錄檢測(cè)的函數(shù)里面我們加入:
復(fù)制代碼 代碼如下:
$refer = Cookie::get('refer');
現(xiàn)在這個(gè)$refer就是我們之前訪問的頁面,我們可以通過AJAX返回這個(gè)參數(shù),然后進(jìn)行跳轉(zhuǎn),或者直接使用程序進(jìn)行跳轉(zhuǎn),具體要根據(jù)你程序的需求了。
解決思路2:
除了存成cookie的形式,相信大家也看到了很多大型網(wǎng)站直接采用GET的形式獲得,Drupal的登陸機(jī)制就是這樣。
這種思路具體是這樣的:
在跳轉(zhuǎn)到登錄頁面前要將訪客訪問的頁面的url作為參數(shù)傳遞過去,登錄驗(yàn)證后,授予訪問權(quán)限之后跳轉(zhuǎn)到該url指定的頁面。
比如登錄前的url為:openphp.html 當(dāng)訪客訪問時(shí),點(diǎn)擊無權(quán)限,跳轉(zhuǎn)到登錄頁面的地址就為login.php?url=openphp.html,這樣在登錄時(shí)就可以用GET方式獲取該參數(shù) openphp.html,登錄驗(yàn)證成功后跳轉(zhuǎn)到openphp.html 這個(gè)頁面就可以了。
大致上我也就這兩種思路了,如果你有更好的思路,真心希望你可以告訴我。
php技術(shù):PHP 登錄完成后如何跳轉(zhuǎn)上一訪問頁面,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。