導航:首頁 > 編程大全 > 使用資料庫保存session

使用資料庫保存session

發布時間:2023-08-31 08:27:36

A. 怎麼把session存入資料庫,請詳細介紹下,最好有能運行的源碼

bool session_set_save_handler ( string open, string close, string read, string write, string destroy, string gc )

自定義Session存儲方式
函數中一個參數對應一個函數,函數的名稱自定但參數為固定格式,沒有用到也要。

一、open(string save_path, string session_name)為session_start 參數string save_path session存取路徑 string session_name傳遞session id的cookie名字。
function _session_open(string save_path, string name)
{
$db=mysql_connect("localhost","root","123456","ten");
return TRUE;
}

二、close為session_close 無參數
在此對應關閉資料庫,但一般網站中在此一般不要關閉。

三、read(key)為讀取session鍵值。key對應session id。

四、write(key,date)其中的data對應設置的session變數,格式如下:
email_name|s:13:"qq[email protected]";member_id|s:1:"1";

五、destroy(key)注銷session
在此程序段中對應刪除對應記錄項。

六、gc(expiry_time)清除過期session記錄。

表的結構 `session`
--

CREATE TABLE `session` (
`session_key` char(32) NOT NULL,
`session_data` char(255) NOT NULL,
`session_expiry` int(11) unsigned NOT NULL,
PRIMARY KEY (`session_key`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;字元集根據情況更改

<?php
class Session{
var $expiry=3600;
var $db;

function __construct(){
$this->Session();
}

function Session(){
session_set_save_handler( array (& $this, "_session_open"),
array (& $this, "_session_close"),
array (& $this, "_session_read"),
array (& $this, "_session_write"),
array (& $this, "_session_destroy"),
array (& $this, "_session_gc")
);

}

/**
* open session handler
*
* @param string $save_path
* @param string $session_name
* @return boolen
*/
function _session_open($save_path, $session_name)
{
$this->db=mysql_connect("localhost","root","123456") or die("資料庫連接失敗!");
mysql_select_db("ten",$this->db);
return TRUE;
}

function _session_close(){
return true;
}

function _session_read($key){
$expiry=time();
$s_query=sprintf("select session_data from session where session_key= '%s' and session_expiry > %d " , $key, $expiry );
$result=mysql_query($s_query,$this->db);
$row=mysql_fetch_assoc($result);
if($row){
return $row['session_data'];
}
else
return FALSE;
}

function _session_write($key,$data){
$expiry_time=time()+$this->expiry;
$s_query=sprintf("select session_data from session where session_key= '%s'", $key);
$result=mysql_query($s_query,$this->db);
if(mysql_num_rows($result)==0){
$s_query=sprintf("insert into session values('%s','%s', %d)",$key,$data,$expiry_time);
$result=mysql_query($s_query,$this->db);
}
else{
$s_query=sprintf("update session set session_key='%s', session_data='%s',session_expiry=%d where session_key='%s'",$key,$data,$expiry_time,$key);
$result=mysql_query($s_query,$this->db);
}
return $result;
}

function _session_destroy($key){
$s_query=sprintf("delete from session where session_key= '%s'", $key);
$result=mysql_query($s_query,$this->db);
return $result;
}

function _session_gc($expiry_time){
$expiry_time=time();
$s_query=sprintf("delete from session where session_expiry < %d", $expiry_time);
$result=mysql_query($s_query,$this->db);
return $result;
}
}

$_ses_=new Session();
session_start();

$_SESSION['time']=time()+1200;
echo strval(time()).'<br/>'.strval($_SESSION['time']);
?>

B. 急求PHP用戶登錄用mysql資料庫存儲session,並同時且用cookie存儲的完整源程序或類

$gb_DBname="charles_friend";//資料庫名稱
$gb_DBuser="charles_friend";//資料庫用戶名稱
$gb_DBpass="wxyzoui";//資料庫密碼
$gb_DBHOSTname="localhost";//主機的名稱或是IP地址
$SESS_DBH="";
$SESS_LIFE=get_cfg_var("session.gc_maxlifetime");//得到session的最大有效期。
function sess_open($save_path,$session_name){
global $gb_DBHOSTname,$gb_DBname,$gb_DBuser,$gb_DBpass,$SESS_DBH;
if(!$SESS_DBH=mysql_pconnect($gb_DBHOSTname,$gb_DBuser,$gb_DBpass)){
echo "<li>MySql Error:".mysql_error()."<li>";
die();
}
if(!mysql_select_db($gb_DBname,$SESS_DBH)){
echo "<li>MySql Error:".mysql_error()."<li>";
die();
}
return true;
}
function sess_close(){
return true;
}
function sess_read($key){
global $SESS_DBH,$SESS_LIFE;
$qry="select value from db_session where sesskey = '$key' and expiry > ".time();
$qid=mysql_query($qry,$SESS_DBH);
if(list($value)=mysql_fetch_row($qid)){
return $value;
}
return false;
}
function sess_write($key,$val){
global $SESS_DBH,$SESS_LIFE;
$expiry=time()+$SESS_LIFE;
$value=$val;
$qry="insert into db_session values('$key',$expiry,'$value')";
$qid=mysql_query($qry,$SESS_DBH);
if(!$qid){
$qry="update db_session set expiry=$expiry, value='$value' where sesskey='$key' and expiry >".time();
$qid=mysql_query($qry,$SESS_DBH);
}
return $qid;
}
function sess_destroy($key){
global $SESS_DBH;
$qry="delete from db_session where sesskey = '$key'";
$qid=mysql_query($qry,$SESS_DBH);
return $qid;
}
function sess_gc($maxlifetime){
global $SESS_DBH;
$qry="delete from db_session where expiry < ".time();
$qid=mysql_query($qry,$SESS_DBH);
return mysql_affected_rows($SESS_DBH);
}
session_mole_name('user');
session_set_save_handler("sess_open","sess_close","sess_read","sess_write","sess_destroy","sess_gc");
session_start();

C. session 存入資料庫有什麼好處

控制一個帳號只能一個人登錄
統計在線人數
踢出某個在線用戶
多站點共享session

支持伺服器斷電和重啟

D. 如何把session存入資料庫

可通過jsp頁面上的<input type="text" name="user"/>的name屬性值獲取用戶名.
String name=(String)session.getAttribute("user");
然後就把取得的值封裝到User類裡面
再用JDBC保存user的對象就可以了!

閱讀全文

與使用資料庫保存session相關的資料

熱點內容
百信集團的網站叫什麼名字 瀏覽:67
開發解壓app理念是什麼 瀏覽:128
linux源代碼路徑 瀏覽:854
美圖2root後不能升級了 瀏覽:133
shell文件size 瀏覽:350
通過大數據查幹部哪些內容 瀏覽:78
如何編程輸出一個數的十位數 瀏覽:760
9月7日蘋果發布會 瀏覽:150
u盤里文件打開都是亂碼怎麼辦 瀏覽:402
文件管理里可以復制 瀏覽:60
怎麼斷數據源 瀏覽:371
linux文件夾遞歸賦權 瀏覽:103
阻止U盤寫入特定後綴文件 瀏覽:8
車載gps埠檢測工具 瀏覽:244
多重網路取消合並 瀏覽:876
哪個APP看電影刪減的少 瀏覽:160
蘋果6進水讀不了卡什麼原因 瀏覽:68
網盤文件怎麼提取到筆記軟體里 瀏覽:136
java解析簡單json數據類型 瀏覽:750
008神器破解版使用教程 瀏覽:974

友情鏈接