2011-07-13 13 views
2

我使用session_set_save_handler()。它工作正常。但是,有時我需要更改用戶的會話數據。我只是預料會議數據傳遞寫功能是這樣內部創建像這樣:什麼樣的序列化使用PHP函數session_set_save_handler的寫入函數?

serialize($_SESSION); 

但他們不是。他們有這種略有不同的格式不是簡單的PHP序列化的數據:

user|a:24:{s:2:"id";s:2:"12";s:5:"email";s:19:...CUT...;}last_activity_time|i:1310535031;logged_everywhere|b:1; 

任何人都知道什麼樣的系列化內部用於序列化的session_set_save_handler $ _SESSION數據寫入功能()?或者甚至更好,如果有一些反序列化和序列化函數可用於處理這些數據?

回答

3

請看看session_decodesession_encode的PHP-Dokumentation。您將在註釋中找到用於反序列化和序列化會話字符串的完整示例。

+0

糟糕,完全錯過了。謝謝你的信息。 – Frodik

0

這是我的2美分這個問題與PHP的內部序列化。它在用戶會話之外不是真正的可分析的。所以當我使用session_set_save_handler()時,我可以將會話數據保存到數據庫,並且在我的寫入方法中,我可以訪問$ _SESSION對象,因此,可以將序列化的$ _SESSION對象保存到我的數據庫,然後讀取或更改它在那裏。唯一的缺點是,如果它被改變了,它不會被修改爲php使用的內部會話數據。

這至少使您可以分析當前用戶的會話數據,但不是對象。

function _write($id, $data) 
{ 
    if ($data == "") 
    { 
     return true; 
    } 

    global $database_connection; 
    global $table_prefix; 

    $clean_data = base64_encode(serialize($_SESSION)); 
    $access = time(); 

    $id = mysql_real_escape_string($id); 
    $access = mysql_real_escape_string($access); 
    $data = base64_encode($data); 

    $sql = "REPLACE 
     INTO " . $table_prefix . "sessions 
     VALUES ('$id', '$access', '$data', '$clean_data')"; 

    return mysql_query($sql, $database_connection); 
}