成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

如何設(shè)置一個(gè)嚴(yán)格30分鐘過(guò)期的Session

馬永翠 / 3152人閱讀

第一種回答

那么, 最常見(jiàn)的一種回答是: 設(shè)置Session的過(guò)期時(shí)間, 也就是session.gc_maxlifetime, 這種回答是不正確的, 原因如下:

首先, 這個(gè)PHP是用一定的概率來(lái)運(yùn)行session的gc的, 也就是session.gc_probability和session.gc_divisor(介紹參看 深入理解PHP原理之Session Gc的一個(gè)小概率Notice), 這個(gè)默認(rèn)的值分別是1和100, 也就是有1%的機(jī)會(huì), PHP會(huì)在一個(gè)Session啟動(dòng)時(shí), 運(yùn)行Session gc. 不能保證到30分鐘的時(shí)候一定會(huì)過(guò)期.

那設(shè)置一個(gè)大概率的清理機(jī)會(huì)呢? 還是不妥, 為什么? 因?yàn)镻HP使用stat Session文件的修改時(shí)間來(lái)判斷是否過(guò)期, 如果增大這個(gè)概率一來(lái)會(huì)降低性能, 二來(lái), PHP使用”一個(gè)”文件來(lái)保存和一個(gè)會(huì)話相關(guān)的Session變量, 假設(shè)我5分鐘前設(shè)置了一個(gè)a=1的Session變量, 5分鐘后又設(shè)置了一個(gè)b=2的Seesion變量, 那么這個(gè)Session文件的修改時(shí)間為添加b時(shí)刻的時(shí)間, 那么a就不能在30分鐘的時(shí)候, 被清理了. 另外還有下面第三個(gè)原因.

PHP默認(rèn)的(Linux為例), 是使用/tmp 作為Session的默認(rèn)存儲(chǔ)目錄, 并且手冊(cè)中也有如下的描述:

Note: 如果不同的腳本具有不同的 session.gc_maxlifetime 數(shù)值但是共享了同一個(gè)地方存儲(chǔ)會(huì)話數(shù)據(jù),則具有最小數(shù)值的腳本會(huì)清理數(shù)據(jù)。此情況下,與 session.save_path 一起使用本指令。 

也就是說(shuō), 如果有倆個(gè)應(yīng)用都沒(méi)有指定自己獨(dú)立的save_path, 一個(gè)設(shè)置了過(guò)期時(shí)間為2分鐘(假設(shè)為A), 一個(gè)設(shè)置為30分鐘(假設(shè)為B), 那么每次當(dāng)A的Session gc運(yùn)行的時(shí)候, 就會(huì)同時(shí)刪除屬于應(yīng)用B的Session files.

所以, 第一種答案是不”完全嚴(yán)格”正確的.
第二種答案

還有一種常見(jiàn)的答案是: 設(shè)置Session ID的載體, Cookie的過(guò)期時(shí)間, 也就是session.cookie_lifetime. 這種回答也是不正確的, 原因如下:

這個(gè)過(guò)期只是Cookie過(guò)期, 換個(gè)說(shuō)法這點(diǎn)就考察Cookie和Session的區(qū)別, Session過(guò)期是服務(wù)器過(guò)期, 而Cookie過(guò)期是客戶端(瀏覽器)來(lái)保證的, 即使你設(shè)置了Cookie過(guò)期, 這個(gè)只能保證標(biāo)準(zhǔn)瀏覽器到期的時(shí)候, 不會(huì)發(fā)送這個(gè)Cookie(包含著Session ID), 而如果通過(guò)構(gòu)造請(qǐng)求, 還是可以使用這個(gè)Session ID的值.
第三種答案

使用memcache, redis等, okey, 這種答案是一種正確答案. 不過(guò), 很顯然出題者肯定還會(huì)接著問(wèn)你, 如果只是使用PHP呢?
第四種答案

當(dāng)然, 面試不是為了難道你, 而是為了考察思考的周密性. 在這個(gè)過(guò)程中我會(huì)提示出這些陷阱, 所以一般來(lái)說(shuō), 符合題意的做法是:

設(shè)置Cookie過(guò)期時(shí)間30分鐘, 并設(shè)置Session的lifetime也為30分鐘.

自己為每一個(gè)Session值增加Time stamp.

每次訪問(wèn)之前, 判斷時(shí)間戳.

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/22758.html

相關(guān)文章

  • php中session相關(guān)設(shè)置描述

    摘要:一下大多是網(wǎng)上的資料,自己只是整理了下,如果有錯(cuò)誤希望能指出,感謝中的相關(guān)配置先看下中的相關(guān)配置的解釋。啟用此設(shè)定可以防止有關(guān)通過(guò)傳遞會(huì)話的攻擊。值為表示直到關(guān)閉瀏覽器。例如意味著在每個(gè)請(qǐng)求中有的概率啟動(dòng)進(jìn)程。 對(duì)于session的了解,之前一直沒(méi)有仔細(xì)研究過(guò),最近遇到了一些問(wèn)題,需要解決session配置問(wèn)題,就順便查看了些資料。一下大多是網(wǎng)上的資料,自己只是整理了下,如果有錯(cuò)誤希望...

    jsdt 評(píng)論0 收藏0
  • session和cookie

    摘要:的作用就是為了解決協(xié)議無(wú)狀態(tài)的缺陷所作的努力。的內(nèi)容主要包括名字,值,過(guò)期時(shí)間,路徑和域。這種生命期為瀏覽器會(huì)話期的被稱為會(huì)話。而機(jī)制采用的是一種在服務(wù)器端保持狀態(tài)的解決方案。中的有效期默認(rèn)分鐘,也就是說(shuō),客戶端超過(guò)分鐘,當(dāng)前就會(huì)失效。 會(huì)話控制是什么? cookie和session都是跟蹤整個(gè)會(huì)話過(guò)程的技術(shù)手段。而會(huì)話,就是用戶通過(guò)瀏覽器和服務(wù)器的一次通話。 為什么要有會(huì)話控制? 因...

    ruicbAndroid 評(píng)論0 收藏0
  • 關(guān)于 PHP 中 Session 幾個(gè)問(wèn)題

    摘要:主要被用于保存某個(gè)訪問(wèn)者的數(shù)據(jù)。服務(wù)器給訪問(wèn)者唯一的鑰匙,這個(gè)鑰匙被稱作。例如官方給出的方案對(duì)于大量使用或者并發(fā)請(qǐng)求的網(wǎng)站而言,這可能是一個(gè)嚴(yán)重的問(wèn)題。例如意味著在每個(gè)請(qǐng)求中有的概率啟動(dòng)進(jìn)程。因此對(duì)于不能跟蹤的文件系統(tǒng)也沒(méi)問(wèn)題了。 什么是 Session 在 web 應(yīng)用開(kāi)發(fā)中,Session 被稱為會(huì)話。主要被用于保存某個(gè)訪問(wèn)者的數(shù)據(jù)。 由于 HTTP 無(wú)狀態(tài)的特點(diǎn),服務(wù)端是不會(huì)記...

    CoyPan 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<