Ⅰ php session 存放對象問題
可以的,但是需要先將類對象序列化如,$_SESSION['object'] = serialize( $Object );
Ⅱ php session 可以存對象嗎
可以啊,步驟如下:
1、得到類,並實例化;
2、用 serialize 序列化;
3、用 session 保存;
4、包含原先的 類文件,用 unserialize 反序列化;
Ⅲ php session原理
在解決問題之前,先來了解一下 PHP SESSION 的工作原理。在客戶端(如瀏覽器)登錄網站時,被訪問的 PHP 頁面可以使用 session_start() 打開 SESSION,這樣就會產生客戶端的唯一標識 SESSION ID(此 ID 可通過函數 session_id() 獲取/設置)。SESSION ID 可以通過兩種方式保留在客戶端,使得請求不同的頁面時,PHP 程序可以獲知客戶端的 SESSION ID;一種是將 SESSION ID 自動加入到 GET 的 URL 中,或者 POST 的表單中,默認情況下,變數名為 PHPSESSID;另一種是通過 COOKIE,將 SESSION ID 保存在 COOKIE 中,默認情況下,這個 COOKIE 的名字為 PHPSESSID。這里我們主要以 COOKIE 方式進行說明,因為應用比較廣泛。
那麼 SESSION 的數據保存在哪裡呢?當然是在伺服器端,但不是保存在內存中,而是保存在文件或資料庫中。默認情況下,php.ini 中設置的 SESSION 保存方式是 files(session.save_handler = files),即使用讀寫文件的方式保存 SESSION 數據,而 SESSION 文件保存的目錄由 session.save_path 指定,文件名以 sess_ 為前綴,後跟 SESSION ID,如:sess_。文件中的數據即是序列化之後的 SESSION 數據了。如果訪問量大,可能產生的 SESSION 文件會比較多,這時可以設置分級目錄進行 SESSION 文件的保存,效率會提高很多,設置方法為:session.save_path="N;/save_path",N 為分級的級數,save_path 為開始目錄。當寫入 SESSION 數據的時候,PHP 會獲取到客戶端的 SESSION_ID,然後根據這個 SESSION ID 到指定的 SESSION 文件保存目錄中找到相應的 SESSION 文件,不存在則創建之,最後將數據序列化之後寫入文件。讀取 SESSION 數據是也是類似的操作流程,對讀出來的數據需要進行解序列化,生成相應的 SESSION 變數。
Ⅳ 請描述 php session 的運行機制,大型網站中session方面應注意什麼
運行機制:客戶端將session id傳遞到伺服器,伺服器根據session id找到對應的文件,讀取的時候對文件內容進行反序列化就得到session的值,保存的時候先序列化再寫入
注意:1,session在大訪問量網站上確實影響系統性能,影響性能的原因之一由文件系統設計造成,在同一個目錄下超過10000個文件時,文件的定位將非常耗時,可以通過修改php.ini中session.save_path設置兩級子目錄 ,session將存儲在兩級子目錄中,每個目錄有16個子目錄[0~f],不過好像PHP session不支持創建目錄,你需要事先把那麼些目錄創建好 。
Ⅳ 使用php的SESSION直接保存對象序列化,但反序列化時出錯
在output.php中$person沒有實例化成Person對象,所以無法調用Person對象的outPut()方法。
Ⅵ PHP中使用類自定義session ,搶奪控制權時的使用__CLASS__設置參數的用法
session_set_save_handler 是表示自定義session的處理方式,否則則使用php內置session處理
(__CLASS__,'open') 是指各個處理方法
open(string $savePath, string $sessionName)
open 回調函數類似於類的構造函數, 在會話打開的時候會被調用。 這是自動開始會話或者通過調用session_start() 手動開始會話 之後第一個被調用的回調函數。 此回調函數操作成功返回 TRUE,反之返回FALSE。
close()
close 回調函數類似於類的析構函數。 在 write 回調函數調用之後調用。 當調用 session_write_close() 函數之後,也會調用 close 回調函數。 此回調函數操作成功返回 TRUE,反之返回 FALSE。
read(string $sessionId)
如果會話中有數據,read 回調函數必須返回將會話數據編碼(序列化)後的字元串。 如果會話中沒有數據,read 回調函數返回空字元串。
在自動開始會話或者通過調用 session_start() 函數手動開始會話之後,PHP 內部調用 read 回調函數來獲取會話數據。 在調用 read 之前,PHP 會調用 open 回調函數。
read 回調返回的序列化之後的字元串格式必須與 write 回調函數保存數據時的格式完全一致。 PHP 會自動反序列化返回的字元串並填充 $_SESSION 超級全局變數。 雖然數據看起來和 serialize() 函數很相似, 但是需要提醒的是,它們是不同的。 請參考: session.serialize_handler。
write(string $sessionId, string $data)
在會話保存數據時會調用 write 回調函數。 此回調函數接收當前會話 ID 以及 $_SESSION 中數據序列化之後的字元串作為參數。 序列化會話數據的過程由 PHP 根據 session.serialize_handler 設定值來完成。
序列化後的數據將和會話 ID 關聯在一起進行保存。 當調用 read 回調函數獲取數據時,所返回的數據必須要和 傳入 write 回調函數的數據完全保持一致。
PHP 會在腳本執行完畢或調用 session_write_close() 函數之後調用此回調函數。 注意,在調用完此回調函數之後,PHP 內部會調用 close 回調函數。
Note:
PHP 會在輸出流寫入完畢並且關閉之後 才調用 write 回調函數, 所以在 write 回調函數中的調試信息不會輸出到瀏覽器中。 如果需要在 write 回調函數中使用調試輸出, 建議將調試輸出寫入到文件。
destroy($sessionId)
當調用 session_destroy() 函數, 或者調用 session_regenerate_id() 函數並且設置 destroy 參數為 TRUE 時, 會調用此回調函數。此回調函數操作成功返回 TRUE,反之返回 FALSE。
gc($lifetime)
為了清理會話中的舊數據,PHP 會不時的調用垃圾收集回調函數。 調用周期由 session.gc_probability 和session.gc_divisor 參數控制。 傳入到此回調函數的 lifetime 參數由 session.gc_maxlifetime 設置。 此回調函數操作成功返回 TRUE,反之返回 FALSE。
create_sid()
當需要新的會話 ID 時被調用的回調函數。 回調函數被調用時無傳入參數, 其返回值應該是一個字元串格式的、有效的會話 ID。
Ⅶ php session[]能否存數組
php的session可以存儲數組。
問題可能是你的session沒有被保存。
先看看用session保存簡單的字元或數字能不能讀取。
還有一種可能就是你保存和讀取的鍵值不一致。