HttpSession常见问题

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
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值