详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt396

修改TOMCAT 默认的生成SESSION ID的算法和字符长度非常简单,只需修改context.xml中的<Manager>标签值,比如:

<Manager

sessionIdLength="20"

pathname="SESSIONS.ser"

maxActiveSessions="8000"

secureRandomAlgorithm="SHA1PRNG"

secureRandomClass="java.security.SecureRandom"

maxInactiveInterval="60"

/>

标红的部分不用我说大家也应该知道了,算法除了SHA1PRNG还有好几种,具体可以查看 JDK DOC的java.security.SecureRandom类章节.

更多配置见:http://tomcat.apache.org/tomcat-7.0-doc/config/manager.html

TOMCAT默认的SESSIONID生成器在高并发下可能产生些性能损失,因为采用了较为安全的随机数来生成SESSION的ID值。

实际上TOMCAT生成的SESSIONID是不可能有重复值的,查看TOMCAT源码文件:ManagerBase.java中的以下代码

/**

* Generate and return a new session identifier.

*/

protected String generateSessionId() {

String result = null;

do {

if (result != null) {

duplicates++;

}

result = sessionIdGenerator.generateSessionId();

} while (sessions.containsKey(result)); //此处保证最终生成给客户端使用的SESSIONID一定是不重复的

return result;

}

所以,不必担心SESSIONID的安全性,如果有更好的实现,可以修改相应代码用于特定项目中。

因此我们可以修改TOMCAT源码中的SessionIdGenerator.java生成ID的函数部分,比如采用 java.util.UUID+java.util.Random+(随机字符串)来构建更高效的生成SESSIONID的算法,或者自己实现相关部分等 等。

最新文章

  1. POJ 3278 Catch That Cow
  2. 初探XML
  3. jq手风琴---点击时列表的左边距逐渐减小
  4. shiro错误No SecurityManager accessible to the calling code
  5. Metadata Lock原理5
  6. saltstack实战4--综合练习3
  7. eclipse+tomcat+httpServlet初学
  8. 【原创】win7同局域网下共享文件
  9. bzoj1588: [HNOI2002]营业额统计 splay瞎写
  10. 配置ssh免密码登陆
  11. Jquery如何删除table里面checkbox选中的多个行
  12. Linux下vim上编辑实现进度条
  13. IDEA 开发环境中设置Subversion,遇到svn安装路径包含空格无法使用版本控制的解决办法
  14. three.js 相机camera位置属性设置详解
  15. nginx启动报错:Job for nginx.service failed. See &#39;systemctl status nginx.service&#39; and &#39;journalctl -xn&#39; fo
  16. (转)azkaban job参数说明
  17. win7系统administrator用户提示没有管理员权限,造装驱动安装错误,软件无法使用
  18. SSD测试第一神器——FIO
  19. conding.net或github,readme.md添加图片
  20. Spring Boot干货系列:(三)启动原理解析

热门文章

  1. 51. leetcode 530. Minimum Absolute Difference in BST
  2. Linux系统C语言socket tcp套接字编程
  3. OpenCV 之 Mat 类
  4. 自定义Git之配置别名
  5. nstallation error: INSTALL_PARSE_FAILED_MANIFEST_MALFORMED报这个错的原因???
  6. tps 与 事务平均响应时间关系对答
  7. 通过反射实现Json数据部分更新JavaBean的属性
  8. Dom的增删查改以及常用事件
  9. NOIP2000提高组 单词接龙
  10. JDK问题--linux下java unrecognized class file version错误的解决