巧用session机制实现用户不重复登录、记录用户登录日志、统计在线人数

  • HttpSessionBindingListener

这个具体的使用文档自查,本篇中是新建了一个类实现本接口

public class UsersOnlineCountListener implements HttpSessionBindingListener {

    private User user;

    public User getUser() {
        return user;
    }

    public void setUser(User user) {
        this.user = user;
    }

    private SimpleDateFormat f = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

    @SuppressWarnings("unchecked")
    @Override
    public void valueBound(HttpSessionBindingEvent arg0) {
        // TODO Auto-generated method stub
        System.out.println("账号"+user.getAccount()+"的用户登录了"+f.format(new Date()));
        HttpSession session = arg0.getSession();
        ServletContext application = session.getServletContext();
        session.setAttribute("user", user);
        List ucList = null;
        // 第一次使用前,需要初始化
        if (application.getAttribute("ucList") == null) {
            ucList = new ArrayList();
            application.setAttribute("ucList", ucList);
        }else {
            ucList = (List)application.getAttribute("ucList");
        }

        ucList.add(user.getAccount());
        System.out.println("当前登录人数:"+ucList.size());
    }

    @SuppressWarnings("unchecked")
    @Override
    public void valueUnbound(HttpSessionBindingEvent arg0) {
        // TODO Auto-generated method stub
        System.out.println("账号"+user.getAccount()+"的用户退出了"+f.format(new Date()));
        HttpSession session = arg0.getSession();
        ServletContext application = session.getServletContext();
        session.removeAttribute("user");
        List ucList = null;
        // 第一次使用前,需要初始化
        if (application.getAttribute("ucList") == null) {
            ucList = new ArrayList();
            application.setAttribute("ucList", ucList);
        }else {
            ucList = (List)application.getAttribute("ucList");
        }

        ucList.remove(user.getAccount());
        System.out.println("当前登录人数:"+ucList.size());
    }
}

User是传值模型,UsersOnlineCountListener类实现了接口的两个方法,一个是valueBound,一个是valueUnbound,从字面上理解,在监听器与session进行绑定与解绑时调用。

  • 使用举例
UsersOnlineCountListener uocl = new UsersOnlineCountListener();
uocl.setUser(u);
this.getSession().setAttribute("uocl", uocl);

注册一个监听器,User注值,与session进行绑定,此时会调用监听器的valueBound方法。

这段代码执行有几个前提,一是用户验证通过,二是用户列表为空或者暂无当前用户,只有满足这两个条件方可算登录成功。

List<String> ucList = null;
if(this.getSession().getServletContext().getAttribute("ucList")!=null) {
    ucList = (List<String>)this.getSession().getServletContext().getAttribute("ucList");
}
if(ucList == null || !ucList.contains(u.getAccount())) {
// 上一段代码块
}else{
// 用户已登录
}

你可能感兴趣的:(java,web)