Spring Security 3.0.5 自定义登录

一般使用SpringSecurity 都需要使用自带的url("j_spring_security_check")进行登录,但是如果你想要使用ajax登录设置就会很麻烦,但是其实可以自己实现登录的action(struts),原理也就是把认证的对象放到spring security context 中,关键代码如下:

try {
	UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken(username, password);
	Authentication auth = getAuthenticationManager().authenticate(token);
	auth = new UserSessionAuthentication(auth, (UserSession)auth.getPrincipal());
	SecurityContextHolder.getContext().setAuthentication(auth);
}catch (AuthenticationException ae) {
	throw new AccessDeniedException("wrong username or password !");
}

其中UserSession是UserDetails的实现,一旦登录完成用户的权限就会缓存在内存中,所以如果想要动态地改变用户的权限的话就得在实现UserDetails中的getAuthorities()方法时从数据库中取出用户的权限而不是从用户的对象方法中取得,代码如下:

@Override
@Transactional(rollbackFor=java.lang.Exception.class,propagation = Propagation.REQUIRED)
public Collection<GrantedAuthority> getAuthorities() {
	List<GrantedAuthority> out = new ArrayList<GrantedAuthority>();
	out.addAll(...(user roles/rights from database));
	...
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值