首先介紹一下session的概念:
所謂session是微軟首先提出的,在asp中最先整合。由於session的採用,大大方便了web開發員的工作。一時間asp風靡全球。現在php4也加入session的支援,再度顯示出open source 的強大力量。和Cookie類似,設計Session的目的也是為了在一個訪問期間在不同的頁間傳輸資料以解決http協定無狀態的問題,但Session更簡單、更安全。 Session 中文沒有一個統一的譯法,我習慣上譯為會話。關於session的意義大家都應該清楚: 其實是在瀏覽某個網站時,在瀏覽器沒有關閉的情形之下,一個web應用的開始和結束。一個session可以包括數次http的請求和應答,例如我們用freemail.263.net,從login到logout或超時就作為一個session 的生存期。每一個被創建的Session都有一個唯一的標識串,叫session ID , 這個串被發送到客戶端,同時在伺服器端也產生了同樣唯一的標識串入口,這個標識串或放在文字檔中,或放在一個資料庫中。然後程式可以在這個sessionID下註冊一些Session 變數。這些變數如同一般的變數一樣可以保存文字或數值訊息,可以透過Session被讀出或寫入。 session 的唯一識別一般是在系統內部唯一的session ID,一般是一個挺長的字串。
問題的提出:
解了session概念後,我在為我單位編寫一個進銷存系統中發現需要讓多個用戶可以同時進入一個php應用程式。原來設計的靜態的唯一的session ID導致資料混亂。這樣,動態產生一個唯一的session ID成為當務之急。
解決辦法很簡單:我用了php檔名 時間戳為唯一的session ID,這樣在我的程式中的每個session就各就各位,不再混亂了。
下面把我的原始碼公佈,方便也有同樣的問題的朋友多一個解決方法。
//Start a PHP session to preserve variables.
if ( empty($mysessionname) ) { ] $micro = str_replace(" "," ",$micro); // strip out the blanks
$micro = str_replace(".","",$micro); // strip out the am 》 》》 . $micro;
}
session_name($mysessionname);
〜 〜 〜〜〕] 我用mysessionname為頁間唯一的sessionname傳遞變量,如果你也用到這個名字必須把上述程序做個小小的改動。 Mysessionname不能為session的內部變數名,因為他在session開始之前就已經存在了。 Mysessionname也不能用cookie方式存放,因為多個session一定會覆寫原來的cookie檔。你可以用隱含表單的網域來保存它。這樣就不會出問題。歡迎來信討論。讓我們一起做得更好。
http://www.bkjia.com/PHPjc/315816.html
www.bkjia.com