我是Spring的新手,我的要求是我不想用用户名和密码对用户进行身份验证。 的用户身份验证是一些其他的应用和我的应用程序获得与folloing细节要求:Spring 3.0安全性 - 授权与认证
- 用户名
- 角色
我只是想使用Spring Security根据固定的页面请求中的角色。 我已经考虑编写UserDetailService,但只添加请求数据,Spring仍然要求提供认证信息。 后来我想过写类似如下:
public class UserLogin {
/*
@Resource(name = "userDetailsService")
private UserDetailsService userDetailsService;
*/
@Resource(name = "authenticationManager")
private AuthenticationManager authenticationManager;
public boolean login(UserEntity user) {
//UserDetails ud = userDetailsService.loadUserByUsername(username);
Collection<GrantedAuthority> authorities = new ArrayList<GrantedAuthority>();
for (String role : user.getAuthorities()) {
authorities.add(new GrantedAuthorityImpl(role));
}
UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken(user.getUsername(), user.getPassword(), authorities);
try {
Authentication auth = authenticationManager.authenticate(token);
SecurityContext securityContext = new SecurityContextImpl();
// Places in ThredLocal for future retrieval
SecurityContextHolder.setContext(securityContext);
SecurityContextHolder.getContext().setAuthentication(auth);
} catch (AuthenticationException e) {
return false;
}
return true;
}
}
上午我在正确的方向前进。如果是这样,如何配置整个事情..在spring-xml中。