2个回答
展开全部
1楼的方法是对的但实现起来会有很多问题,踢掉前一次登录反而最简单,如下代码:
1、添加两个监听器类:
public class MySessionAttributeListener implements HttpSessionAttributeListener {
public static Map<String, HttpSession> sessionMap=new ConcurrentHashMap<String, HttpSession>();
@Override
public void attributeAdded(HttpSessionBindingEvent arg0) {
String name=(String)arg0.getValue();
if("name".equals(name)){//name属性保存用户登录信息,name=为唯一信息如用户名
if(sessionMap.containsKey(name)){//踢掉前一次登录
HttpSession session=sessionMap.remove(name);
session.invalidate();
}
sessionMap.put(name, arg0.getSession());
}
}
@Override
public void attributeRemoved(HttpSessionBindingEvent arg0) {}
@Override
public void attributeReplaced(HttpSessionBindingEvent arg0) {}
}
public class MySessionListener implements HttpSessionListener {
@Override
public void sessionCreated(HttpSessionEvent arg0) {}
@Override
public void sessionDestroyed(HttpSessionEvent arg0) {
String name=(String)arg0.getSession().getAttribute("name");
if(name!=null && name.length()>0){//session失效时候移除记录
if(MySessionAttributeListener.sessionMap.containsKey(name))
MySessionAttributeListener.sessionMap.remove(name);
}
//else System.out.println("注销用户:未获取到登录用户属性");
}
}
2、web.xml加入监听
<listener>
<listener-class>你的包名.MySessionListener</listener-class>
</listener>
<listener>
<listener-class>你的包名.MySessionAttributeListener</listener-class>
</listener>
3、jsp或servlet中保存登录信息如:
request.getSession().setAttribute("name", "登录信息");
1、添加两个监听器类:
public class MySessionAttributeListener implements HttpSessionAttributeListener {
public static Map<String, HttpSession> sessionMap=new ConcurrentHashMap<String, HttpSession>();
@Override
public void attributeAdded(HttpSessionBindingEvent arg0) {
String name=(String)arg0.getValue();
if("name".equals(name)){//name属性保存用户登录信息,name=为唯一信息如用户名
if(sessionMap.containsKey(name)){//踢掉前一次登录
HttpSession session=sessionMap.remove(name);
session.invalidate();
}
sessionMap.put(name, arg0.getSession());
}
}
@Override
public void attributeRemoved(HttpSessionBindingEvent arg0) {}
@Override
public void attributeReplaced(HttpSessionBindingEvent arg0) {}
}
public class MySessionListener implements HttpSessionListener {
@Override
public void sessionCreated(HttpSessionEvent arg0) {}
@Override
public void sessionDestroyed(HttpSessionEvent arg0) {
String name=(String)arg0.getSession().getAttribute("name");
if(name!=null && name.length()>0){//session失效时候移除记录
if(MySessionAttributeListener.sessionMap.containsKey(name))
MySessionAttributeListener.sessionMap.remove(name);
}
//else System.out.println("注销用户:未获取到登录用户属性");
}
}
2、web.xml加入监听
<listener>
<listener-class>你的包名.MySessionListener</listener-class>
</listener>
<listener>
<listener-class>你的包名.MySessionAttributeListener</listener-class>
</listener>
3、jsp或servlet中保存登录信息如:
request.getSession().setAttribute("name", "登录信息");
2013-08-05
展开全部
使用session+DB记录。登录时,记录下来,未登了前,不接受另一个登录。——当然要处理浏览器突然关闭的意外。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询