最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
PHP 实现多服务器共享 SESSION 数据
时间:2022-06-24 18:09:48 编辑:袖梨 来源:一聚教程网
代码实现
首先创建数据表,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(); |
|
相关文章
- 燕云十六声墨城见闻任务怎么完成 06-27
- 失控进化手游天赋如何搭配 06-27
- 修真高手手游将臣玩法指南 修真高手手游将臣角色培养与实战技巧详解 06-27
- 修真高手手游路西法玩法攻略 修真高手手游路西法角色强度与技能连招解析 06-27
- 《007 First Light》的Switch 2版本不会像《无主之地4》那样销声匿迹 06-27
- 驾校一点通如何绑定驾校 06-27