`

深入理解HTTP Session ---- 20161212

阅读更多
session在web开发中是一个非常重要的概念,这个概念很抽象,很难定义,也是最让人迷惑的一个名词,也是最多被滥用的名字之一,在不同的场合,session一次的含义也很不相同。这里只探讨HTTP Session。
 
为了说明问题,这里基于Java Servlet理解Session的概念与原理,这里所说Servlet已经涵盖了JSP技术,因为JSP最终也会被编译为Servlet,两者有着相同的本质。
 
在Java中,HTTP的Session对象用javax.servlet.http.HttpSession来表示。
 

1、概念:

Session代表服务器与浏览器的一次会话过程,这个过程是连续的,也可以时断时续的。在Servlet中,session指的是HttpSession类的对象,这个概念到此结束了,也许会很模糊,但只有看完本文,才能真正有个深刻理解。
 

2、Session创建的时间是:

一个常见的误解是以为session在有客户端访问时就被创建,然而事实是直到某server端程序调用 HttpServletRequest.getSession(true)这样的语句时才被创建,注意如果JSP没有显示的使用 <% @page session="false"%> 关闭session,则JSP文件在编译成Servlet时将会自动加上这样一条语句 HttpSession session = HttpServletRequest.getSession(true);这也是JSP中隐含的 session对象的来历。
由于session会消耗内存资源,因此,如果不打算使用session,应该在所有的JSP中关闭它。
 
引申:
1)、访问*.html的静态资源因为不会被编译为Servlet,也就不涉及session的问题。
2)、当JSP页面没有显式禁止session的时候,在打开浏览器第一次请求该jsp的时候,服务器会自动为其创建一个session,并赋予其一个sessionID,发送给客户端的浏览器。以后客户端接着请求本应用中其他资源的时候,会自动在请求头上添加:
Cookie:JSESSIONID=客户端第一次拿到的session ID
这样,服务器端在接到请求时候,就会收到session ID,并根据ID在内存中找到之前创建的session对象,提供给请求使用。这也是session使用的基本原理----搞不懂这个,就永远不明白session的原理。
下面是两次请求同一个jsp,请求头信息:
通过图可以清晰发现,第二次请求的时候,已经添加session ID的信息。
 

3、Session删除的时间是:

1)Session超时:超时指的是连续一定时间服务器没有收到该Session所对应客户端的请求,并且这个时间超过了服务器设置的Session超时的最大时间。
2)程序调用HttpSession.invalidate()
3)服务器关闭或服务停止
 

4、session存放在哪里:

服务器端的内存中。不过session可以通过特殊的方式做持久化管理。
 

5、session的id是从哪里来的

sessionID是如何使用的:当客户端第一次请求session对象时候,服务器会为客户端创建一个session,并将通过特殊算法算出一个session的ID,用来标识该session对象,当浏览器下次(session继续有效时)请求别的资源的时候,浏览器会偷偷地将sessionID放置到请求头中,服务器接收到请求后就得到该请求的sessionID,服务器找到该id的session返还给请求者(Servlet)使用。一个会话只能有一个session对象,对session来说是只认id不认人。
 

6、session会因为浏览器的关闭而删除吗?

不会,session只会通过上面提到的方式去关闭。
 

7、同一客户端机器多次请求同一个资源,session一样吗?

一般来说,每次请求都会新创建一个session。
 
其实,这个也不一定的,总结下:对于多标签的浏览器(比如360浏览器)来说,在一个浏览器窗口中,多个标签同时访问一个页面,session是一个。对于多个浏览器窗口之间,同时或者相隔很短时间访问一个页面,session是多个的,和浏览器的进程有关。对于一个同一个浏览器窗口,直接录入url访问同一应用的不同资源,session是一样的。
 

8、session是一个容器,可以存放会话过程中的任何对象。

 

9、session因为请求(request对象)而产生,同一个会话中多个request共享了一session对象,可以直接从请求中获取到session对象。

 

10、其实,session的创建和使用总在服务端,

而浏览器从来都没得到过session对象。但浏览器可以请求Servlet(jsp也是Servlet)来获取session的信息。客户端浏览器真正紧紧拿到的是session ID,而这个对于浏览器操作的人来说,是不可见的,并且用户也无需关心自己处于哪个会话过程中。
 

本文出自 “熔 岩” 博客,请务必保留此出处http://lavasoft.blog.51cto.com/62575/275589

分享到:
评论

相关推荐

    tomcat-redis-session-manager的jar包-包含Tomcat7和Tomcat8

    《深入理解Tomcat-Redis-Session-Manager:在Tomcat7和Tomcat8中的应用》 在现代Web应用程序开发中,session管理是一个至关重要的环节,它涉及到用户会话的持久化和跨请求的数据共享。传统的session管理方式在高...

    Acct-Session-idAcct-Session-id

    通过对它的深入理解和合理应用,不仅可以提高网络资源的利用效率,还能增强网络安全,保障服务质量。因此,对于IT专业人士而言,掌握 Acct-Session-id 的工作原理和最佳实践是非常必要的。在未来,随着网络技术的...

    flask-session-cookie-manager-master.zip

    首先,我们来深入理解session和cookie的概念。在Web应用中,用户认证通常依赖于session和cookie。cookie是服务器发送到用户浏览器并存储在本地的一小块数据,用于跟踪用户状态。而session则是一种在服务器端存储用户...

    tomcat-redis-session-manager源码

    《深入解析Tomcat-Redis-Session-Manager源码》 在现代Web应用中,服务器端会话管理是一个至关重要的部分,特别是在高并发、分布式环境中。Tomcat作为最流行的Java Servlet容器,提供了丰富的功能来支持这一需求。...

    -redis-session-manager-master.zip

    通过阅读源码,我们可以深入理解其内部实现机制,比如如何序列化和反序列化session对象,以及如何处理并发和超时问题。而README通常会提供详细的安装和使用指南,包括环境需求、配置参数的解释以及可能出现的问题及...

    memcached(十一)memcached-session-manager

    "源码"标签意味着教程可能会深入到代码级别,讲解如何读取和理解`memcached-session-manager`的源代码,或者如何定制和修改它以适应特定的需求。 "工具"标签则表明`memcached-session-manager`是一个实用工具,用于...

    tomcat-redis-session-manager-master.zip

    《深入理解Tomcat Redis Session Manager:源码剖析与实践指南》 在当今互联网应用中,随着用户量的急剧增长,单台服务器的session管理能力往往无法满足需求,这时就需要引入session共享技术。Tomcat作为广泛使用的...

    memcached-session-manager-1.8.1

    《深入理解Memcached Session Manager 1.8.1》 在Web开发中,session管理是一项至关重要的任务,它涉及到用户状态的保持与跨请求的数据共享。Memcached Session Manager(MSM)是Java环境下的一种解决方案,它利用...

    memcached-session-manager 实现 tomcat session共享

    对于标签中的 "源码",深入理解 memcached-session-manager 的源码可以帮助你更好地定制和优化。例如,你可以查看 Session 的序列化和反序列化逻辑,了解如何与 Memcached 通信,以及在 Session 过期或被移除时的...

    memcached-session-manager-1.6.5.rar

    《深入理解Memcached Session Manager 1.6.5》 Memcached Session Manager 1.6.5是一款专门用于处理Web应用程序中的用户会话管理的工具,它基于Java平台,利用了高效的分布式缓存系统——Memcached。在Java Web开发...

    redis-session-manager-redis-session-manager-2.0.7.tar.gz

    该工具的2.0.7版本的源码压缩包为"redis-session-manager-redis-session-manager-2.0.7.tar.gz",适用于Linux操作系统,并且提供免费下载。 在深入讲解Redis Session Manager之前,我们先了解一下Redis和Session的...

    tomcat-redis-session-manager 支持 tomcat7 ,包含源码和jar

    《深入理解Tomcat-Redis-Session-Manager:与Tomcat7的整合及源码解析》 在现代Web应用中,由于高并发、分布式部署的需求,单一服务器的session管理已无法满足需求。这时,将session存储在外部存储系统,如Redis,...

    Memcached-Session-Manager多tomcat实现session共享配置

    文档通常会包含详细的配置示例、性能优化建议以及常见问题的解答,对理解和使用Memcached-Session-Manager非常有帮助。 总结,Memcached-Session-Manager通过将Session数据存储在Memcached中,为Tomcat集群提供了...

    PyPI 官网下载 | ssh-session-manager-0.0.1.tar.gz

    通过深入理解和使用这个库,可以提升日常的服务器管理能力,降低错误发生的风险。对于想要学习更多关于Python库开发、SSH管理或者自动化运维的同学,ssh-session-manager是一个值得研究的例子。

    tomcat7&tomcat8;-redis-session-manager-2.0.0.zip

    《深入理解Tomcat7&Tomcat8 Redis Session Manager》 在现代Web应用中,随着用户量的增加,Session管理成为了服务器性能的关键因素。传统的基于内存的Session管理方式在高并发场景下存在诸多挑战,如内存消耗大、...

    tomcat8-session-jars.zip

    在深入讨论之前,首先理解几个关键概念: 1. **Session**: Session是Web应用程序中用于跟踪用户状态的一种机制。当用户登录后,服务器会为该用户创建一个session对象,存储用户信息,以便在不同页面间保持状态。 2. ...

    Nginx+Tomcat+Memcached-Session-Manager集群Session共享

    在本篇文章中,我们将深入探讨如何使用Nginx、Tomcat和Memcached-Session-Manager(MSM)来构建一个集群环境,并实现Session共享。这涉及到集群搭建、分布式应用以及缓存管理等多个方面的IT知识。下面将详细展开这些...

    PyPI 官网下载 | couchdb-session-0.1.tar.gz

    《PyPI官网下载 | couchdb-session-0.1.tar.gz》 在Python的世界里,PyPI(Python Package Index)是官方的第三方软件包仓库,它为开发者提供了分享和发现Python库的平台。本文将深入探讨PyPI、couchdb-session库...

    分布式集群Session共享 简单多tomcat8+redis的session共享实现

    接下来,我们关注`tomcat-redis-session-manager-master-8.0`、`tomcat-redis-session-manager-master-8.5`和`tomcat-redis-session-manager-master-9`这些文件夹。它们分别对应Tomcat 8.0、8.5和9.0版本的`Tomcat-...

Global site tag (gtag.js) - Google Analytics