程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> 解決PHP中SESSION不能跨頁傳遞的問題

解決PHP中SESSION不能跨頁傳遞的問題

編輯:PHP綜合
SESSION變量不能跨頁傳遞困擾著很多人。本文詳細介紹和解決了這個問題。出現這個問題的原因一般有以下幾點: 
1、客戶端禁用了cookIE 
2、浏覽器出現問題,暫時無法存取cookIE 
3、php.ini中的session.use_trans_sid = 0或者編譯時沒有打開--enable-trans-sid選項 

為什麼會這樣呢?下面解釋一下: 

Session儲存於服務器端(默認以文件方式存儲session),根據客戶端提供的session id來得到用戶的文件,取得變量的值,session id可以使用客戶端的CookIE或者Http1.1協議的Query_String(就是訪問的URL的“?”後面的部分)來傳送給服務器,然後服務器讀取Session的目錄……。也就是說,session id是取得存儲在服務上的session變量的身份證。當代碼session_start();運行的時候,就在服務器上產生了一個session文件,隨之也產生了與之唯一對應的一個session id,定義session變量以一定形式存儲在剛才產生的session文件中。通過session id,可以取出定義的變量。跨頁後,為了使用session,你必須又執行session_start();將又會產生一個session文件,與之對應產生相應的session id,用這個session id是取不出前面提到的第一個session文件中的變量的,因為這個session id不是打開它的“鑰匙”。如果在session_start();之前加代碼session_id($session id);將不產生新的session文件,直接讀取與這個id對應的session文件。 

PHP中的session在默認情況下是使用客戶端的Cookie來保存session id的,所以當客戶端的cookie出現問題的時候就會影響session了。必須注意的是:session不一定必須依賴cookie,這也是session相比cookie的高明之處。當客戶端的CookIE被禁用或出現問題時,PHP會自動把session id附著在URL中,這樣再通過session id就能跨頁使用session變量了。但這種附著也是有一定條件的,即“php.ini中的session.use_trans_sid = 1或者編譯時打開打開了--enable-trans-sid選項”。 

用過論壇的朋友都知道,在進入論壇的時候,往往會提示你檢查Cookie是否打開,這是因為大多數論壇都是基於Cookie的,論壇用它來保存用戶名、密碼等用戶信息,方便使用。而且很多朋友都認為CookIE不安全(其實不是這樣),往往禁用它。其實在PHP程序中,我們完全可以用SESSION來代替Cookie,它可以不依賴於客戶端是否開啟CookIE。 

所以,我們可以拋開cookie使用session,即假定用戶關閉cookIE的情況下使用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 

<?PHP 
session_start(); 
$_SESSION[’var1’]="中華人民共和國"; 
$url="<a href=".""s2.PHP">下一頁</a>"; 
echo $url; 
?> 

s2.PHP 

<?PHP 
session_start(); 
echo "傳遞的session變量var1的值為:".$_SESSION[’var1’]; 
?> 

運行以上代碼,在客戶端cookIE正常的情況下,應該可以在得到結果“中華人民共和國”。 
現在你手動關閉客戶端的cookIE,再運行,可能得不到結果了吧。如果得不到結果,再“設置PHP.ini中的session.use_trans_sid = 1或者編譯時打開打開了--enable-trans-sid選項”,又得到結果“中華人民共和國” 



途徑2舉例說明: 

s1.PHP 

<?PHP 
session_start(); 
$_SESSION[’var1’]="中華人民共和國"; 
$sn = session_id(); 
$url="<a href=".""s2.PHP?s=".$sn."">下一頁</a>"; 
echo $url; 
?> 

s2.PHP 

<?PHP 
session_id($_GET[’s’]); 
session_start(); 
echo "傳遞的session變量var1的值為:".$_SESSION[’var1’]; 
?> 

隱藏表單的方法基本原理同上。 

途徑3舉例說明: 

login.Html 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD Html 4.01 Transitional//EN"> 
<Html
<head> 
<title>Login</title> 
<meta http-equiv="Content-Type" content="text/Html; charset=gb2312"> 
</head> 
<body> 
請登錄: 
<form name="login" method="post" action="mylogin1.PHP"> 
用戶名:<input type="text" name="name"><br> 
口 令:<input type="passWord" name="pass"><br> 
<input type="submit" value="登錄"> 
</form> 
</body> 
</Html> 

mylogin1.PHP 

<?PHP 

$name=$_POST[’name’]; 
$pass=$_POST[’pass’]; 
if(!$name || !$pass) { 
    echo "用戶名或密碼為空,請<a href="login.Html">重新登錄</a>"; 
    dIE(); 

if (!($name=="jzxue" && $pass=="123") { 
    echo "用戶名或密碼不正確,請<a href="login.Html">重新登錄</a>"; 
    dIE(); 

//注冊用戶 
ob_start(); 
session_start(); 
$_SESSION[’user’]= $name; 
$psid=session_id(); 
$fp=fopen("e:\tmp\PHPsid.txt","w+"; 
fwrite($fp,$psid); 
fclose($fp); 
//身份驗證成功,進行相關操作 
echo "已登錄<br>"; 
echo "<a href="mylogin2.PHP">下一頁</a>"; 

?> 

mylogin2.PHP 

<?PHP 
$fp=fopen("e:\tmp\PHPsid.txt","r"; 
$sid=fread($fp,1024); 
fclose($fp); 
session_id($sid); 
session_start(); 
if(isset($_SESSION[’user’]) && $_SESSION[’user’]="jzxue"  { 
     
    echo "已登錄!"; 

else { 
    //成功登錄進行相關操作 
    echo "未登錄,無權訪問"; 
    echo "請<a href="login.Html">登錄</a>後浏覽"; 
    dIE(); 


?> 

同樣請關閉cookIE測試,用戶名:jzxue 密碼:123  這是通過文件保存session id的,文件是:e: mpPHPsid.txt,請根據自己的系統決定文件名或路徑。 

至於用數據庫的方法,我就不舉例子了,與文件的方法類似。 

總結一下,上面的方法有一個共同點,就是在前一頁取得session id,然後想辦法傳遞到下一頁,在下一頁的session_start();代碼之前加代碼session_id(傳過來的session id); 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved