本文實例講述了PHP中Session ID的實現(xiàn)原理。分享給大家供大家參考,具體如下:
Session 的工作機制是:為每個訪問者創(chuàng)建一個唯一的 id (UID),并基于這個 UID 來存儲變量。UID 存儲在 cookie 中,亦或通過 URL 進行傳導。
PHPSESSIONID的生產(chǎn)算法原理如下:
hash_func = md5 / sha1 #可由php.ini配置
PHPSESSIONID = hash_func(客戶端IP + 當前時間(秒)+ 當前時間(微妙)+ PHP自帶的隨機數(shù)生產(chǎn)器)
從以上hash_func(*)中的數(shù)據(jù)采樣值的內(nèi)容分析,多個用戶在同一臺服務器時所生產(chǎn)的PHPSESSIONID重復的概率極低(至少為百萬份之一),設想,但臺動態(tài)Web Server能到2000/rps已經(jīng)很強悍了。
另外,黑客如果要猜出某一用戶的PHPSESSIONID,則他也必須知道“客戶端IP、當前時間(秒、微妙)、隨機數(shù)”等數(shù)據(jù)方可模擬。
php.ini配置如下:
; Select a hash function for use in generating session ids.
; Possible Values
; 0 (MD5 128 bits)
; 1 (SHA-1 160 bits)
; This option may also be set to the name of any hash function supported by
; the hash extension. A list of available hashes is returned by the hash_algos()
; function.
; http://php.net/session.hash-function
session.hash_function=0
【PHP session工作原理】
以下以cookie傳輸PHPSESSID描述。
1. 客戶端請求一個php的服務端地址。
2. 服務端收到請求,此次php腳本中包含session_start()。
3. 服務端會生成一個PHPSESSID。(默認session存儲方式為session.save_handler=files,文件形式存儲。生成的session文件名規(guī)則即為sess_PHPSESSID,session文件存在session.save_path中。)
4. 服務端響應首部Response Headers:Set-Cookie:PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50; path=/。在客戶端生成一個cookie保存此PHPSESSID。
5. 此時,客戶端的cookie里面包含了PHPSESSID,之后客戶端的每次請求首部Request Headers:Cookie:PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50。服務端之后每次接收到客戶端的請求就都能根據(jù)這個
PHPSESSID來找到服務端的session文件,通過對這個session文件的讀寫操作即實現(xiàn)了session的超全局變量屬性。
如果客戶端禁用了cookie,由于無法使用cookie傳遞PHPSESSID,那么客戶端每次請求,服務端都會重新建立一個session文件,而無法通過通過PHPSESSID來重用session文件,所以session也就失效了。
這種情況可以設置session.use_trans_sid來傳輸PHPSESSID,具體實現(xiàn)方式與cookie的區(qū)別就是將PHPSESSID通過HTTP的GET傳輸。每次請求的地址里面都會補全PHPSESSID參數(shù)”url?
PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50”來實現(xiàn)。
【PHPcli模式通過session_id()使用session】
可以通過它來獲取當前會話的PHPSESSID,也可以通過它來設置當前的會話PHPSESSID。
PHPcli模式下可以通過設置這個,達到使用session的目的,非常方便。
例如:
?php
// session_id('vingbrv8m64asth0nhplu9gmb7');
session_start();
$_SESSION[md5(rand(100,999))] = rand(100,999);
var_dump($_SESSION);
更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《php緩存技術總結》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結》、《PHP錯誤與異常處理方法總結》、《php面向對象程序設計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- php中session_id()函數(shù)詳細介紹,會話id生成過程及session id長度
- php查看當前Session的ID實例
- PHP修改session_id示例代碼
- PHP通過session id 實現(xiàn)session共享和登錄驗證的代碼
- PHP Session_Regenerate_ID函數(shù)雙釋放內(nèi)存破壞漏洞
- php生成SessionID和圖片校驗碼的思路和實現(xiàn)代碼
- PHP Session ID的實現(xiàn)原理與實例