基于session简单的实现单点登录

本文介绍了Web服务器如何利用Session和Cookie实现单点登录(SSO)。每个浏览器实例对应一个Session,Session ID存储在Cookie中。新窗口若属于同一实例,则共享Session;反之,则创建新Session。登录验证、注销处理均涉及Session管理。对于移动端SSO,文中提到目前尚无明确解决方案。

web服务器为每一个浏览器实例对应一个session。

这个session有自己的一个独立id,这个id保存在浏览器的cookie中(这个cookie貌似随着这个浏览器实例的关闭而清除),

访问web服务器的时候,web服务会根据你cookie中的sessionId来决定重新创建一个session还是使用已经存在的session。

如果使用桌面的ie图标打开一个IE窗口,这个窗口属于一个新的浏览器实例(其中不包含sessionid信息),

这时候用这个IE访问web服务器的时候web服务器会为这个浏览器实例新创建一个httpsession,

sessionId也是新的(sessionId保存到本地的cookie中),

不会对你以前打开的窗口中的session产生覆盖,关闭ie窗口的时候cookie中的信息也就清除掉了。 

如果是在打开的ie窗口中按“ctrl+n”打开一个ie窗口,这个窗口于刚才的窗口是同一个实例,

与刚才的窗口共用session,所有的同一个ie实例的窗口都关掉后,会清除掉sessionId。


登陆之后验证:

//用户登录成功后,更新session Map,如重复登录,强制之前session过期  
String sessionid = UserSession.userMap.get(username);  
UserSession userSession = new UserSession();
if(sessionid != null&&!sessionid.equals("")){
    //注销在线用户,如果session id 相同,不销毁。  
    if(!sessionid.equals(request.getSession().getId())){ 
    	userSession.destroyed(username, request);
    	userSession.created(username, request);
    }  
}else{
	userSession.created(username, request);
} 


处理请求:

@WebListener
public class UserSession implements HttpSessionListener {
	
	public static HashMap<String,String> userMap = new HashMap<String,String>();  

	public static HashMap<String,HttpSession> sessionMap = new HashMap<String,HttpSession>();  
	
	//使session失效,并移除map
	public void destroyed(String username, HttpServletRequest request) {
		String sessionid = userMap.get(username);
		sessionMap.get(sessionid).invalidate();
		sessionMap.remove(sessionid);
		userMap.remove(username);
	}
	
	//将session信息存入map
	public void created(String username, HttpServletRequest request) {
		HttpSession session = request.getSession();
		userMap.put(username, session.getId());  
		sessionMap.put(session.getId(), session);  
	}

	@Override  
	public void sessionCreated(HttpSessionEvent httpSessionEvent) {  

	}  

	@Override
	public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
	}  
}



注销需移除相应的map:

SecurityUtils.getSubject().logout(); // session会销毁,在SessionListener监听session销毁,清理权限缓存
	if(UserSession.sessionMap.containsKey(request.getSession().getId())){  
	    UserSession.sessionMap.remove(request.getSession().getId());  
	    for(String key : UserSession.userMap.keySet()){
	        if(UserSession.userMap.get(key).equals(request.getSession().getId())){  
	            UserSession.userMap.remove(key);
	            break;
	        }  
	     } 
	 }

该方法只适用于web的单点登录,移动端的单点登录暂时没有思路,还请大大们指教。






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值