程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php在客戶端禁用cookie時讓session不失效的解決方法

php在客戶端禁用cookie時讓session不失效的解決方法

編輯:關於PHP編程

       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

     php在客戶端禁用cookie時讓session不失效的解決方法三聯

      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);希望能為您提供一些參考。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved