PHP session会话操作技巧小结
本文实例总结了PHP session会话操作技巧。分享给大家供大家参考,具体如下: 会话技术session 将会话数据存储与服务器端,同时使会话数据可以区分浏览器 为每个会话数据建立独立的会话数据区(来存储当前会话的全部数据),每个会话数据区存在唯一的标志,同时浏览器端存储该唯一标识配对使用。 响应时给浏览器的session-id值也存储于浏览器端的cookie数据区。 php.ini:
增删改查都是使用$_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()前使用 ';
$link = mysql_connect('127.0.0.1','root','root');
mysql_query('set names utf8');
mysql_select_db('session_override');
}
//在session机制关闭时执行的方法,最后一个执行的存储相关操作,用于收尾
function ses_end(){
echo 'end';
return true;
}
//不需要负责反序列化操作,在读取之后脚本自动执行
function ses_read($ses_id){
// echo 'read';
$sql = "select session_content from session where session_id = '$ses_id'";
$res = mysql_query($sql);
if($row = mysql_fetch_assoc($res)){
return $row['session_content'];
}else{
return '';
}
}
//不需要序列化操作,在写入之前脚本会自动执行
function ses_write($ses_id,$ses_con){
// echo 'write';
// echo $ses_id,$ses_con;
$sql = "replace into session values( '$ses_id','$ses_con',unix_timestamp() )";
echo $sql.'';
return mysql_query($sql);
}
//当调用session_destroy()时执行
function ses_del($ses_id){
// echo 'del';
$sql = "delete from session where session_id = '$ses_id'";
return mysql_query($sql);
}
//session.gc_maxlifetime = 1440
//在开启session机制的过程中,有概率地执行垃圾回收机制
//session.gc_probability = 1
//session.gc_divisor = 1000
//@param session.gc_maxlifetime
//return boolean
function ses_gc($maxlifetime){
// echo 'gc';
ini_set('session.gc_divisor',2);
$sql = 'delete from session_override where last_time
session 与 cookie
都是会话技术的实现
session基于cookie
浏览器端 session-id 服务器端 session数据区 常规情况下,cookie禁用,session不能使用 技术上可以通过get或者post方式向服务器携带session-id 更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》、《》及《》 希望本文所述对大家PHP程序设计有所帮助。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |