Spring Security 取Session中的值和修改userDetails
(2010-09-27 11:38:30)
标签:
it |
分类: javaEE |
1.在session中取得spring security的登录用户名如下
${session.SPRING_SECURITY_CONTEXT.authentication.principal.username}
spring security 把SPRING_SECURITY_CONTEXT 放入了session 没有直接把username 放进去。
view plaincopy to clipboardprint?
存跳转时候的URL
session
{SPRING_SECURITY_SAVED_REQUEST_KEY=SavedRequest[http://localhost:8080/AVerPortal/resourceAction/resourceIndex.action]}
存的是登录成功时候session中存的信息
session
{SPRING_SECURITY_CONTEXT=org.springframework.security.context.SecurityContextImpl@87b16984:
Authentication:
org.springframework.security.providers.cas.CasAuthenticationToken@87b16984:
Principal: com.avi.casExtends.UserInfo@ff631d80:
Username: test; Password: [PROTECTED]; Enabled: true;
AccountNonExpired: true; credentialsNonExpired: true;
AccountNonLocked: true; Granted Authorities: ROLE_ADMIN; Password:
[PROTECTED]; Authenticated: true; Details:
org.springframework.security.ui.WebAuthenticationDetails
存跳转时候的URL
session
存的是登录成功时候session中存的信息
session
2.在页面端用tag获取
<%@ taglib prefix='security' uri='http://www.springframework.org/security/tags'%>
<security:authentication property="principal.username"></security:authentication>
或者
<security:authorize
ifAllGranted="ROLE_ADMIN">
</security:authorize>
或者取session中的值
#session.SPRING_SECURITY_CONTEXT.authentication.principal.username等同于
3.在后台获取
UserDetails userDetails = (UserDetails)
SecurityContextHolder.getContext()
userDetails.getUsername()
想要获取更多的信息得扩展userDetails的默认实现类user类和UserDetailsService接口
由于springsecurity是把整个user信息放入session中的即:session.SPRING_SECURITY_CONTEXT.authentication.principal
这个就是代表着user对象
因此我做了扩展增加user里的信息 加上userId
代码如下:扩展user
+ expand sourceview plaincopy to clipboardprint?
package
com.avi.casExtends;
import
org.springframework.security.GrantedAuthority;
import
org.springframework.security.userdetails.User;
public class UserInfo extends
User{
}
package com.avi.casExtends;
import org.springframework.security.GrantedAuthority;
import org.springframework.security.userdetails.User;
public class UserInfo extends User{
}
实现userDetailsservice接口
+ expand sourceview plaincopy to clipboardprint?
package
com.avi.casExtends;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import
org.springframework.dao.DataAccessException;
import
org.springframework.security.GrantedAuthority;
import
org.springframework.security.GrantedAuthorityImpl;
import
org.springframework.security.userdetails.UserDetails;
import
org.springframework.security.userdetails.UserDetailsService;
import
org.springframework.security.userdetails.UsernameNotFoundExceptio
import
com.avi.dao.AccountDao;
import com.avi.data.User;
public class UserInfoService implements
UserDetailsService{

加载中…