php的session預設的情況下是采用的檔案方式來儲存的,我們在php的配制檔案php.ini中可以看到這樣的一行,session.save_handler="files",這樣的意思就是采用檔案來儲存session 的,要采用資料庫來儲存的話,我們需要修改成擁護模式,改稱 session.save_handler="use"就可以了,但是,這僅僅是說明我門沒有采用檔案的方式存儲session,我們還要選擇資料庫和建立資料庫的表。
建立資料庫和資料庫的表結構,我們可以采用php可以使用的任何的資料庫,因為php和mysql的結合最好,我就使用mysql來做事例,當然根據你的需要可以改稱别的資料庫,同時因為mysql沒有事物的功能,這也比别的資料庫更快,然而儲存session 書、一 不許要事物處理的,再者裡我決的更好。
建立資料庫:
CREATE DATABASE 'session'; 建立表結構 CREATE TABLE 'session'( id CHAR(30) NOT NULL , 'user 'CHAR(30), data CHAR(3000) ,PARMIRY BY ('id') );
下面我們來編寫儲存session的檔案session_start.php
$con =mysql_connection("127.0.0.1","user" , "pass");
mysql_select_db("session");
function open($save_path, $session_name)
{
return(true);
}
function close()
{
return(true);
}
function read($id)
{
if($result = mysql_query("SELECT * FROM session WHERE id='$id'"))
{
if($row = mysql_felth_row($result ))
{ return $row["data"]; }
}
else
{
return "";
}
}
function write($id, $sess_data)
{
if($result = mysql_query("UPDATE session SET data='$sess_data' WHERE id='$id'"))
{
return true;
}
else
{
return false;
}
}
function destroy($id)
{
if($result = mysql_query("DELETE * FROM session WHERE id='$id'"))
{
return true;
}
else
{
return false;
}
}
function gc($maxlifetime)
{
return true;
}
session_set_save_handler("open", "close", "read", "write", "destroy", "gc");
session_start();
// proceed to use sessions normally
?>
現在我們的工作就已經完成了,隻要你在需要在使用session的時候,把session_user_start.php。包含進來,
注意,這個檔案一定要在檔案的第一行包含,然後就想使用檔案的session一樣的方法使用舊可以了。