cookie固然好,不過有些客戶端浏覽器會禁用cookie,這就會導致你所依賴cookies的程序會失效或出錯,那麼若真出現用戶關閉cookies的情況,PHP應該如何再次使用session?方法還是有的。
1、設置php.ini的session.use_trans_sid = 1或者打開enable-trans-sid選項,讓PHP自動跨頁傳遞session id。
2、手動通過URL傳值、隱藏表單傳遞session id。
3、用文件、數據庫等形式保存session_id,在跨頁過程中手動調用。
途徑1舉例說明:
s1.php
1
2session_start();
3$_SESSION[’var1’]="源碼愛好者";
4$url="下一頁";
5echo $url;
6?>
s2.php
1
2session_start();
3echo "傳遞的session變量var1的值為:".$_SESSION[’var1’];
4?>
運行以上代碼,在客戶端cookie正常的情況下,應該可以在得到結果“源碼愛好者”。
若此時關閉了客戶端的cookie,估計就得不到結果了,這時可設置php.ini中的session.use_trans_sid = 1或者編譯時打開--enable-trans-sid選項”,此時又可重新得到結果“源碼愛好者”
途徑2舉例說明:
s1.php
1
2session_start();
3$_SESSION[’var1’]="源碼愛好者";
4$sn = session_id();
5$url="下一頁";
6echo $url;
7?>
s2.php
1
2session_id($_GET[’s’]);
3session_start();
4echo "傳遞的session變量var1的值為:".$_SESSION[’var1’];
5?>
隱藏表單的方法基本原理同上。
途徑3舉例說明:login.html
mylogin1.php
01
02$name=$_POST[’name’];
03$pass=$_POST[’pass’];
04if(!$name || !$pass) {
05echo "用戶名或密碼為空,請重新登錄";
06die();
07}
08if (!($name=="youngong" && $pass=="123") {
09echo "用戶名或密碼不正確,請重新登錄";
10die();
11}
12//注冊用戶
13ob_start();
14session_start();
15$_SESSION[’user’]= $name;
16$psid=session_id();
17$fp=fopen("e:tmpphpsid.txt","w+";
18fwrite($fp,$psid);
19fclose($fp);
20//身份驗證成功,進行相關操作
21echo "已登錄
";
22echo "下一頁";
23?>
mylogin2.php
01
02$fp=fopen("e:tmpphpsid.txt","r";
03$sid=fread($fp,1024);
04fclose($fp);
05session_id($sid);
06session_start();
07if(isset($_SESSION[’user’]) && $_SESSION[’user’]="laogong" {
08echo "已登錄!";
09}
10else {
11//成功登錄進行相關操作
12echo "未登錄,無權訪問";
13echo "請登錄後浏覽";
14die();
15}
16?>
請關閉cookie再測試,用戶名:youngong 密碼:123 這是通過文件保存session id的,文件是:e:tmpphpsid.txt。至於用數據庫的方法,就不舉例子了,與文件的操作方法類似。以上方法有一個共同點,就是在前一頁取得session id,想辦法傳遞到下一頁,在下一頁的session_start();之前加代碼session_id(傳過來的session id);希望能為您提供一些參考。