本文实例总结了php session会话操作技巧。分享给大家供大家参考,具体如下:
会话技术
session
将会话数据存储与服务器端,同时使会话数据可以区分浏览器
为每个会话数据建立独立的会话数据区(来存储当前会话的全部数据),每个会话数据区存在唯一的标志,同时浏览器端存储该唯一标识配对使用。
响应时给浏览器的session-id值也存储于浏览器端的cookie数据区。
php.ini:
session_start();
增删改查都是使用$_session完成
跟操作普通数组一样操作$_session数组,就可以完成对session数据的操作
session原理
存储于浏览器端cookie中的session-id,就是一个普通的cookie变量
每个会话生成存储于服务器端的session数据区
默认的以文件的形式存储于服务器系统临时目录下
session数据属性
有效期:一个会话周期
有效路径:整站
有效域:当前域
是否仅安全连接传输:否
是否httponly:否
以上session数据的特征,都是由浏览器cookie中存储的session-id的特征所导致的。可见如果需要改变session数据的属性,则需更改存储session-id的cookie变量phpsessid的属性:
php.ini 存在该属性的设置:
仅安全连接传输:
生命周期:
有效路径:
有效域:
httponly:
如果需要对默认属性进行修改,可通过以下方法:
1. 修改php.ini配置文件;
2. 在脚本中使用 ini_set(key,val) 进行设置配置的修改,仅在设置后的脚本周期内有效,要在 session_start() 前设置完毕;
3. 使用特定功能函数:
session语法问题
session数据可以是任意的类型,因为session数据区的数据就是序列化后存储的。
$_session['']的下标只能是字符串
session_start()前不应存在输出
session数据区
在脚本周期外,持久存储当前会话session数据
在脚本周期内,使用$_session管理session数据
session 销毁
清空session数据
当前相关session的全部数据删除:
重写session存储机制(入库、入内存)
目的:
便于管理大量session数据
便于web服务器集群共享session数据
实现:
定义自定义的相关的存储处理函数
将其设置为session机制需要的存储函数(告知session机制,使用我们的函数完成存储处理)
session机制:
共需六个存储处理函数
begin、end、read、write、del、gc(垃圾回收)
需要在session_start()前使用
session 与 cookie
联系
都是会话技术的实现
session基于cookie
差异
tables
cookie
session
会话数据存储位置
浏览器端
服务器端
安全性
低
高
数据传输量
大
小
支持会话数据量
有限制 4k 20个
无大小限制
支持数据类型
字符串
all
session数据持久化
浏览器端 session-id
服务器端 session数据区
cookie禁用
常规情况下,cookie禁用,session不能使用
技术上可以通过get或者post方式向服务器携带session-id
希望本文所述对大家php程序设计有所帮助。