如何从SessionRegistry获取用户名,它总是返回ADMIN用户

问题描述 投票:0回答:1

我正在使用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用户。

在最终用户loggedUser =(用户)主体;我总是得到我的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>

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

提前致谢。

spring spring-boot spring-security
1个回答
0
投票

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

model.addAttribute("loggedInUser", loggedUsers);
© www.soinside.com 2019 - 2024. All rights reserved.