微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – 如何使用spring安全性以编程方式记录用户

我正在使用spring security v3.1.4.我想要实现的是让管理员能够注销常规用户(使他的会话无效).用户只能在任何给定时间登录一次,但如果他忘记退出,那么当他尝试从其他位置登录时,他将无法登录.所以他会把一张票给管理员管理员将使他之前登录的所有会话无效(希望只有一个).

在我的web.xml中,我有以下定义.

ecurity.web.session.HttpSessionEventPublisher

在我的春天安全xml我有以下定义.

ecurity.core.session.SessionRegistryImpl"/>

然后我有一个类似休息的控制器来执行注销.

@Controller
@RequestMapping("/api/admin")
public class RestAdminController {
 static final Setlogout");
 public @ResponseBody String logout(@RequestBody Account account) {
  User user = new User(account.getUsername(),"",AUTHS);
  Listinformation> infos = sessionRegistry.getAllSessions(u,false);

  for(Sessioninformation info : infos) {
   info.expireNow(); //expire the session
   sessionRegistry.removeSessioninformation(info.getSessionId()); //remove session
  }

  return "ok";
 }
}

当我从同一台计算机上测试时,这段代码“kinda”有效.假设我们有一个用户USER_A和一个管理员ADMIN_A.

> USER_A使用chrome登录APP.
> USER_A使用firefox登录APP.他被拒绝是因为用户一次只能有1个登录会话.
> ADMIN_A进入,并调用类似其余的服务(上面的代码)来“踢出”所有USER_A的会话.
> USER_A现在可以使用firefox登录APP.

但是,USER_A现在登录两次,一次是在chrome中,一次是在firefox中.

>刷新Chrome中的USER_A(弹出安全保护)页面(首次登录)不会强制他被重定向(到登录页面).
>在firefox中刷新USER_A的受保护页面(第二次登录)也不会强制他被重定向.

关于如何完全无效/销毁USER_A的第一个/上一个登录会话的方法的任何想法,如果他试图访问受保护的页面,春天的安全性会知道,“嘿这个人的会话无效或过期,将他发送到登录页面”?

任何帮助表示赞赏.谢谢.

最佳答案
看起来你已经差不多了,但我认为问题在于你是否过早地从SessionRegistry中删除了这些信息.当用户发出请求时,ConcurrentSessionFilter会对当前会话执行检查,此时,它会注销已过期的会话并使其无效.由于您已经删除了该会话的信息,因此无法找到它并且什么都不做.

尝试删除该行:

sessionRegistry.removeSessioninformation(info.getSessionId());

原文地址:https://www.jb51.cc/spring/431665.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐