重写session的存储机制 转自 http://www.cnblogs.com/bc8web/p/5699935.html

Session数据区

  默认以 文件的形式存储与服务器操作系统临时目录中!

当 session数据区过多时,文件形式的存储,操作速度变慢。磁盘的读写(IO,input/output)开销是很大的。

实际项目中,都会采用其他的方式更快地存储session数据。典型的办法:数据库,内存。

以 数据库存储为例,讲解:session数据入库!

重写 与 session数据区直接的相关操作即可:

最基本的只有2个:读,写!

一:定义2个可以完成读和写的函数。

二:告知session机制,在需要读写时,使用用户自定义的读写函数完成。

定义2(其实共6个需要的相关函数)个可以完成读和写的函数

告知session机制,需要读写时,使用用户自定义的读写函数完成

Session_set_save_handler(

开始函数,结束函数,读函数,写函数,删除函数,GC函数

);

用来将用户自定义的函数,设置成session存储相关的函数。

以上的语法,仅仅是设置告知,不是调用以上6个函数,这六个函数,在session机制运行到某个时间点时,才会被调用!例如,咋开启session时,才需要调用sessRead()

常规使用session

开启session机制

操作$_SESSION

创建session表

该session中,每条记录,就是一个session数据区,相当于原来的一个session文件。

表结构:

读操作:sessRead()

  谁调用,谁传参!

在PHP的session机制调用该函数时,会将当前的session-ID作为参数传递到函数中:

因此,需要定一个形参,接受传递的session-ID 参数:

需要返回,读取到的session数据字符串。就是sess_content字段的内容。如果没有读到,则返回空字符串即可,表示没有session数据。

写操作:sessWrite()

当PHPsession机制调用该函数执行写操作时,会将 当前session-ID和 需要写入的内容(序列化好的)传递到函数!

需要2个形参来接收:

测试:

删除操作:sessDelete()

销毁session时。

执行了PHP函数:

Session_destroy();

可以销毁session,删除对应的session数据区,同时关闭session机制!

由于需要删除session数据区,需要增加用于删除的方法:

PHP的session机制,在调用sessDelete时,会传递 当前session-ID作为参数:

需要定义形参来接收:

垃圾回收操作:sessGC()

  垃圾:服务器上过时的session数据区。、

垃圾如何判定?

  如果一个session数据区已经超过多久没有使用(最后一次写操作)了,就是被视为垃圾数据。

该时间临界点:默认1440s。可以被配置:

  配合最后写入时间,就可以断定是否为垃圾

需要增加字段,记录最后写入时间。

  写入时,更新该字段:

sessWrite();

判断条件:过期

Last_write < 当前时间-1440

如何删除?

  在 session_start()过程中,开启session机制过程中:有几率地执行 垃圾回收操作。一旦执行,就会删除所有的过期的垃圾数据区。

默认的概率为1/1000。

可以设置该几率:

可能性:

基数(除数):

调整几率测试:

建议在脚本周期调整,使用函数ini_set(),在开启session机制前完成:

实现 sessGC()

PHP的session机制将 最大有效期作为参数,传递过来!

开始操作sessBegin():

初始化工作

可保证在第一个执行。将初始代码,在sessBegin完成:

例如初始化数据库连接:

结尾操作sessEnd():

收尾性工作

Return true;

语法细节

先设置在开启session机制

Session_set_save_handler()先于session_start()被调用。

不要自动开启session!php.ini: session.auto_start = 0

PHP配置项:session.save_handler

PHP所使用的存储机制:

最后建议,将以上配置改为 user: 表示用户自定义!

php 重写session的更多相关文章

  1. php重写session的存储机制

    重写session的存储机制 Session数据区 默认以 文件的形式存储与服务器操作系统临时目录中! 当 session数据区过多时,文件形式的存储,操作速度变慢.磁盘的读写(IO,input/ou ...

  2. 重写session

    <?php ini_set('session.use_only_cookies', 0); $session_id = rand(10000, 99999); session_set_cooki ...

  3. 理解Cookie和Session机制(转)

    目录[-] Cookie机制 什么是Cookie 记录用户访问次数 Cookie的不可跨域名性 Unicode编码:保存中文 BASE64编码:保存二进制图片 设置Cookie的所有属性 Cookie ...

  4. 10 Cookie/Session

    JSP/EL入门     * SUN提供了开发WEB资源的技术     Servlet/JSP              * response.getWriter().write();         ...

  5. 基于ZooKeeper的分布式Session实现(转)

    1.   认识ZooKeeper ZooKeeper—— “动物园管理员”.动物园里当然有好多的动物,游客可以根据动物园提供的向导图到不同的场馆观赏各种类型的动物,而不是像走在原始丛林里,心惊胆颤的被 ...

  6. JavaWeb-10(会话技术之session&amp;JSP)

    JavaWeb-会话技术之session&JSP 会话管理之Session技术 一.Session 在WEB开发中,server能够为每一个用户浏览器创建一个会话对象(session对象),注 ...

  7. 会话—session

    这篇随笔是上一篇的姊妹篇@_@! session       在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下) ...

  8. 基于ZooKeeper的分布式Session实现

    1.   认识ZooKeeper ZooKeeper—— “动物园管理员”.动物园里当然有好多的动物,游客可以根据动物园提供的向导图到不同的场馆观赏各种类型的动物,而不是像走在原始丛林里,心惊胆颤的被 ...

  9. 会话技术cookie和session详解

    什么是会话 会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. 会话技术解决了什么问题 每个用户与服务器进行交互的过程中,各自会有一 ...

随机推荐

  1. Linux命令-目录处理命令:mkdir

    mkdir /tmp/beijing mkdir -p /tmp/shijiazhuang/yuhuaqu 一条命令可以同时创建父目录和子目录 mkdir /tmp/beijing/chaoyangq ...

  2. 【ASP.NET MVC系列】浅谈MVC

    描述 本篇文章主要概述ASP.NET MVC,具体包括如下内容: 1.MVC模式概述 2.WebForm概述 3.WebForm与MVC区别 4.ASP.NET MVC发展历程 5.运用程序结构 6. ...

  3. Java Persistence with MyBatis 小结1

    数据持久层做的工作是1)将从数据库中查询到的数据生成需要的java对象:2)将 Java 对象中的数据通过 SQL 持久化到数据库中. MyBatis 通过抽象底层的 JDBC 代码,自动化 SQL ...

  4. 从JSON数据中取出相关数据

    参考: http://www.cnblogs.com/shuilangyizu/p/6019561.html JSON数据如下: { "total": 1, "rows& ...

  5. mysql 字面值

    mysql 数据库中实现了许多的数据类型.通常我们用的最多的是在建表的时候指定列的数据类型 如:brithday date default '2000-01-01' 那么我们如何给字面值(直接量)指定 ...

  6. X86平台简称

    1.PCH:PCH全称为Platform Controller Hub,是intel公司的集成南桥.AMD SB700/710/750  http://support.amd.com/TechDocs ...

  7. oracle 使用occi方式插入数据时中文乱码

    这个是由于数据库的编码格式和我们输入的编码格式不一致导致的. 我们使用c++插入数据时数据库的中文显示??(即乱码),但同样的数据使用navicat进行插入却显示正常. 因此,问题并不是处在服务器端的 ...

  8. 记一次线上MySQL数据库死锁问题

            最近线上项目报了一个MySQL死锁(DealLock)错误,虽说对业务上是没有什么影响的,由于自己对数据库锁这块了解不是很多,之前也没怎么的在线上碰到过.这次刚好遇到了,便在此记录一下 ...

  9. 设置open_cursors参数

    1.进入终端,输入命令:sqlplus /nolog 2.输入命令:conn /as sysdba 3.输入命令:alter system set open_cursors=1000 scope=me ...

  10. 基于 jQuery支持移动触摸设备的Lightbox插件

    Swipebox是一款支持桌面.移动触摸手机和平板电脑的jquery Lightbox插件.该lightbox插件支持手机的触摸手势,支持桌面电脑的键盘导航,并且支持视频的播放. 在线预览   源码下 ...