如何记录 tomcat 会话失效或用户注销

Posted

技术标签:

【中文标题】如何记录 tomcat 会话失效或用户注销【英文标题】:How to log tomcat session invalidation or user logout 【发布时间】:2014-11-06 20:08:47 【问题描述】:

当tomcat 7 使会话无效或用户由于会话过期或错误会话而从应用程序中注销时,我如何记录情况。例如,用户登录到 webapp,他将他的 jsessionid 保存到浏览器 cookie 中,然后我通过 tomcat 管理器手动使会话无效或从 cookie 中删除 jsessionid。这两种情况都会导致用户注销,但我认为这种行为会处理 tomcat 本身,所以我必须在 tomcat 的某个地方捕获这个调用。我该怎么做?

我需要这个是因为会话随机失效的问题,这可能是由于集群不良(我们有两个节点具有粘性会话)或者垃圾收集器破坏了我们的会话,但它可以是其他任何东西,所以我需要更广泛的上下文。

我使用 tomcat 7、java 1.7、jsf 1.2、spring-security 3

谢谢

【问题讨论】:

有一个监听器。 【参考方案1】:

您必须实现一个 HttpSessionListener,将您的日志记录代码放在 sessionDestroyed 方法中,并将其注册到您的 web.xml 文件中。

这是一个例子:

http://www.mkyong.com/servlet/a-simple-httpsessionlistener-example-active-sessions-counter/

【讨论】:

请注意,这个例子有些过时了——现在这一切都可以通过注释来完成。不需要任何web.xml

以上是关于如何记录 tomcat 会话失效或用户注销的主要内容,如果未能解决你的问题,请参考以下文章

会话超时后失效

如何在会话超时或结束时注销用户

Spring Security 注销会话未失效

如何从 Laravel 的特定会话中注销用户?

当用户关闭浏览器而不单击注销时销毁或取消设置会话[重复]

如何在 Swift 3 的 UIWebview 中会话过期?