首页 > 解决方案 > 如何从 SessionRegistry 获取用户名,它总是返回 ADMIN 用户

问题描述

我正在使用 Spring Security,我想创建一个页面来显示所有当前登录的用户。

为了实现这一点,我有这个代码。

@RequestMapping(value="/users" , method=RequestMethod.GET)
public String users(Model model)
{
    List<Object> loggedUsers = sessionRegistry.getAllPrincipals();
    for (Object principal : loggedUsers) {
        final User loggedUser = (User) principal;
        model.addAttribute("loggedInUser", loggedUser); 
    }

    List<Benutzer> users = userRepository.findAll();

    if(users !=null)
    {
        model.addAttribute("benutzern",users);
    }
    return "users";
}

但是,我总是只得到 ADMIN 用户。

在最终用户登录用户=(用户)主体;我总是得到我的 ADMIN 用户以及我的其他用户。所以这很完美。

我认为我的问题出在网页上,但我不知道具体在哪里。

当前登录的用户如下:

<table class="table table-striped">
<thead>
<tr>
<th>Benutzername</th>
<th>Anzeigename</th>
<th>Dienstnummer</th>
</tr>
</thead>
<dl th:each="user : ${loggedInUser}">
<tr>
<td th:text="${user.username}">benutzername</td>
</tr>
</table>

也许有人可以指出我正确的方向。

提前致谢。

标签: springspring-bootspring-security

解决方案


好吧,在提出问题后,我立即找到了解决方案。我不得不更改以下行。我不知道我是如何监督这一点的。

model.addAttribute("loggedInUser", loggedUsers);

推荐阅读