java实现统一账户同一时间只能在一个地方登陆
现在所做的手机软件要求类似QQ,当一处登陆.另外一处就要取消.所以查看了一下源代码.发现代码实现如下
web.xml:实现监听session作用.一旦session出现登陆、重复登录或者超时等.调用session中的方法
<!-- session管理监听 --> <listener> <listener-class>com.yitong.app.listener.SessionManageListener</listener-class> </listener>
<!-- session超时定义,单位为分钟 --> <session-config> <session-timeout>15</session-timeout> </session-config>
session类:继承自javax.servlet.http.HttpSessionListener接口,并且实现了该接口内的sessionCreated()和sessionDestroyed()两个方法,sessionCreated方法获取了从
HttpSessionListener中获取的session并创建实例.sessionDestroyed()方法负责获取session中超时或者异常状态的session加以销毁
package com.yitong.app.listener;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
import org.apache.log4j.Logger;
import com.yitong.app.communicate.bean.SessionInstance;
/**
* session管理监听类
*
* @author twf
*
*/
public class SessionManageListener implements HttpSessionListener {
private Logger logger = Logger.getLogger(this.getClass());
@Override
public void sessionCreated(HttpSessionEvent event) {
HttpSession session = event.getSession();//session监听类接收到的
logger.debug("Web 容器Session对象被创建,sid:" + session.getId());
}
@Override
public void sessionDestroyed(HttpSessionEvent event) {
try {
HttpSession session = event.getSession();
logger.debug("有session被销毁=" + session.getId());
SessionInstance instance = SessionInstance.getSessionInstance();
if(instance.hasSessionById(session.getId())){
instance.removeSessionId(session.getId());
}
// 关闭过期连接
// HttpMsgClient.cm.closeExpiredConnections();
} catch (Exception e) {
logger.error("清理session 实例失败", e);
}
}
}声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
