分类: PHP
2013-12-14 11:54:28
首先创建数据表,MySQL 的 SQL 语句如下:
代码如下 | 复制代码 |
CREATE TABLE `sess` ( `sesskey` varchar(32) NOT NULL default ”, `expiry` bigint(20) NOT NULL default ‘0′, `data` longtext NOT NULL, PRIMARY KEY (`sesskey`), KEY `expiry` (`expiry`) ) TYPE=MyISAM |
sesskey 为 SESSION ID,expiry 为 SESSION 过期时间,data 用于保存 SESSION 数据。
默认情况下 SESSION 数据是以文件方式保存,想要使用数据库方式保存,就必须重新定义 SESSION 各个操作的处理函数。PHP 提供了session_set_save_handle() 函数,可以用此函数自定义 SESSION 的处理过程,当然首先要先将 session.save_handler 改成 user,可在 PHP 中进行设置:
代码如下 | 复制代码 |
session_module_name(‘user‘); ?> |
接下来着重讲一下 session_set_save_handle() 函数,此函数有六个参数:
session_set_save_handler ( string open, string close, string read, string write, string destroy, string gc )
各个参数为各项操作的函数名,这些操作依次是:打开、关闭、读取、写入、销毁、垃圾回收。PHP 手册中有详细的例子,在这里我们使用 OO 的方式来实现这些操作,详细代码如下:
代码如下 | 复制代码 |
define(‘MY_SESS_TIME‘, 3600); //SESSION 生存时长
//使用 COOKIE 保存 SESSION ID 的方式
//将 session.save_handler 设置为 user,而不是默认的 files
if ($MY_SESS_CONN) { //关闭数据库连接
$sql = ‘SELECT data FROM sess WHERE sesskey=‘ . $MY_SESS_CONN->qstr($sesskey) . ‘ AND expiry>=‘ . time();
$qkey = $MY_SESS_CONN->qstr($sesskey);
$sql = ‘DELETE FROM sess WHERE sesskey=‘ . $MY_SESS_CONN->qstr($sesskey);
$sql = ‘DELETE FROM sess WHERE expiry< ‘ . time(); |