• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

修改Session存放方式为MySQL的类

mysql 搞代码 4年前 (2022-01-09) 14次浏览 已收录 0个评论

lt;?php/*** 修改session存放方式为Mysql Aboc QQ:9986584*/class Session{//过期时间private $_LEFT_TIME = 1440;public funct

<?php
/**
* 修改session存放方式为Mysql Aboc QQ:9986584
*/

class Session{

//过期时间
private $_LEFT_TIME = 1440;

public function open() {


}

public function close(){

}

/**
* 读
*/
public function read( $sessid ) {
$sql = “select data from dm_session where sessid =’$sessid’ and expiry > time本文来源gao.dai.ma.com搞@代*码#网()”;
$row = DMmysql::open()->fetchRow( $sql );
return $row[‘data’];
}

/**
* 写
*/
public function write( $sessid , $sessdata ) {
$data = array(
‘expiry’ => time()+ $this->_LEFT_TIME,
‘data’ => $sessdata,
‘ip’ => ‘192.168.1.123’
);
if( DMmysql::open()->fetchRow(“select sessid from dm_session where sessid =’$sessid'”) ) {
//更新
$where = “sessid = ‘$sessid'”;
if( DMmysql::open()->update( ‘dm_session’,$data,$where ) ){
return true;
} else {
return false;
}
} else {
//插入
$data[‘sessid’] = $sessid;
if( DMmysql::open()->insert(‘dm_session’,$data) ){
return true;
} else {
return false;
}
}
}

/**
* 指定销毁
*/
public function destroy( $sessid ) {
$where = “sessid = ‘$sessid'”;
if(DMmysql::open()->delete(‘dm_session’,$where)) {
return true;
} else {
return false;
}
}

/**
* 销毁过期的数据
*/
public function gc( $maxlifetime ) {
//随机销毁数据,减轻服务器压力
if( rand(0,3) == 3 ) {
$where = “expiry < time()";
if( DMmysql::open()->delete(‘dm_session’,$where) ) {
return true;
} else {
return false;
}
}
}

}

$session = new Session();
session_set_save_handler(
array(&$session,’open’),
array(&$session,’close’),
array(&$session,’read’),
array(&$session,’write’),
array(&$session,’destroy’),
array(&$session,’gc’)
);
session_start();
?>


在每个使用session的文件前include一下就行了

数据库:

CREATE TABLE `dm_session` (
`sessid` char(32) NOT NULL default ”,
`expiry` int(10) NOT NULL default ‘0’,
`data` text NOT NULL,
`ip` char(15) NOT NULL default ”,
PRIMARY KEY (`sessid`),
KEY `sesskid` (`sessid`,`expiry`)
) ENGINE=MyISAM DEFAULT CHARSET=gbk;


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:修改Session存放方式为MySQL的类
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址