锁定老帖子 主题:http session原理
精华帖 (0) :: 良好帖 (1) :: 新手帖 (9) :: 隐藏帖 (1)
|
|
---|---|
作者 | 正文 |
发表时间:2009-12-02
1.cookie保存sessionid,在浏览器支持cookie的情况下,服务端一般首选这种方式,在用户请求有状态的服务端时,服务端会写如客户端cookie中一个jsessionid(在tomcat中是这样,其他服务器也类似),这里会有一个服务端生成的session id 用来保存这次会话的id编号,服务端维护了一个session池,这个池是有时间限制的,一般可以在web.xml中配置session-config选项中的,session-timeout,这样客户端在每次请求中代上服务端分配的sessionid,服务端自然知道是那个用户了,从而达到维护客户端状态的目的。 2.服务端考虑到如果客户端浏览器不支持cookie,那么采取了一种叫做url rewrite的技术,这种方式体现在,用户在请求服务端时,会在用户请求的url后边加入;jsessionid=XXXXXXX,这样的参数,效果与存入cookie一样,还是通过客户端记录sessionid编号来维护客户端状态。 所以,有状态的 web session就是这样被实现的,但是在并发量大,集群的环境中使用session可能消耗服务端很大的资源,所以尽量在session里少存入信息. 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-12-03
楼主写了几个错别字,依次列举如下:
这中方式 应该是 这种方式 写如 应该是 写入 代上 应该是 带上 |
|
返回顶楼 | |
发表时间:2009-12-03
tuhaitao 写道 1.cookie保存sessionid,在浏览器支持cookie的情况下,服务端一般首选这种方式,在用户请求有状态的服务端时,服务端会写如客户端cookie中一个jsessionid(在tomcat中是这样,其他服务器也类似),这里会有一个服务端生成的session id 用来保存这次会话的id编号 补充一点内容:客户端COOKIE又分为进程COOKIE和持久COOKIE,简单点说就是COOKIE要么保存在浏览器进程中,随浏览器关闭而消失,要么保存在客户端本地文件中。具体采用哪种保存方式,由服务端决定。一般在SERVLET中使用javax.servlet.http.Cookie的setMaxAge()来决定是进程COOKIE还是持久COOKIE。在TOMCAT中,TOMCAT创建了jsessionid这个COOKIE,并且设置setMaxAge(-1),也就是说TOMCAT下jsessionid的COOKEI是进程COOKIE,在客户端本地是看不到这个COOKIE文件的。 |
|
返回顶楼 | |
发表时间:2009-12-03
hanz188 写道 楼主写了几个错别字,依次列举如下:
这中方式 应该是 这种方式 写如 应该是 写入 代上 应该是 带上 好的,谢谢,下次一定改正 |
|
返回顶楼 | |
发表时间:2009-12-03
he_lux 写道 tuhaitao 写道 1.cookie保存sessionid,在浏览器支持cookie的情况下,服务端一般首选这种方式,在用户请求有状态的服务端时,服务端会写如客户端cookie中一个jsessionid(在tomcat中是这样,其他服务器也类似),这里会有一个服务端生成的session id 用来保存这次会话的id编号 补充一点内容:客户端COOKIE又分为进程COOKIE和持久COOKIE,简单点说就是COOKIE要么保存在浏览器进程中,随浏览器关闭而消失,要么保存在客户端本地文件中。具体采用哪种保存方式,由服务端决定。一般在SERVLET中使用javax.servlet.http.Cookie的setMaxAge()来决定是进程COOKIE还是持久COOKIE。在TOMCAT中,TOMCAT创建了jsessionid这个COOKIE,并且设置setMaxAge(-1),也就是说TOMCAT下jsessionid的COOKEI是进程COOKIE,在客户端本地是看不到这个COOKIE文件的。 学习了,谢谢你啊 |
|
返回顶楼 | |
发表时间:2009-12-03
这个原理需要完善。。。
讲的太简单了哈哈 |
|
返回顶楼 | |
发表时间:2009-12-03
tangbo530 写道 这个原理需要完善。。。
讲的太简单了哈哈 本来想随便写点,自己以后备用,结果不知道咋的,就发到这里来了,惭愧啊~ |
|
返回顶楼 | |
发表时间:2009-12-03
掌握原理很重要。
|
|
返回顶楼 | |
发表时间:2009-12-03
现在的浏览器都是线程级别了
不知道大家都与线程级别的session覆盖是如何解决的 现在看google 和网易的邮箱都是解决了 感觉网易好像是通过了动态的二级域名方式 大家说说看法 |
|
返回顶楼 | |
发表时间:2010-06-03
户端COOKIE又分为进程COOKIE和持久COOKIE,简单点说就是COOKIE要么保存在浏览器进程中,随浏览器关闭而消失,要么保存在客户端本地文件中。具体采用哪种保存方式,由服务端决定。
--------------apache服务器的session采用的是哪种保存方式? 在php里面貌似保存在文件里面的.... |
|
返回顶楼 | |