当前位置:首页 > 开发 > 互联网 > 正文

会话状态保持,JSESSIONID,COOKIE之间的关系

发表于: 2012-12-06   作者:一炮送你回车库   来源:转载   浏览:
摘要: 在服务器端,我们用惯了session.setAttribute("",userInfo)这样的一行代码,估计你很少想到:服务器与浏览器之间是如何保持会话状态的。好了,先引用一些文章的精彩片段:http://www.xxx.com/xxx_app;jsessionid=xxxxxxxxxx?a=x&b=x。这跟一般的url基本一样,只有一个地方有区别,那就是“;je

在服务器端,我们用惯了session.setAttribute("",userInfo)这样的一行代码,估计你很少想到:服务器与浏览器之间是如何保持会话状态的。好了,先引用一些文章的精彩片段:
http://www.xxx.com/xxx_app;jsessionid=xxxxxxxxxx?a=x&b=x

这跟一般的url基本一样,只有一个地方有区别,那就是“;jessionid=xxxxxxxx”。这个参数有时候有,有时候又没有,说它是参数可又跟一般传递的参数不同,它是紧跟在url后面用分号来分隔的 ,用一般的request.getParameter()方法还取不到jsessionid
启动你的tomcat,打开FireFox(爱得不得了,一定要安装FireBug),输入localhost就行,打开firebug,点网络,你会看到,浏览器与服务器会话的信息,给出浏览器
(1)
第一次请求服务器:
浏览器的请求头信息

Host

localhost

User-Agent

Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.2.6) Gecko/20100625 Firefox/3.6.6

Accept

text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8

Accept-Language

zh-cn,zh;q=0.5

Accept-Encoding

gzip,deflate

Accept-Charset

GB2312,utf-8;q=0.7,*;q=0.7

Keep-Alive

115

Connection

keep-alive
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->

服务器响应头信息

Server

Apache-Coyote/1.1

Set-Cookie

JSESSIONID=64D21B4D69DFB3041B6375C1932BD6CB; Path=/

Content-Type

text/html;charset=UTF-8

Content-Language

zh-CN

Content-Length

242

Date

Mon, 28 Jun 2010 02:35:29 GMT

(2)第二次请求服务器:
浏览器的请求头信息

Host

localhost

User-Agent

Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.2.6) Gecko/20100625 Firefox/3.6.6

Accept

text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8

Accept-Language

zh-cn,zh;q=0.5

Accept-Encoding

gzip,deflate

Accept-Charset

GB2312,utf-8;q=0.7,*;q=0.7

Keep-Alive

115

Connection

keep-alive

Cookie

JSESSIONID=64D21B4D69DFB3041B6375C1932BD6CB

服务器响应头信息

Server

Apache-Coyote/1.1

Content-Type

text/html;charset=UTF-8

Content-Language

zh-CN

Content-Length

242

Date

Mon, 28 Jun 2010 02:37:51 GMT

重复第三次,每四次...N次请求服务器,浏览器和服务器的请求头信息都是与第二次请求服务器是一样的。

(3)
但是,如果你在服务器端加入如下一行代码:
Log.info("SessionId:" + request.getSession().getId());
你会看到,当你第一次请求服务器时,就会默认有一个新的session被创建,而且在session的有效时间范围内,这个输出值是不会变的,否则,服务器会重新创建一个session,自然,sessionId也就不同了,这段代码的输出自然也会不同了。

(4)
你必须注意这一点:你用的是浏览器与服务器通信:
有一些事情是浏览器帮助我们去做了,那就是:当你第一次与服务器通信时,浏览器会保存服务器返回的 Set-Cookie 这个健的值( JSESSIONID=64D21B4D69DFB3041B6375C1932BD6CB ),只要你不关闭浏览器(彻底关闭,关闭选项卡不算),浏览器会从第二次向服务器发出请求开始,一直带上这个键值对,发给服务器。服务器就会知道,这是同一个人(同一个会话)发起的请求。

(5)
我们再注意一下:request.setAttribute("sysuser",userInfo)这句话:
当你第一次请求服务器时,这句代码会根据服务器默认产生的session得到ID,并与sysuser=userInfo这个键值对挂上钩(当然,userInfo可以是任何对象),保证唯一关联,检测用户是否登录就是这样实现的。
我一定要声明一点:保持一个会话与用户是否登录是没有任何关系的。

 

 

转自:http://www.g4studio.org/forum.php?mod=viewthread&tid=275

会话状态保持,JSESSIONID,COOKIE之间的关系

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
会话Cookie及session的关系(Cookie & Session) 在通常的使用中,我们只知道session信息是存放在服务
我们知道web网站在客户端存储数据有三种形式:1. Cookie 2. hidden(隐藏域) 3.QueryString 其中vi
我们知道web网站在客户端存储数据有三种形式:1. Cookie 2. hidden(隐藏域) 3.QueryString 其中vi
cookie、session、sessionid 与jsessionid,要想明白他们之间的关系,下面来看个有趣的场景来帮你理
Session,Cookie,jsessionid和Url重写 故障描述: 人员管理系统(A)内嵌到权限系统(B),B系统通
发布日期 : 4/1/2004|更新日期 : 4/1/2004 Billy Yuen Microsoft Corporation 2003 年 2 月 适用于
如何在传统 ASP 和 ASP.NET 之间共享会话状态 发布日期 : 4/1/2004 | 更新日期 : 4/1/2004 Billy Yu
如何在传统 ASP 和 ASP.NET 之间共享会话状态 发布日期 : 4/1/2004 | 更新日期 : 4/1/2004 Billy Yu
发布日期 : 4/1/2004|更新日期 : 4/1/2004 Billy Yuen Microsoft Corporation 2003 年 2 月 适用于
如何在传统 ASP 和 ASP.NET 之间共享会话状态 发布日期 : 4/1/2004 | 更新日期 : 4/1/2004 Billy Yu
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号