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:\tmp\phpsid.txt","w+";
18fwrite($fp,$psid);
19fclose($fp);
20//身分識別驗證成功,進行相關操作
21echo "已登入
";
22echo "下一頁";
23?>
mylogin2.php
01
02$fp=fopen("e:\tmp\phpsid.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:\tmp\phpsid.txt。至於用資料庫的方法,就不舉例子了,與檔案的操作方法類似。以上方法有一個共同點,就是在前一頁取得session id,想辦法傳遞到下一頁,在下一頁的session_start();之前加代碼session_id(傳過來的session id);希望能為您提供一些參考。
http://www.bkjia.com/PHPjc/765434.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/765434.htmlTechArticlecookie固然好,不過有些用戶端瀏覽器會禁用cookie,這就會導致你所依賴cookies的程式會失效或出錯,那麼若真出現使用者關閉cookies的情況,P...