技术开发 频道

jsessionid传递对session实现机制的影响

  【IT168 技术文档】近期因工作需求探索apache + resin的多机负载分布和多个webapp统一认证的实现方案, 期间设计多个webapp统一认证的实现方案时, 发现resin下通过cookie来传递jsessionid和通过url重写将jsessionid放url中传递, 会有细微的差异.

  在servlet规范中,HttpServletSession的获取时通过调用request.getSession(boolean createnew)方法来实现,其实现机制可以简单的理解为: 存在一个大的hashMap结构,key就是jsessionid,而valule是HttpservletSession对象。request.getSession(boolean createnew)方法通过jsessionid来获取对应的HttpservletSession,如果不存在并且参数createnew=true,则创建一个新的HttpservletSession对象,并设置jsessionid=session.getId() ,保存到hashMap结构中。以后再传递这个jsessionid. (详细的过程比较复杂,各家的实现也不尽相同,但大体的实现原理是如此。)

  关注以下几点:

  一). 获取jsessionid

  jsessionid的传递可以是以下途径

  1. 放在cookie中

  Cookie: JSESSIONID=abcrmF3Gx-5Z-hhkgHfzr

  2. 以参数形式放在url

  http://10.3.2.35:11280/wmail/welcome.action?jsessionid=abcQNqiT4C01rg-necLBr

  3. 用form表单传递,通常是用隐藏域

<input type="hidden" name="jsessionid" value="abcQNqiT4C01rg-necLBr"/>

  4. url重写

  http://10.3.2.35:11280/jid=abcQNqiT4C01rg-necLBr/wmail/welcome.action

  或者

  http://10.3.2.35:11280/wmail/welcome.action;jsessionid=abcQNqiT4C01rg-necLBr

  如果当前还没有jsessionid则当然就无法获取,通常用户第一次访问或者登录前就是这种情况.

  可以通过request.getRequestedSessionId() 方法来获取本次http 请求的jsessonid值。

1
相关文章