一个账号只能在一台机器上登录,如果在其他机器上登录,则原来的session自动失效。利用Listener实现单态登录,不会与Servlet有任何的耦合!前后台登录相关代码省略。。。。注意在登录成功后将用户对象加入session,前台每个页面需要每间隔5000毫秒左右检测用户session是否为null,所以建议把前台检测session相关代码放在一个通用页面。如果是null的说明账号在其他机器上登录,你的session被remove了。这时常规做法是给用户提示,并弹登录界面!下面是主要是监听器核心代码部分。
package com.zh.listener;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionAttributeListener;
import javax.servlet.http.HttpSessionBindingEvent;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import com.hr.entity.Sysuuser;
/**
* 实现单态登录
* @author Administrator
*
*/
public class LogonSeionListener implements HttpSessionAttributeListener{
Map<String,HttpSession> map = new HashMap<String, HttpSession>();
@Override
public void attributeAdded(HttpSessionBindingEvent event) {
String name = event.getName();
if(name.equals("user")){
Sysuuser user= (Sysuuser) event.getValue();
//若Map中存在改账号
if(map.get(user.getUsruname())!=null){
//map集合中有记录,表示该账号在其他机器上登录过
HttpSession session=map.get(user.getUsruname());
Sysuuser oldsysuuser=(Sysuuser)session.getAttribute("user");
session.removeAttribute("user");
session.setAttribute("msg","您的账号在其他机器上登录,您被迫下线");
}
//将session以用户名为索引,放入Map
map.put(user.getUsruname(),event.getSession());
}
}
@Override
public void attributeRemoved(HttpSessionBindingEvent event) {
String name = event.getName();
if(name.equals("user")){
Sysuuser oldsysuuser= (Sysuuser) event.getValue();
map.remove(oldsysuuser.getUsruname());
}
}
@Override
public void attributeReplaced(HttpSessionBindingEvent event) {
String name = event.getName();
if(name.equals("user")){
Sysuuser oldsysuuser= (Sysuuser) event.getValue();
//移除旧的登录信息
map.remove(oldsysuuser.getUsruname());
Sysuuser user= (Sysuuser) event.getSession().getAttribute("user");
if(map.get(user.getUsruname())!=null){
//map集合中有记录,表示该账号在其他机器上登录过
HttpSession session=map.get(user.getUsruname());
session.removeAttribute("user");
session.setAttribute("msg","您的账号在其他机器上登录,您被迫下线");
}
map.put(user.getUsruname(),event.getSession());
}
}
}