会话技术-------session技术
使用session将会话数据存储于服务器端,同时使用会话技术可以区分浏览器;
为每个会话数据建立独立的会话数据区(来存储当前会话的全部数据);每一个会话数据区存在唯一的标志;同时浏览器端存储该唯一的标志;做配对使用;seeionID存储于cookie中;sessionID在cookie中就是一个普通变量;
服务器响应的时候,就会设置sessionID到cookie中;




开启session机制:session_start();
在开启session_start()之前,$_SESSION是不能使用的;


增删改查;

设定:

判断:

session的属性:
有效期:默认会话周期结束;
有效路径:默认整站有效;
有效域:默认当前域有效;
是否仅安全连接:默认false;
是否仅为http使用httonly:默认false;
session的属性取决于存储于浏览器端的sessionID的cookie变量;
如果需要更改session数据的属性,其实是更改存储在浏览器端的seessionID的属性;
在php。ini中设置;


更改session属性:


session可以存储任意数据类型(不包含资源),资源不能序列化,资源是php外部的;
session数据区内的数据是序列化后才存储的;
$_SESSION数组的下标只能是字符串类型;
session_start()类似于header();前面不能有输出;
session 数据区的操作:




虽然session销毁了,但是在脚本周期内$_SESSION中还有数据,但是脚本周期结束后,就不会自动写入session数据区了(原因是关闭了session机制);因此下次脚本周期就不能获取session数据了;









创建数据库表存储session数据;

读操作:



删除操作:

调用了session_destroy()销毁 session过程中被调用,才会执行delete;

垃圾回收机制“:
如何识别垃圾数据:
加上最后处理时间的字段:

带时间戳存储:
”


设置垃圾回收机制概率:






如果不对session的存储做处理,session默认是以文件的形式存储的,


项目中的session如数据库:

注意上面的session_set_save_handler()方法中的参数,如果参数是函数时,必须要用数组的形式,如上,数组中的元素位置必须固定;
cookie和session的区别:





是否自动采用其他方法传输sessionID:

默认session的存储路径是tmp临时目录;



配置文件:
在application目录下创建一个config目录;用来配置项目应用程序;
配置文件的内容格式:

一般在框架类中初始化载入配置文件;
static是针对同一个类中所有方法公用;超全局$GLOABALS是针对整个项目,整个项目中都可以使用;

新闻热点
疑难解答
图片精选