天天看點

session存入mysql_探讨如何把session存入資料庫

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一樣的方法使用舊可以了。