最新下载
热门教程
- 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(); |
|
相关文章
- Take-Two CEO对《BioShock 4》的延期表示“深感失望” 05-07
- 红果剧场免广告入口-红果短剧vip会员无广告版地址 05-07
- 109偃师技能搭配攻略(解锁终极技巧,让你成为顶级偃师!) 05-07
- 战神5同伴技能选择攻略(绝对胜利!无敌阵容一网打尽) 05-07
- 蛋仔派对秒玩链接-蛋仔派对秒玩入口最新 05-07
- 忘却前夜免费五抽选择推荐指南 05-07