session高级(session入库)
我们知道,session是一种会话技术,用来实现跨脚本共享数据。
在之前的php会话技术中我们介绍过,session是存放在服务器端的文件里的,因此session有可能因为文件数量过多,会在查询session文件以及读取的时候产生压力。一般我们有三种解决方案
1.使用文件分层(缺点:I/O操作是系统的一个瓶颈,即使分层也不能避免此问题)
2.将session放入数据库
3.将session放在内存中(非关系性数据库)(缺点:对服务器内存要求教高)
因此我们选用一个折中的办法,将session存入mysql数据库,也就是我们要讲的重点,
session入库技术:
要实现session入库,首先我们要了解session 机制:
什么是session机制:
在php中,session可以理解为一套单独的小系统,在该系统中有很多关于session的处理方法,用来解决各种问题,用户只需要在session之外,调用session_start函数(session系统的一个接口)
其他操作都是session系统帮忙去处理

//session入库
//以为修改session机制必须借助session_set_save_handler()函数,该函数需要6个可以调用的回调函数,因此需要创建6个人对应的函数
//1.开启session机制
function sess_open()
{
//开启资源
//连接数据库
mysql_connect('localhost','root','');
mysql_query('set names utf8');
mysql_query('use session');
echo __FUNCTION__,'<br/>';
}
//2.关闭session
function sess_close()
{
//关闭资源
mysql_close();
echo __FUNCTION__,'<br/>';
}
//3.读取session
function sess_read($sess_id)
{
//从数据库读取数据
//根据sess_id(由系统提供)获取数据
//读数据时要过滤掉过期的数据
$expire=time()-ini_get('session.gc_maxlifetime');
$sql="selsct * from session where sess_id='{$sess_id}' and sess_expire>='{$expire}'";
$res=mysql_query($sql);
//得到的是一个数组
if($sess=@mysql_fetch_assoc($res))
{
//得到一个序列化后的字符串
//要进行反序列化,read只负责读取数据,不负责加工数据
return $sess['sess_info'];
}
echo __FUNCTION__,'<br/>';
}
//4.写入session
function sess_write($sess_id,$sess_info)
{
//向数据库中写入数据
$time=time();
$sql="replace into session values('{$sess_id}','{$sess_info}','{$time}')";
mysql_query($sql);
echo __FUNCTION__,'<br/>';
}
//5.销毁session
function sess_destroy($sess_id)
{
$sql="delete from session where sess_id='{$sess_id}'";
return mysql_query($sql);
echo __FUNCTION__,'<br/>';
}
//6.回收session
function sess_gc()
{
//从数据库删除过期的session数据
//判断session是否过期,过期的删除
$expire=ini_get('session.gc_maxlifetime');
//得到最迟的时间,在$expire之前的都是过期的
$expire=time()-$expire;
$sql="delete from session where sess_expire < '{expire}'";
return mysql_query($sql);
echo __FUNCTION__,'<br/>';
}
//使用session_set_save_handler()修改session机制
session_set_save_handler('sess_open','sess_close','sess_read','sess_write','sess_destroy','sess_gc');
//想要使用session,必须要用session_start()来开启
session_start();
$_SESSION['name']='wangqixing';
$_SESSION['age']='23';
//session_destroy();
session高级(session入库)的更多相关文章
- 懒加载session 无法打开 no session or session was closed 解决办法(完美解决)
首先说明一下,hibernate的延迟加载特性(lazy).所谓的延迟加载就是当真正需要查询数据时才执行数据加载操作.因为hibernate当中支持实体对象,外键会与实体对象关联起来.如 ...
- PHP自带Session隐患(session文件独占锁引起阻塞)
PHP自带Session隐患(session文件独占锁引起阻塞) PHP默认的会话处理器是session.save_handler = files(即文件).如果同一个客户端同时并发发送多个请求(如a ...
- PHP session有效期session.gc_maxlifetime的设置方法
PHP(外文名: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言.语法吸收了C语言.Java和Perl的特点,入门门槛较低,易于学习,使用广泛,主要适 ...
- hibernate 管理 Session(单独使用session,不spring)
Hibernate 本身提供了三个管理 Session 对象的方法 Session 对象的生命周期与本地线程绑定 Session 对象的生命周期与 JTA 事务绑定 Hibernate 托付程序管理 ...
- ASP.NET Web Service中使用Session 及 Session丢失解决方法 续
原文:ASP.NET Web Service中使用Session 及 Session丢失解决方法 续 1.关于Session丢失问题的说明汇总,参考这里 2.在Web Servcie中使用Sessio ...
- org.hibernate.LazyInitializationException...no session or session was closed
org.hibernate.LazyInitializationException:failed to lazily initialize a collection of role:cn.its.oa ...
- Apache shiro集群实现 (六)分布式集群系统下的高可用session解决方案---Session共享
Apache shiro集群实现 (一) shiro入门介绍 Apache shiro集群实现 (二) shiro 的INI配置 Apache shiro集群实现 (三)shiro身份认证(Shiro ...
- PHP session有效期session.gc_maxlifetime详解
一个已知管用的方法是,使用session_set_save_handler,接管所有的session管理工作,一般是把session信息存储到数据库,这样可以通过SQL语句来删除所有过期的sessio ...
- HttpContext.Current.Session 和 Session 的区别
Session(会话)通常指一个动作从开始到结束不间断的一个动作. 例如“打电话”,通常是“1.拿起电话--2.拨对方号码--3.对方截图--4.挂机”.这四个步骤从完成到结束组成了一个基本的Sess ...
- session 之session混乱解决方法(转)
知道了session混乱产生的原因之后,也就知道了问题的根源.同时也引出了很多的问题: 1.如何记录住在线人员(这里只有帐号的系统用户,不包括访客): 2.如何限制同一个帐号在同一时间段内只能够登陆一 ...
随机推荐
- 架构之微服务(zookeeper)转
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等.Zookeeper是hadoop的一个子项目,其 ...
- 对比深度学习十大框架:TensorFlow 并非最好?
http://www.oschina.net/news/80593/deep-learning-frameworks-a-review-before-finishing-2016 TensorFlow ...
- 尚硅谷springboot学习9-配置文件值注入
首先让我想到的是spring的依赖注入,这里我们可以将yaml或者properties配置文件中的值注入到java bean中 配置文件 person: lastName: hello age: 18 ...
- Lazarus 0.9.26——UTF8编码副作用
Lazarus 0.9.26中,涉及范围最广的的改变就是所有的的String默认都采用UTF8编码,IDE终于有了完全的UTF8支持,以前在源码编辑器中“吃掉”半个汉字的情况不再出现.对于Linux下 ...
- English Phrases with THE – Linking the TH Sound
English Phrases with THE – Linking the TH Sound Share Tweet Share Tagged With: The Word THE Study En ...
- Learn English like a Baby – How to Sound Native
Learn English like a Baby – How to Sound Native Share Tweet Share Tagged With: tips & tricks Wha ...
- vmware搭建lnmp环境配置域名
找到nginx配置文件,修改server_name 然后找到/etc/hosts文件 修改成如下 之后在Windows本地的C盘的hosts文件中添加解析 好了,这样就可以访问了 通往牛逼的路上,在意 ...
- android事件处理概括
什么是事件处理? 事件处理就是针对用户的一些特定操作,进行相对应的回馈.时间处理也是程序开发中的人机交互的一个非常重要的体现.事件处理中,事件源是事件的起始位. 一.事件处理三要素 事件源——事件—— ...
- 重启虚拟机后,再次重启nginx会报错:[emerg] open() "/var/run/nginx/nginx.pid" failed (2: No such file or directory)
问题: 重启虚拟机后,再次重启nginx会报错: open() "/var/run/nginx/nginx.pid" failed (2: No such file or dire ...
- ./configure: error: the HTTP rewrite module requires the PCRE library解决
./configure: error: the HTTP rewrite module requires the PCRE library解决 有时候,我们需要单独安装nginx,来处理大量的下载 ...