phpphpsessid
A. php session是怎樣生成的
session是在伺服器端保持用戶會話數據的一種方法,對應的cookie是在客戶端保持用戶數據。HTTP協議是一種無狀態協議,伺服器響應完之後就失去了與瀏覽器的聯系,最早,Netscape將cookie引入瀏覽器,使得數據可以客戶端跨頁面交換,那麼伺服器是如何記住眾多用戶的會話數據呢?
首先要將客戶端和伺服器端建立一一聯系,每個客戶端都得有一個唯一標識,這樣伺服器才能識別出來。建議唯一標識的方法有兩種:cookie或者通過GET方式指定。默認配置的PHP使用session的時會建立一個名叫」PHPSESSID」的cookie(可以通過php.ini修改session.name值指定),如果客戶端禁用cookie,你也可以指定通過GET方式把session id傳到伺服器(修改php.ini中session.use_trans_sid等參數)。
我們查看伺服器端session.save_path目錄會發現很多類似sess_vv9lpgf0nmkurgvkba1vbvj915這樣的文件,這個其實就是session id 「vv9lpgf0nmkurgvkba1vbvj915″對應的數據。真相就在這里,客戶端將session id傳遞到伺服器,伺服器根據session id找到對應的文件,讀取的時候對文件內容進行反序列化就得到session的值,保存的時候先序列化再寫入。
事實就是這樣,所以如果伺服器不支持session或者你想自定義session,完全可以DIY,通過PHP的uniqid生成永不重復的session id,然後找個地方存儲session的內容即可,你也可以學flickr把session存儲在MySQL資料庫中。
B. php SESSION時效的問題。關閉瀏覽器 伺服器的 session沒有消失,還存在。
session會在伺服器存在一定時間,php5默認是1440秒。就是說你把網頁關閉了這個session還存在伺服器里1440秒。
為什麼關了瀏覽器session會生成新的呢,牽扯到一個瀏覽器的數據傳輸問題。
新開一個全新的瀏覽器(IE6下是點擊ie圖標新開一個窗口),瀏覽器沒有帶sessionD這個值(php里名字叫PHPSESSID),伺服器就判斷這是一個新請求,返回給瀏覽器一個新的SESSIONID,然後每次刷新或者打開新頁面,瀏覽器會默認把這個SESSIONID傳給伺服器,這個值在http
head里,你用抓包軟體可以看到。
伺服器接受了這個sessionID,就會知道是哪個SESSION,再取出一系列這個id對應的SESSION值。
C. php第二次獲取前台cookie的值總是PHPSESSID
獲取PHPSESSID的值方法為session_id(),PHPSESSID為SESSION的名稱,使用session_name()獲取
D. PHPSESSID是什麼東西為何總是跟著我的文件後面自動加上
文件名加上$沒什麼作用,但是在區域網內共享的文件夾如果後面加上$就可以在網路上隱藏該文件夾----------
在共享名後面加上 半形的$符號 ,即可把共享目錄隱藏起來了。然後在需要訪問該目錄時,手工在目錄名後加上$。例如:隱藏共享d:\123目錄:右鍵點擊123目錄-共享-在windows的「共享名」後手工輸入$,即123$。在別的機子要獲得該目錄,需要在地址欄輸入\\xx\123$,就能看到該目錄了。
這樣做才可以。
以後注意就是了。
E. PHPSESSID的問題
session好像跨域就會不同,如果跨域跳轉老的session就會丟失好像。後面的問題我就不知道了
F. PHP的SESSION無法保存
您好,SESSION的存儲在伺服器端,但是session id(SESSION標識)的存儲是在客戶端的cookie中的。不同的瀏覽器訪問頁面保存的cookie是隔離的,所以session id是不同的,那麼服務端將會存儲不同的session值。您可以使用chrome查看一下這2個頁面的PHPSESSID的cookie值。
還有一種情況,當客戶端禁用cookie的時候,php可以通過url參數傳遞session參數,您可以到網上搜索一下相關的資料。
G. PHP中,怎麼才能關閉瀏覽器後自動銷毀session
像這個問題,你首先的明白SESSION原理,只有明白了原理才能達到你想要的效果。SESSion的清除是看他的失效時間的,如果你想提交刪除,你可以用PHP判斷SESSIOn是否失效,然後手動清除。