最新下载
热门教程
- 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(); |
|
相关文章
- 超星学生登录入口-超星学习通一键登录 01-30
- 赛氪大英赛报名入口-赛氪竞赛官网首页速点 01-30
- 抖币充值官网入口-抖音抖币充值官网直通 01-30
- j站(Jable)网页版登录入口地址-j站(Jable)海外版国际站网页登录入口地址 01-30
- 奇漫屋在线看漫画:海量国漫日漫全库,每日准时连载更新 01-30
- 无广告漫画app排行榜2026-免费无广告漫画app推荐 01-30