session 加入mysql库的方法
作者:lqh 发布时间:2024-01-24 02:51:37
我们知道,session是一种会话技术,用来实现跨脚本共享数据或者检测跟踪用户状态。
session的工作原理
(1)当一个session第一次被启用时,一个唯一的标识被存储于本地的cookie中。
(2)首先使用session_start()函数,PHP从session仓库中加载已经存储的session变量。
(3)当执行PHP脚本时,通过使用session_register()函数注册session变量。
(4)当PHP脚本执行结束时,未被销毁的session变量会被自动保存在本地一定路径下的session库中,这个路径可以通过php.ini文件中的session.save_path指定,下次浏览网页时可以加载使用。
session是存放在服务器端的文件里的,因此session有可能因为文件数量过多,会在查询session文件以及读取的时候产生压力。一般我们有三种解决方案
1.使用文件分层(缺点:I/O操作是系统的一个瓶颈,即使分层也不能避免此问题)
2.将session放入数据库
3.将session放在内存中(非关系性数据库)(缺点:对服务器内存要求教高)
随着 session的增加,管理已经不方便。
因此我们选用一个折中的办法,将session存入mysql数据库,也就是我们要讲的重点.
建立一个表管理 session 。
更改 session的存储机制,让 session 不再存在文件中,而是入库。
更该存储机制,只需要在文件中增加函数session_set_save_handler() 便可。
<?php
ini_set("session.save_handler","user");
//session.gc_probability = 1 分子
ini_set("session.gc_probability",1);
//session.gc_divisor = 1000 分母
ini_set("session.gc_divisor",2);
//session.gc_maxlifetime = 1440 垃圾回收时间,session有效期
session_set_save_handler( "open","close","read","write","destroy","gc" );
//连接数据库
function open(){
@$link = mysql_connect('127.0.0.1', 'root', 'root');
mysql_query('set names utf8');
mysql_query('use wangbin');
//<span>open 回调函数类似于类的构造函数, 在会话打开的时候会被调用。
这是自动开始会话或者通过调用 session_start() 手动开始会话
之后第一个被调用的回调函数。 此回调函数操作成功返回TRUE,反之返回FALSE。</span>
}
function close(){
mysql_close();
//<span>close 回调函数类似于类的析构函数。 在 write 回调函数调用之后调用。
当调用 session_write_close() 函数之后,
也会调用 close 回调函数。 此回调函数操作成功返回TRUE,反之返回FALSE。</span>
}
function read($sess_id){
$sql = "select session_data from `session` where session_id = '$sess_id'";
$result = mysql_query($sql);
if($rows = mysql_fetch_assoc($result)){
return $rows['session_data']; }
else{
return '';
}
<ol class="dp-py" start="1"><li class="alt"><span>如果会话中有数据,read 回调函数必须返回将会话数据编码(序列化)后的字符串。 </span></li><li class="alt"><span>如果会话中没有数据,read 回调函数返回空字符串。 </span></li><li class="alt"><span>在自动开始会话或者通过调用 session_start() 函数手动开始会话之后,</span></li><li class="alt"><span>PHP 内部调用 read 回调函数来获取会话数据。 在调用 read 之前,PHP会调用open回调函数。
</span></li><li class="alt"><span>read 回调返回的序列化之后的字符串格式必须与 write 回调函数保存数据时的格式完全一致。</span></li><li class="alt"><span>PHP 会自动反序列化返回的字符串并填充 $_SESSION 超级全局变量。
</span></li><li class="alt"><span>虽然数据看起来和 serialize() 函数很相似, 但是需要提醒的是,它们是不同的。
</span></li><li class="alt"><span>请参考: session.serialize_handler。</span></li></ol>
}
function write($sess_id,$sess_data){
$sql = "insert into `session` (session_id,session_data,session_time) values('$sess_id','$sess_data', now()) on duplicate key update session_data = '$sess_data' , session_time = now()"; //这是为了gc()
return mysql_query($sql);
/*
<span>在会话保存数据时会调用 write 回调函数。 此回调函数接收当前会话ID以及$_SESSION中数据序列化之后的字符串作为参数。
序列化会话数据的过程由 PHP 根据 session.serialize_handler 设定值来完成。</span>
<span>序列化后的数据将和会话 ID 关联在一起进行保存。 当调用 read 回调函数获取数据时,
所返回的数据必须要和传入write回调函数的数据完全保持一致。</span><span>
PHP 会在脚本执行完毕或调用 session_write_close() 函数之后调用此回调函数。
注意,在调用完此回调函数之后,PHP 内部会调用 close 回调函数。 </span>
Note:
<span>PHP 会在输出流写入完毕并且关闭之后 才调用 write 回调函数,
所以在 write 回调函数中的调试信息不会输出到浏览器中。
如果需要在 write 回调函数中使用调试输出, 建议将调试输出写入到文件。</span>
*/
}
function destroy($sess_id){
echo __FUNCTION__;
$sql = "delete from `session` where session_id = '$sess_id'";
return mysql_query($sql);
/*
<span>当调用 session_destroy() 函数,或者调用 session_regenerate_id() 函数并且设置 destroy 参数为 TRUE 时,
会调用此回调函数。此回调函数操作成功返回 TRUE,反之返回 FALSE。</span>
*/
}
function gc($sess_id){
$maxlifetime = ini_set("session.gc_maxlifetime");
echo __FUNCTION__;
$sql = "delete from `session` where now()-session_time > '$maxlifetime' ";
return mysql_query($sql);
/*
<span>为了清理会话中的旧数据,PHP 会不时的调用垃圾收集回调函数。
调用周期由 session.gc_probability 和 session.gc_divisor 参数控制。
传入到此回调函数的 lifetime 参数由 session.gc_maxlifetime 设置。
此回调函数操作成功返回 TRUE,反之返回 FALSE。</span>
*/
}
header("content-type:text/html;charset=utf8");
session_start();
$_SESSION['name']='aa';
//echo session_id();
echo $_SESSION['name'];
总结 session 运行机制:
1. 打开 session 时,语法上执行函数 session_start() ,php 的session 机制读取浏览器端的 cookie,语法上表示为$_cookie['PHPSESSID']。
2. 根据 cookie 找到存储在服务器端的 session数据。
3. 把 session 数据反序列化,赋值给变量 $_SESSION。
4. 之后对变量 $_SESSION 的操作都是对变量的操作,不会更新 session文件。
5. 是否执行了 session_destroy() 函数,如果执行了,那么删除服务器端的session 文件。
6. 脚本结束时,判断是否有 sessin 文件,或者说是否执行过session_destroy() 方法。如果没有执行过,则把 $_SESSION 变量中的数据写入到 session文件中。如果执行过,那么什么也不做.


猜你喜欢
- 之前在比赛的时候需要用Python实现灰色关联分析,从网上搜了下只有实现两个列之间的,于是我把它改写成了直接想Pandas中的计算工具直接计
- 在我们的生活中,只要你睁开眼睛就能看到各种各样的视觉。不同的视觉能给你不同的视觉暗示,同样能给你不同的心理感受。视觉这个话题太泛了,大自然中
- 前言 在tensorflow的官方文档中得卷积神经网络一章,有一个使用cifar-10图片数据集的实验,搭建卷积神经网络倒不难,但是那个ci
- 今天遇到多条件搜索,其中需要用到in查询,但是laravel不支持 [ 'type', 'in', '
- 前段时间因为忙一些其它的事情,分享的有些少,最近学习一下redis在Go语言开发中的应用。一、理论知识Redis是一个开源的、使用C语言编写
- 已经11月了,不知道还有没有人看华强买瓜。。。要把华强卖瓜做成字符视频,总共分为三步读取视频把每一帧转为字符画把字符画表现出来 读
- 方法1: X:\oracle\ora81\bin\wrap iname=XXX oname=XXX 方法2:9i在win2000下使用wra
- ThinkPHP3.1.3版本有一些特性,还是值得关注的,下面来简单说下。1、异常方面的改进新版的ThinkPHP3.1.3重写了异常类Th
- 方法: 使用urlencode函数urllib.request.urlopen()import urllib.requestimport u
- 像素是计算机视觉中图像的重要属性。它们是表示图像 * 定空间中光的颜色强度的数值,是图像中数据的最小单位。图像中的像素总数是高度、宽度和通道的
- 目录与SpringBoot2.0整合 1、核心依赖2、配置文件3、实体类对象4、JPA框架的用法5、封装一个服务层逻辑测试代码块&
- NumPy(Numerical Python) 是 Python 语言的一个扩展程序库,支持大量的维度数组与矩阵运算,此外也针对数组运算提供
- 如图,面对一团糟代码的你~~~真的想说,What F~U~C~K!!!回归正题,我们所要的说的axios的封装和api接口的统一管理,其实主
- 集合(Set)集合是无序和无索引的集合。在 Python 中,集合用花括号编写。实例创建集合:thisset = {"apple&
- 开发动机:最近用手机QQ浏览器下载了一些视频,视频越来越多,占用了手机内存,于是想把下载的视频传到电脑上保存,可后来发现这些视频都是m3u8
- 本文系统的对HTTP Headers进行了简明易懂的阐述,我仅稍作笔记。什么是HTTP HeadersHTTP是“Hypertext Tra
- 一、前言二、爬取观影数据https://movie.douban.com/在『豆瓣』平台爬取用户观影数据。爬取用户列表网页分析为了获取用户,
- 一 . 得到这个对象的实例Connection con ;con = DriverManager.getConnection(url,use
- 目录1. Django简介Django是什么?Django前景Django框架核心2. 设计模式MVT模式3. 开发环境简介4.创建虚拟环境
- 阅读上一篇:打造设计你自己的字体 ⅠMyFonts.com上销售的字体总数已经超过55,000个。现有字体的巨大数量表明了一个事实:我们在设