PHP session会话操作技巧小结
php  /  管理员 发布于 7年前   166
本文实例总结了PHP session会话操作技巧。分享给大家供大家参考,具体如下: 会话技术 session 将会话数据存储与服务器端,同时使会话数据可以区分浏览器 php.ini: session_start(); 增删改查都是使用$_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数据 实现: 定义自定义的相关的存储处理函数 session机制: 共需六个存储处理函数 begin、end、read、write、del、gc(垃圾回收) 需要在session_start()前使用 session 与 cookie 联系 都是会话技术的实现 差异 session数据持久化 浏览器端 session-id 服务器端 session数据区 cookie禁用 常规情况下,cookie禁用,session不能使用 技术上可以通过get或者post方式向服务器携带session-id 更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP中cookie用法总结》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《PHP运算与运算符用法总结》、《php面向对象程序设计入门教程》、《PHP网络编程技巧总结》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》 希望本文所述对大家PHP程序设计有所帮助。
为每个会话数据建立独立的会话数据区(来存储当前会话的全部数据),每个会话数据区存在唯一的标志,同时浏览器端存储该唯一标识配对使用。
响应时给浏览器的session-id值也存储于浏览器端的cookie数据区。session.auto_start = 0
跟操作普通数组一样操作$_SESSION数组,就可以完成对session数据的操作session.save_path = '/temp'
; http://php.net/session.cookie-secure;session.cookie_secure =
; Lifetime in seconds of cookie or, if 0, until browser is restarted.; http://php.net/session.cookie-lifetimesession.cookie_lifetime = 0
; The path for which the cookie is valid.; http://php.net/session.cookie-pathsession.cookie_path = /
; The domain for which the cookie is valid.; http://php.net/session.cookie-domainsession.cookie_domain =
; Whether or not to add the httpOnly flag to the cookie, which makes it inaccessible to browser scripting languages such as JavaScript.; http://php.net/session.cookie-httponlysession.cookie_httponly =
//session_set_cookie_params(有效期,有效路径,有效域,是否仅安全传输连接,是否HTTPOnly);session_set_cookie_paramas(60,'/','me.com',true,true);session_start();
//删除当前会话对应的session数据区并关闭session机制(周期结束后无法持久化)session_destroy();//$_SESSION还是存在的
$_SESSION = array();
session_destroy();unset($_SESSION);setcookie('PHPSESSID',"",time()-1);//PHPSESSID称之为session.name 可通过php.ini配置//可通过session_name()获取当前值; Name of the session (used as cookie name).; http://php.net/session.namesession.name = PHPSESSID
便于web服务器集群共享session数据
将其设置为session机制需要的存储函数(告知session机制,使用我们的函数完成存储处理)session_set_save_handler();
'; $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 booleanfunction ses_gc($maxlifetime){// echo 'gc'; ini_set('session.gc_divisor',2); $sql = 'delete from session_override where last_time
session基于cookieTables cookie session 会话数据存储位置 浏览器端 服务器端 安全性 低 高 数据传输量 大 小 支持会话数据量 有限制 4K 20个 无大小限制 支持数据类型 字符串 ALL session_set_params(3600)
ini_set('session.gc_maxlifetime','3600')
//是否仅仅使用cookie携带session-idini_set('session.use_only_cookies','0');//是否自动采用其它方式自动传session-id,不安全ini_set('session.use_trans_sid','1');
您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号