使用spring 3安全性访问jsp页面中的自定义用户对象

问题描述 投票:5回答:3

我已经实现了UserDetailsService,它返回MyUser的实例(实现UserDetails

public MyUser loadUserByUsername(String arg0)

现在我想在我的JSP页面中访问MyUser上的自定义getter / fields,到目前为止我得到了这个:

${pageContext.request.userPrincipal.name}

但这只允许访问Principal对象。我怎样才能访问MyUser对象?

java spring spring-mvc spring-security
3个回答
8
投票

它在jsp页面中很容易我添加了这个:

<%@ taglib prefix="sec" uri="http://www.springframework.org/security/tags" %>
...
<sec:authentication property="principal.firstname" /> 

如果principal实际上是MyUser的一个实例,那么“firstname”可以是我的任何自定义getter和setter


6
投票

在分析了HTTPSesson之后,在成功登录后立即发现有一个名为SPRING_SECURITY_CONTEXT的属性。例如,我的自定义UserDetails具有名为user的对象,其具有属性firstName。在JSP中,可以使用以下命令达到此属性的值:

${sessionScope.SPRING_SECURITY_CONTEXT.authentication.principal.user.firstName}

2
投票

如果你的MyUser对象实现了Principal并且你在成功登录时将它放在http会话中,你可以从会话中获取它并进行转换。


你可以实现AuthenticationSuccessHandler在那里注入你的UserDetailsService并将其放入会话中。

然后你可以将你的AuthenticationSuccessHandler注入处理UsernamePasswordauthenticationFilter元素的<form-login>

如果您提供有关安全上下文配置的详细信息,我可以为您提供更多详细信息。

© www.soinside.com 2019 - 2024. All rights reserved.