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

php中Session的生成機(jī)制、回收機(jī)制和存儲(chǔ)機(jī)制探究

1、php中session的生成機(jī)制

我們先來(lái)分析一下php中是怎么生成一個(gè)session的。設(shè)計(jì)出session的目的是保持每一個(gè)用戶的各種狀態(tài)來(lái)彌補(bǔ)HTTP協(xié)議的不足(無(wú)狀態(tài))。我們現(xiàn)在有一個(gè)疑問,我們都知道session是保存在服務(wù)器的,既然它用于保持每一個(gè)用戶的狀態(tài)那它利用什么來(lái)區(qū)別用戶的呢?這個(gè)時(shí)候就得借助cookie了。當(dāng)我們?cè)诖a中調(diào)用session_start();時(shí),php會(huì)同時(shí)往SESSION的存放目錄(默認(rèn)為/tmp/)和客戶端的cookie目錄各生成一個(gè)文件。session文件名稱像這樣:

格式為sess_{SESSIONID} ,這時(shí)session文件中沒有任何內(nèi)容,當(dāng)我們?cè)趕ession_start();添加了這兩行代碼:
復(fù)制代碼 代碼如下:
$_SESSION['name'] = 'wanchun0222';

$_SESSION['blog'] = 'coderbolg.NET';

這時(shí)文件就有內(nèi)容了:
復(fù)制代碼 代碼如下:
name|s:11:"wanchun0222";blog|s:13:"coderbolg.NET";

這時(shí)再看看cookie:

可以看到服務(wù)器為我們自動(dòng)生成了一個(gè)cookie,cookie名稱為"phpSESSID",cookie內(nèi)容是一串字符,其實(shí)這串字符就是{SESSIONID}。也許你已經(jīng)明白了,當(dāng)我們使用session時(shí),php就先生成一個(gè)唯一的SESSIONID號(hào)(如2bd170b3f86523f1b1b60b55ffde0f66),再在我們服務(wù)器的默認(rèn)目錄下生成一個(gè)文件,文件名為sess_{SESSIONID},同時(shí)在當(dāng)前用戶的客戶端生成一個(gè)cookie,內(nèi)容已經(jīng)說(shuō)過了。這樣php會(huì)為每一個(gè)用戶生成一個(gè)SESSIONID,也就是說(shuō)一個(gè)用戶一個(gè)session文件。php第一次為某個(gè)用戶使用session時(shí)就向客戶端寫入了cookie,當(dāng)這個(gè)用戶以后訪問時(shí),瀏覽器會(huì)帶上這個(gè)cookie,php在拿到cookie后就讀出里面的SESSIONID,拿著這個(gè)SESSIONID去session目錄下找session文件。找到后在調(diào)用$_SESSION['blog']的時(shí)候顯示出來(lái)。

2、php中session的過期回收機(jī)制

我們明白了session的生成及工作原理,發(fā)現(xiàn)在session目錄下會(huì)有許多session文件。當(dāng)然這些文件一定不是永遠(yuǎn)存在的,php一定提供了一種過期回收機(jī)制。在php.ini中session.gc_maxlifetime為session設(shè)置了生存時(shí)間(默認(rèn)為1440s)。如果session文件的最后更新時(shí)間到現(xiàn)在超過了生存時(shí)間,這個(gè)session文件就被認(rèn)為是過期的了。在下一次session回收的時(shí)候就會(huì)被刪除。那下一次session回收是在什么時(shí)候呢?這和php請(qǐng)求次數(shù)有關(guān)的。在php內(nèi)部機(jī)制中,當(dāng)php被請(qǐng)求了N次后就會(huì)有一次觸發(fā)回收機(jī)制。到底是請(qǐng)求多少次觸發(fā)一次是通過以下兩個(gè)參數(shù)控制的:
復(fù)制代碼 代碼如下:
session.gc_probability = 1

session.gc_divisor = 100

這是php.ini的默認(rèn)設(shè)置,意思是每100次php請(qǐng)求就有一次回收發(fā)生。概率是 gc_probability/gc_divisor 。我們了解了服務(wù)器端的session過期機(jī)制,再來(lái)看看客戶端的cookie的過期機(jī)制。

如果cookie失效了瀏覽器自然發(fā)送不了cookie到服務(wù)器,這時(shí)即使服務(wù)器的session文件存在也沒用,因?yàn)?a href=/itjie/phpjishu/ target=_blank class=infotextkey>php不知道要讀取哪個(gè)session文件。我們知道php的cookie過期時(shí)間是在創(chuàng)建時(shí)設(shè)置的,那么php在創(chuàng)建session的同時(shí)為客戶端創(chuàng)建的cookie的生命周期是多久呢?這個(gè)在php.ini中有設(shè)置:session.cookie_lifetime 。這個(gè)值默認(rèn)是0,代表瀏覽器一關(guān)閉SESSIONID就失效。那就是說(shuō)我們把session.gc_maxlifetime和session.cookie_lifetime設(shè)置成同一個(gè)值就可以控制session的失效時(shí)間了。

3、php中session的客戶端存儲(chǔ)機(jī)制

由上面的介紹我們可以知道,如果用戶關(guān)閉了cookie,那我們的session就完全沒法工作了。是的,確實(shí)是這樣。php中session的客戶端存儲(chǔ)機(jī)制只有cookie嗎?不是的。既然我們的SESSIONID 不能通過cookie傳遞到各個(gè)頁(yè)面,那我們還有另一個(gè)法寶,就是通過頁(yè)面GET傳值的方式。

php可以在cookie被禁用時(shí)自動(dòng)通過GET方式跨頁(yè)傳遞SESSIONID,前提是設(shè)置php.ini的session.use_trans_sid為1。這時(shí)當(dāng)我們?cè)诳蛻舳私昧薱ookie時(shí)使用了session,并在當(dāng)前頁(yè)面通過點(diǎn)擊鏈接到另一頁(yè)面時(shí),php會(huì)自動(dòng)在鏈接上添加SESSIONID參數(shù),像這樣:nextpage.php?SESSIONID=2bd170b3f86523f1b1b60b55ffde0f66。我想你應(yīng)該看到了這種方式的缺點(diǎn):好像不夠安全啊。

php技術(shù)php中Session的生成機(jī)制、回收機(jī)制和存儲(chǔ)機(jī)制探究,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 色网站视频 | 九九99久久精品午夜剧场免费 | 国产在线观看成人 | 国产成人一区二区三区在线视频 | 一区二区网站在线观看 | 天天色天天拍 | 国产综合在线视频 | 性开放网站 | 国产精品美女久久久久网站 | 欧美大片欧美激情免费看一 | 图片小说亚洲 | 男人靠女人视频无遮挡大全 | 国产成人免费高清视频 | 午夜视频国语 | 一区二区三区四区在线不卡高清 | 久久久夜间小视频 | 国产精品亚洲国产 | 成人福利在线观看 | 91华人在线视频 | 大杳蕉伊人狼人久久一本线 | 怡红院视频网 | 色在线看| 国产综合变态自虐重口另类 | 亚洲一区免费在线观看 | 久久一级视频 | 国产一二三在线观看 | 国产成人禁片免费观看视频 | 亚洲第一综合网站 | 久久成人精品视频 | 国产99er66在线视频 | 韩国三级久久精品 | 色婷婷网| 国产一区二区视频在线观看 | 亚洲欧美成人 | 蝴蝶色综合综合成人网 | 亚洲一区二区三区免费看 | 欧美亚洲三级 | 欧美特黄三级在线观看 | 国产视频一区二区三区四区 | 91精选视频在线观看 | 欧美色惰 |