為什么會這樣呢?下面我解釋 " /> 久久66热在线视频精品,疯狂小护士,69国产精品成人无码视频

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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=="youngong" && $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']="laogong" {

echo "已登錄!";
}
else {
//成功登錄進行相關操作
echo "未登錄,無權訪問";
echo "請<a href="login.html">登錄</a>后瀏覽";
die();
}

?>

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

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

總結一下,上面的方法有一個共同點,就是在前一頁取得session id,然后想辦法傳遞到,在的session_start();代碼之前加代碼session_id(傳過來的session id);

php技術PHP Session變量不能傳送到的解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 18videosex性欧美黑色 | 91嫩草国产在线观看免费 | 精品久久久久久久久免费影院 | 午夜伦4480yy妇女久久 | 囯产精品久久久久久久久蜜桃 | 一区二区三区四区国产 | 国内精品久久久久久久试看 | 丰满少妇被猛烈进出69影院 | 草699一码二码三码四码 | 两百磅美女 | 微福利92合集 | 欧美高清另类video | 999久久久国产| 亚洲欧美中文日韩v在线 | 好妞操 | 亚洲国产欧美国产综合在线 | 99久久全国免费久久爱 | 漂亮妈妈中文字幕版 | 秋霞电影网午夜鲁丝片无码 | 日韩亚洲欧美中文高清 | 国产成人综合在线观看 | 亚洲欧美免费无码专区 | 一色狗影院 | 国内精品视频一区二区在线观看 | 很很射影院 | 国产一区二区三区乱码在线观看 | 最近中文字幕mv手机免费高清 | zooskoo1videos人与狗 | 啪啪漫画无遮挡全彩h同人 啪啪激情婷婷久久婷婷色五月 | 中文字幕成人免费高清在线 | 啊好深啊别拔就射在里面 | 精品久久香蕉国产线看观看麻豆 | 午夜精品国产自在现线拍 | 亚洲视频在线看 | A片毛片免费视频在线看 | 99re这里只有精品视频 | 在线免费观看国产视频 | 欧美精品成人a多人在线观看 | 欧美成人免费观看久久 | 久久视频在线视频观看天天看视频 | 岳扒开让我添 |