首先介紹一下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); // stripdout the periods 》 》 〜 〜 〜 什麼 〜 什麼. $micro;
}
session_name($mysessionname);
session_start();
程式註解: session_start();
程式註解:
程式註解:
以上就介紹了php伺服器 多php伺服器實作多session並發運行,包含了php伺服器的內容,希望對PHP教學有興趣的朋友有幫助。