我正在使用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>
也许有人可以指出我正确的方向。
提前致谢。
好吧,在提出问题后我立即找到了解决方案。我不得不改变以下行。我不知道我是如何监督这一点的。
model.addAttribute("loggedInUser", loggedUsers);