前几天我发生了一件非常奇怪和尴尬的事情,我无法用语言来描述发生的事情。
我的应用程序在 Tomcat 7 上运行与 JSF 2.1、Hibernate 4、Spring Security 集成的 Spring 3。我通过电话与 C 级别的重要人物通话,我们同时在同一页面上同时在测试环境中。当他的页面出现我的个人帐户详细信息时,他几乎在同一时刻导航到我正在导航的页面。我不相信他,所以我走到他的办公室,果然,他不知何故以我的帐户登录,而他没有密码。
该应用程序将保护患者的健康信息,因此我被要求向 C 级人员提供一份完整的报告,说明所发生的事情,但我不知道这是怎么可能的。我搜索了代码库,一无所获。我试图在多个场合重现确切的场景,但始终无法重现。我什至没有一个我满意的有根据的猜测。
我认为可能对存储在 Tomcat 应用程序上下文实现中的会话进行了一些不安全的线程操作,但如果它不可重现,我无法证明这一点。我还认为,由于 Spring Security 在其他请求和转发之前作为过滤器运行,因此可能其他 servlet 过滤器之一受到干扰。另外两个是我最近添加的 Primefaces 文件上传过滤器和 Omnifaces SEO 过滤器。
Omnifaces 过滤器确实干扰了 Primefaces 文件上传过滤器,我不得不修改它的配置,这样它们两个才能很好地相互配合,所以我仍然觉得这也可能是一种可能性。
Spring Security 是否有任何已知的错误导致类似的问题?Tomcat 是否存在关于从 ApplicationContext 意外提供错误会话状态的已知问题?有没有其他人遇到过类似的问题或对此有一些独特的见解?
编辑:发布后不久,我发现了这个,仅在几天前发布:
会话混合 - apache httpd 与 mod_jk、tomcat、spring security - 提供其他用户的数据
它几乎与我在 Tomcat 前面安装 Apache httpd+mod_jk 插件的设置完全相同,所以我肯定不是疯了 :)
更新:
我能够在没有 mod_jk 或 Apache 的情况下在我的开发环境中重现该问题,因此我可以可靠地将其排除为罪魁祸首。