有关session的数据库存储类
来源:互联网 发布:github搜索源码 编辑:程序博客网 时间:2024/06/05 19:43
session的数据库存储类 本人用的是pear的DB库
有关session的存储过程:
当增加一条记录时,先是从read函数读取session_id
然后才调用write函数,开始先判断是否有这个id,如果有就执行update,如果没有就执行insert操作,
讲了这些大家可以对session的操作会多了解一点,如果哪里讲的不好,请大家指正。
CREATE TABLE `session` (
`session_id` varchar(32) binary NOT NULL default '''',
`updated_on` int(10) unsigned NOT NULL default ''0'',
`session_data` text,
`session_ip` varchar(15)
PRIMARY KEY (`session_id`)
) TYPE=InnoDB;
class Session
{
// --- ATTRIBUTES ---
/**
* Short descrīption of attribute db
*
* @access private
*/
private $db;
private $life;
// --- OPERATIONS ---
public function __construct()
{
// get session-lifetime
$this->life = get_cfg_var("session.gc_maxlifetime");
//将 session.save_handler 设置为 user,而不是默认的 files
session_module_name(''user'');
// section -64--88-0--25--4853ec1c:108dbfe7d30:-7fec end
} // end function
public function open($savePath, $sessName)
{
require_once ''DB.php'';
$this->db = DB::connect("mysql://root:test@127.0.0.1/test");
if(!$this->db)
return false;
return true;
} // end function
public function close()
{
return $this->db->disconnect();
} // end function
public function read($key)
{
$key = $this->db->quoteSmart($key);
$time = time();
$strsql = "select `session_data` from session where `session_id` = $key and `updated_on` > $time";
$result = $this->db->getOne($strsql);
if (DB::isError($result)) {
//Must return "" because php.net says so
return "";
} else {
return $result;
}
//Something slipped through the cracks, so throw an error
return "";
}// end function
public function write($key, $data)
{
$key = $this->db->quoteSmart($key);
$value = $this->db->quoteSmart($data);
$ip = $_SERVER[''REMOTE_ADDR''];
$expiry = time() + $this->life; //设置过期时间
$strsql = "SELECT `updated_on` FROM session WHERE `session_id`=$key";
$result = $this->db->getOne($strsql);
if ($result === null) {
$strsql = "INSERT INTO session (`session_id`, `updated_on`, `session_data`, `session_ip`) VALUES ($key, ''$expiry'', $value, ''$ip'')";
$result = $this->db->query($strsql);
if (DB::isError($result)) {
//error of some sort
return false;
}
return true;
} else {
$strsql = "UPDATE session SET `updated_on`=$expiry, `session_data`=$value WHERE `session_id`=$key";
$result = $this->db->query($strsql);
//Something went wrong
if (DB::isError($result)) {
return false;
}
return true;
}
//Something slipped through, so throw an error
return false;
} //end function
public function destroy($key)
{
$key = $this->db->quoteSmart($key);
$strsql = "DELETE FROM session WHERE `session_id`=$key";
$result = $this->db->query($strsql);
if (!DB::isError($result)) {
return true;
}
return false;
} // end function
public function gc($maxlifetime)
{
$time = $this->db->quoteSmart(time());
$strsql = "DELETE FROM session WHERE `updated_on` < $time";
$result = $this->db->query($strsql);
if (DB::isError($result)) {
return 0;
}
$strsql = ''OPTIMIZE TABLE session'';
$result = $this->db->query($strsql);
if (DB::isError($result)) {
return 0;
}
return $this->db->affectedRows();
} // end function
} /* end of class Session */
$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();
?>
那个页面需要用的是时候,include就可以了
我连测试用例也贴出来,我们用的是smarty,smarty配置我就不说了,自己到我前面发表的文章看看吧
session_php.htm 代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
</head>
<body>
<h1>Session Test scrīpt</h1>
<ul>
<li>Action: <b><%$action%></b>
<li>Count: <b><%$count%></b>
</ul>
<hr size=1>
<form method="post" name="frm">
<table>
<tr>
<td>
<select name="action">
<option value="increment">Increment</option>
<option value="destroy">Session Destroy</option>
<option value="gc">Force Garbage Collection</option>
</select>
</td>
</tr>
<tr>
<td></td>
<td><br><input type="submit" value="提交"></td>
</tr>
</table>
</form>
</body>
</html>
session_test.php 代码如下:
<?php
require_once(''include.inc.php'');//此文件以前文章有,大家可以看看
require_once(''session.inc.php'');//这个是我上面类的文件名
session_start();
$result = '''';
$action = '''';
if ($_SERVER[''REQUEST_METHOD''] == "POST") {
$action = $_POST[''action''];
switch ($action) {
case "increment":
$_SESSION[''num''] += 1;
$result = $_SESSION[''num''];
break;
case "destroy":
session_destroy();
break;
case "gc":
$maxlife = get_cfg_var("session.gc_maxlifetime");
$session->gc($maxlife);
break;
}
}
$tpl->assign("action", $action);
$tpl->assign("count", $result);
$tpl->display("session_test.htm");
?>
- 有关session的数据库存储类
- 有关数据库存储过程编写的经验总结
- 有关数据库存储过程编写的经验总结
- Oracle数据库和session等待事件有关的几个视图
- session 数据库存储
- 有关session的知识点
- sql数据库有关系统表,存储过程,函数的介绍
- 【thinkphp3.2.x】thinkphp3.2.x中有关session存储机制的相关文件
- 【thinkphp3.1.x】thinkphp3.1.x中有关session存储机制的相关文件
- 数据库中存储Session信息
- 使用数据库的方式来自定义存储用户session信息
- 有关Session的作用范围
- 有关SESSION丢失的原因
- 有关Session的一些术语
- 有关Session超时的问题!
- 有关Session的一点总结
- 有关Session的相关问题
- Hibernate中的Session的refresh()方法执行效果与数据库的隔离级别有关
- asp.net 2.0 Login控件 系列 入门
- java数据库连接
- js实现页面跳转的几种方式
- TokenProcessor 同步令牌源码,极具参考价值
- JavaScript页面跳转常用代码
- 有关session的数据库存储类
- linux 从命名
- 定制JList显示
- 经典:单件模式(Singleton Pattern)
- 动力的来源
- 把从其他系统传过来的自开放程序重置为orginal
- 技巧:删除表中重复数据的几种方法
- 只运行一个实例程序
- ASP.net动态调用非托管DLL的参数传递问题