重写session的存储机制

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: 表示用户自定义!

 

 

点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部