一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

深入解析Session是否必須依賴Cookie

php中的session可以默認情況下是使用客戶端的cookie(以便和普通意義上的cookie區別,我稱之為session cookie,普通意義上的cookie為cookie)來保存session id的,但是php中的session是否只能使用session cookie呢?

當然不是,否則何必還弄個session出來,不如直接用cookie算了.session的一大優點就是當客戶端的cookie被禁用時會自動把session id附在url中,這樣再通過session id就能記住session變量了.

下面我寫兩個文件來證實一下,首先在瀏覽器中設置禁用cookie.
復制代碼 代碼如下:
<?
//文件名為test1.php
session_start();
session_register("url");
$url="test2.php";
echo "<a href=$url>goto test2.php</a>";
?><SPAN style="FONT-FAMILY: Arial, Helvetica, sans-serif"> </SPAN>

復制代碼 代碼如下:
<?//文件名為test2.php
session_start();
if (session_is_registered("url")) {
   echo "congratulations.";
   $url="test1.php";
   echo "<a href=$url>goto test1.php</a>";
} else
   echo "failed.";
?>

現在在瀏覽器中輸入"http://localhost/test1.php",把鼠標移到鏈接上看看狀態欄上的地址,不是簡單的"http://localhost/test2.php",而是這種形式:"http://localhost/test2.php?phpsessid=6e3610749f7ded3784bc4a4dd10f879b".

你還可以查看html的源文件,源文件是這種形式:
<a href="test2.php?phpsessid=6e3610749f7ded3784bc4a4dd10f879b">goto test2.php</a>
所以說這完全是php的功勞,和瀏覽器無關,也就是說無論你用什么瀏覽器session都有效,而不是有的人認為的只對ie有用.

但是,我們的超鏈接是語句是由echo語句輸出的,如果超鏈接不包含在php的標簽<? ?>之內會怎樣呢?還是寫個例子來驗證一下,把test1.php稍作修改:
復制代碼 代碼如下:
<?php
session_start();
session_register("url");
$url="test2.php";
echo "<a href=$url>goto test2.php</a>";?>
<a href="test2.php">(html形式)goto test2.php</a>

在瀏覽器中輸入"http://localhost/test1.php",分別把鼠標移到兩個鏈接上看看有沒有不同?可以看到,兩個鏈接是完全相同的,后面都會自動附帶session id.所以不必擔心沒被包含在php標簽中的鏈接會失效,php不會這么笨的.

但是在使用時要注意必須先用session_start()函數告訴php開始用session,哪怕你在這個文件中只有html代碼,如:
<? session_start();?>
<html>
<head>
<body>
<a href=test2.php>gogogo</a>
…………

記得有人說過這個優點只能在linux/unix下才能發揮出來,而我用的win2000p+apache1.3.17+php4.0.4pl1,php為apache模塊方式,卻照樣可以.恰恰相反,我轉到linux下去測試時反而不行了.其實是在編譯時的一個選項--enable-trans-sid控制了這項功能能否有用.而按照php默認來編譯時是沒有打開這項功能的,只需重新編譯時加入它就可以了.我的配置為apache1.3.17+php4.0.4pl1,php為apache模塊方式,在linux重新編譯后用NETscape navigator4.7測試可以通過(這更證明了和瀏覽器無關).

只靠session是不能跨窗口使用的,即使你啟用了cookie,當你在一個窗口中有一個合法的session id(記錄在session cookie中,不是url中),再新開一個窗口進入相同頁面時,你會重新擁有一個新的session id,而與前一個窗口互不影響.

要想跨窗口使用同一個session id就只能在url后指定session id,也就是說如果你把帶有session id的的窗口的url復制,在新開的窗口中粘貼一下,還是照樣使用的.知道了session id的這個原理要實現跨窗口session還是不難的,可以把cookie與session結合起來,首先取得當前合法的session id,然后把它記錄在cookie中,在其它窗口讀取cookie就可獲得當前的session id了.

php技術深入解析Session是否必須依賴Cookie,轉載需保留來源!

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

主站蜘蛛池模板: 欧美成人精品福利在线视频 | 一区二区免费在线观看 | 一本久久道 | 欧美精品人爱a欧美精品 | 国产精品伦子一区二区三区 | 91精品啪在线观看国产91九色 | 欧美精品第二页 | 国产身材极品喷水 在线播放 | 日本成人在线网站 | 麻豆精品久久久一区二区 | 亚洲精品国产拍拍拍拍拍 | 美女网站一区二区三区 | 欧美超级碰碰 | 亚洲酒色1314狠狠做 | 久久精品国产清白在天天线 | www.色呦呦.com | 国产高清免费的视频 | 国内一级特黄女人精品毛片 | 高清 仑乱 一级 a | 亚洲国产成人在线观看 | 免费国产成人手机在线观看 | 国产精品福利在线 | 国产视频一二三区 | 国产成人综合久久精品亚洲 | 狂野欧美性猛交xxxx巴西 | 多人伦交性欧美在线观看 | 在线观看视频www在线观看 | 深夜福利一区二区 | 国产亚洲欧美另类专区 | 久久久久久久久亚洲 | 91在线视频国产 | 成年美女黄网站色大片图片 | 九一精品国产 | 亚洲黄色一级毛片 | 日韩精品一区二区三区中文在线 | 男女91视频| 国产成人久久精品麻豆二区 | 91久久青草精品38国产 | 国产亚洲精品激情都市 | fefe66毛片免费看 | 亚洲精品成人中文网 |