zoukankan
html css js c++ java
关于Cookie与Session的疑问解答
1、会话cookie
如果不设置过期时间,则表示这个cookie生命周期为浏览器会话期间,
只要关闭浏览器窗口,cookie就消失了
。这种生命期为浏览会话期的cookie被称为
会话cookie
。会话cookie一般不保存在硬盘上而是保存在内存里。
如果设置了过期时间,浏览器就会把cookie保存到硬盘上,关闭后再次打开浏览器,这些cookie依然有效直到超过设定的过期时间。
存储在硬盘上的cookie可以在不同的浏览器进程间共享,比如两个IE窗口。而对于保存在内存的cookie,不同的浏览器有不同的处理方式。
2、关于SeesionID与Session的生命周期
当你第一次访问一个网站的时候,网站服务器会在响应头内加上Set-Cookie:PHPSESSID=nj1tvkclp3jh83olcn3191sjq3(php服务器),或Set-Cookie
JSESSIONID=nj1tvkclp3jh83olcn3191sjq3(java服务器)信息,
此信息是服务器随机生成的,放在服务器内存里,
为了标识唯一的客户端用户,内容不会重复,这就是sessionid.
当浏览器得到这个sessionid会将它放在自己的进程内存里
,这里不同的浏览器会有所不同,IE进程间不能共享这个sessionid,也就是新开一个
IE将不能共享
这个sessionid;而
Firefox进程间可以共享.然后你继续发请求给这个网站的时候,浏览器就会把这个sessionid放在请求头里发送给该服务器了,这样服务器得到sessionid后再
和自己内存里存放的
sessionid对比
锁定客户端,从而区分不同客户端,完成会话.
可以看出如果用这种方式,当用户在会话的过程中关闭浏览器结束进程,则这个sessionid将消失,如果用户又打开浏览器想继续这次会话的时候,就会因为发送的请求中没有这个
sessionid而使服务器无法辨别该把那个session信息给他,注意(
这个时候服务器端的sessionid和sessionid所指向的session都还存在,只是没有正确的sessionid和它匹配而占用服
务器内存
,
只有session过期或服务器重启才释放内存
).
上面这种方式叫会话cookie,把cookie放在浏览器内存里,只能在这个浏览器的内存范围里完成会话,是一种不长久的方式,为了能长久会话,就出现了持久化cookie,把cookie固
化在用户的计算机上,现在的cookie不单单能存放sessionid,还能放用户信息,样式表信息等.
如果用户禁止了所有cookie的使用,那么会话cookie和持久化cookie都不能用了,有个方案也可以解决问题,就是URL重写,这里要说下的就是URL重写只能实现会话cookie的效果,持久会话实现不了.
查看全文
相关阅读:
使用Linq to Sqlite 出现异常Object already attached
CSS 嵌套DIV布局
《面试笔记》——MySQL终结篇(30问与答)
PotPlayer播放器下载
博客圆的RSS怎么不能用呢
OPC在自控系统的应用
TAPI的使用
刷iPAQ为Linux(zz HiPDA)
再论软工
Silverlight的大小自适应中存在的一个问题
原文地址:https://www.cnblogs.com/smallstone/p/1773803.html
最新文章
音乐API
Android VCard联系人备份恢复(导入/导出)详解
struts.properties
Android 桌面同步显示歌词
Windows核心编程读书笔记之通过消息传递句柄
ubuntu 11.04安装vmware tools找不到C Header Files的问题
Windows 7下阻止系统关机
Windows核心编程读书笔记之通过命令行传递句柄
VS2005的一个关于调试的bug
递归优化——尾递归果然给力
热门文章
Windows核心编程读书笔记之ErrorLookup
Javascript获取IFrame内容(兼容IE&FF)
网站性能优化笔记JS
.net 4下引用低版本.net类库发生异常的解决方案
在数据库‘master’中拒绝CREATE DATABASE权限 的问题
WPF使用Linq 一行代码搞定数据绑定
WPF获取窗口句柄
SAPI使用总结——SpVoice的使用方法
Android 游戏开发中横竖屏切换问题
CSS 控制div在页面中水平垂直居中
Copyright © 2011-2022 走看看