HttpSession常见问题

1、session在何时被创建

一个常见的误解是以为session在有客户端访问时就被创建,然而事实是直到某server端程序调用HttpServletRequest.getSession(true)这样的语句时才被创建,注意如果JSP没有显示的使用 <%@page session="false"%> 关闭session,则JSP文件在编译成Servlet时将会自动加上这样一条语句HttpSession session = HttpServletRequest.getSession(true);这也是JSP中隐含的session对象的来历。

由于session会消耗内存资源,因此,如果不打算使用session,应该在所有的JSP中关闭它。

2、session何时被删除

综合前面的讨论,session在下列情况下被删除a.程序调用HttpSession.invalidate();或b.距离上一次收到客户端发送的session id时间间隔超过了session的超时设置;或c.服务器进程被停止(非持久session)

3、如何做到在浏览器关闭时删除session

严格的讲,做不到这一点。可以做一点努力的办法是在所有的客户端页面里使用javascript代码window.oncolose来监视浏览器的关闭动作,然后向服务器发送一个请求来删除session。但是对于浏览器崩溃或者强行杀死进程这些非常规手段仍然无能为力。

4、有个HttpSessionListener是怎么回事

你可以创建这样的listener去监控session的创建和销毁事件,使得在发生这样的事件时你可以做一些相应的工作。注意是session的创建和销毁动作触发listener,而不是相反。类似的与HttpSession有关的listener还有HttpSessionBindingListener,HttpSessionActivationListener和HttpSessionAttributeListener。

5、存放在session中的对象必须是可序列化的吗

不是必需的。要求对象可序列化只是为了session能够在集群中被复制或者能够持久保存或者在必要时server能够暂时把session交换出内存。在Weblogic Server的session中放置一个不可序列化的对象在控制台上会收到一个警告。我所用过的某个iPlanet版本如果session中有不可序列化的对象,在session销毁时会有一个Exception,很奇怪。

6、如何才能正确的应付客户端禁止cookie的可能性

对所有的URL使用URL重写,包括超链接,form的action,和重定向的URL,具体做法参见[6]
http://e-docs.bea.com/wls/docs70/webapp/sessions.html#100770

7、开两个浏览器窗口访问应用程序会使用同一个session还是不同的session

参见第三小节对cookie的讨论,对session来说是只认id不认人,因此不同的浏览器,不同的窗口打开方式以及不同的cookie存储方式都会对这个问题的答案有影响。

8、如何防止用户打开两个浏览器窗口操作导致的session混乱

这个问题与防止表单多次提交是类似的,可以通过设置客户端的令牌来解决。就是在服务器每次生成一个不同的id返回给客户端,同时保存在session里,客户端提交表单时必须把这个id也返回服务器,程序首先比较返回的id与保存在session里的值是否一致,如果不一致则说明本次操作已经被提交过了。可以参看《J2EE核心模式》关于表示层模式的部分。需要注意的是对于使用javascript window.open打开的窗口,一般不设置这个id,或者使用单独的id,以防主窗口无法操作,建议不要再window.open打开的窗口里做修改操作,这样就可以不用设置。

9、为什么在Weblogic Server中改变session的值后要重新调用一次session.setValue

做这个动作主要是为了在集群环境中提示Weblogic Server session中的值发生了改变,需要向其他服务器进程复制新的session值。

10、为什么session不见了

排除session正常失效的因素之外,服务器本身的可能性应该是微乎其微的,虽然笔者在iPlanet6SP1加若干补丁的Solaris版本上倒也遇到过;浏览器插件的可能性次之,笔者也遇到过3721插件造成的问题;理论上防火墙或者代理服务器在cookie处理上也有可能会出现问题。
出现这一问题的大部分原因都是程序的错误,最常见的就是在一个应用程序中去访问另外一个应用程序。我们在下一节讨论这个问题。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: httpsession.setattribute是一个Java Servlet API中的方法,用于将一个对象存储在当前会话中。该方法需要两个参数:属性名称和属性值。在当前会话中,可以使用属性名称来检索属性值。这个方法通常用于在不同的页面之间共享数据。 ### 回答2: httpsession.setattribute是Java Servlet API中的一个方法,用于在HttpSession对象中存储数据。它接受两个参数,第一个参数是要设置的属性的键,第二个参数是属性的值。 通过使用httpsession.setattribute方法,我们可以在HttpSession对象中存储各种类型的数据,例如字符串、整数、对象等。这些数据将一直保存在会话期间,直到会话结束或者手动删除。 使用httpsession.setattribute的一个常见的用例是在用户登录后,将用户信息存储在会话中。例如,我们可以将用户的用户名、id和角色等存储在HttpSession对象中。这样,在整个会话期间,我们可以随时从会话中获取这些用户信息,而不需要再次进行身份验证。 另一个常见的用例是存储用户的购物车信息。当用户添加商品到购物车时,我们可以使用httpsession.setattribute方法将这些信息存储在会话中,以便在用户浏览其他页面或结账时,仍然可以访问这些购物车信息。 总结来说,httpsession.setattribute方法是一个非常有用的方法,用于在会话期间存储和访问数据。通过将数据存储在会话中,我们可以方便地在不同的页面和请求之间传递数据,从而实现更高效和灵活的Web应用程序设计。 ### 回答3: `HttpSession.setAttribute`是一个方法,它用于在`HttpSession`对象中设置一个属性。`HttpSession`对象是在每个用户与Web服务器之间建立的一种会话。在Web应用程序中,每当用户与服务器建立连接时,都会创建一个唯一的`HttpSession`对象,用于跟踪和存储用户的会话信息。 `setAttribute`方法接受两个参数:属性的名称和属性的值。属性的名称是一个字符串,用于标识属性,在后续的访问中可以使用这个名称来获取属性的值。属性的值可以是任何Java对象。 使用`setAttribute`方法,我们可以将数据存储在`HttpSession`对象中,以便在整个会话期间持久化和共享数据。这对于将特定于用户的数据(例如登录状态、购物车内容等)传递给不同的页面和请求非常有用。例如,我们可以将用户的用户名存储在`HttpSession`对象中,以便在整个会话期间验证用户身份。 以下是使用`setAttribute`方法的示例代码: ```java // 获取当前HttpSession对象 HttpSession session = request.getSession(); // 设置属性,将用户的用户名存储在session中 session.setAttribute("username", "John123"); // 获取属性值 String username = (String) session.getAttribute("username"); // 打印属性值 System.out.println("Username: " + username); ``` `setAttribute`方法还可以用于更新现有的属性。如果使用相同的属性名称调用`setAttribute`方法,它将覆盖旧的属性值。 需要注意的是,`setAttribute`方法将传递的属性值视为`Object`类型。因此,在获取属性值时,我们可能需要进行适当的类型转换。 总而言之,`HttpSession.setAttribute`方法是用于在`HttpSession`对象中设置属性的方法,通过它可以持久化和共享数据。它在Web应用程序中的使用非常广泛,特别是在处理用户会话相关的数据时。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值