2

我遇到了一个非常奇怪的问题。当两个用户同时登录时,其中一个被检测为另一个。

    locale = new Locale(getLocale(request).getLanguage(), getLocale(request).getCountry());


    strRemoteUser = WebTools.getUserIdWithoutDomainName(request.getRemoteUser()).toUpperCase();

    logger.info("[MYAPP] User " + strRemoteUser + " is logging in");

    logger.info("[MYAPP] Creating session for : " + strRemoteUser);

    HttpSession session = request.getSession(false);

    if (session != null) {

        session.invalidate();
        session = request.getSession();
    }       

    logger.info("[MYAPP] User in session is : " + strRemoteUser);             

我得到的是以下内容。让我们假设两个用户(USR001 和 USR002)同时登录到应用程序。它们位于不同的位置。

日志:

    2013-05-14 08:19:38,550 INFO  [com.myapp.action.common.LoginAction] [MYAPP] User USR001 is logging in
2013-05-14 08:19:38,551 INFO  [com.myapp.action.common.LoginAction] [MYAPP] Creating session for : USR001
2013-05-14 08:19:38,760 INFO  [com.myapp.action.common.LoginAction] [MYAPP] User USR002 is logging in
2013-05-14 08:19:38,761 INFO  [com.myapp.action.common.LoginAction] [MYAPP] Creating session for : USR002
2013-05-14 08:19:38,834 INFO  [com.myapp.action.common.LoginAction] [MYAPP] User in session is : USR002
2013-05-14 08:19:39,104 INFO  [com.myapp.action.common.LoginAction] [MYAPP] User in session is : USR002
2013-05-14 08:19:39,425 INFO  [com.myapp.action.common.LoginAction] [MYAPP] Auto Added User USR002
2013-05-14 08:19:39,550 INFO  [com.myapp.action.common.LoginAction] [MYAPP] Setting user in session: USR002 (673)

如您所见,USR002“赢得”并发会话创建,因为 USR001 现在被识别为 USR002。如果 USR001 注销然后重新登录,它可以正常工作。

有什么想法/建议吗?

非常感谢您的帮助。

眼镜:

  • jBoss 4.2.3GA
  • PostgreSQL 9.0.3
  • Struts 1.3.5
  • EJB3
4

2 回答 2

1

许多开发人员忽略了 Struts 1 使用单个实例Action服务来自所有会话的请求这一事实,因此Actions 应该以并发安全的方式编写,例如

  • 仅使用不可变(最终)字段
  • 使用局部变量而不是可变字段
  • 注意线程不安全的类,例如Calendar,SimpleDateFormatMatcher

当然还有很多更微妙的问题,并且有很多资源可以学习(例如,Brian Goetz 的 Java Concurrency in Practice)。

来自原始 Apache Struts 文档的PS动作类设计指南

于 2013-05-16T19:31:32.280 回答
1

我很高兴它有所帮助。这是作为答案发布的评论:如果我们谈论的是同一件事,这些都是经典的并发问题。将变量移动到方法中并再次运行它并查看输出。

于 2013-05-15T14:18:06.670 回答