我想在安全认证过程中向 Authentication 对象添加自定义数据:
public class MyAuthFilter extends AbstractAuthenticationProcessingFilter {
MyUserDetailService userDetailService; // <==== How to wire??
@Override
public Authentication attemptAuthentication(
HttpServletRequest request,
HttpServletResponse response)
throws AuthenticationException, IOException, ServletException {
...
Authentication auth = new UsernamePasswordAuthenticationToken(
username,
r.sessionId,
Arrays.asList(new GrantedAuthority[]{new SimpleGrantedAuthority(grantedUserRole)}));
auth.setDetails(userDetailService.getDetail()); // <== Save detail to auth.
return auth;
}
}
如何连接 MyUserDetailService 服务?
如何将 MyUserDetailService 缓存到主体映射(以避免不必要的调用userDetailService.getDetail()
并且不会内存不足)?
PS spring-security.xml
:
<http use-expressions="true" auto-config="false" entry-point-ref="oauthEntryPoint" authentication-manager-ref="oauthAuthenticationManager">
<custom-filter position="FORM_LOGIN_FILTER" ref="myFilter" />
<intercept-url pattern="/login.htm" access="permitAll" />
<intercept-url pattern="/**" access="isAuthenticated()" />
<anonymous username="anonymous" enabled="true" granted-authority="AN" key="anonymous-security" />
<logout invalidate-session="true" logout-url="/logout" success-handler-ref="logoutHandler"/>
</http>
<beans:bean id="myFilter" class="com.web.filter.MyAuthFilter"> ...</beans:bean>