zoukankan      html  css  js  c++  java
  • Java通过sessionId获取Session

    Servlet2.1之后不支持SessionContext里面getSession(String id)方法。

    但是,我们可以通过HttpSessionListener监听器和全局静态map自己实现一个SessionContext。

    MySessionContext.java:

    public class MySessionContext {
        private static HashMap mymap = new HashMap();

        public static synchronized void AddSession(HttpSession session) {
            if (session != null) {
                mymap.put(session.getId(), session);
            }
        }

        public static synchronized void DelSession(HttpSession session) {
            if (session != null) {
                mymap.remove(session.getId());
            }
        }

        public static synchronized HttpSession getSession(String session_id) {
            if (session_id == null)
            return null;
            return (HttpSession) mymap.get(session_id);
        }
    }

    MySessionListener.java:

    public class MySessionListener implements HttpSessionListener {
        public void sessionCreated(HttpSessionEvent httpSessionEvent) {
        MySessionContext.AddSession(httpSessionEvent.getSession());
        }

        public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
            HttpSession session = httpSessionEvent.getSession();
            MySessionContext.DelSession(session);
        }

    }

    web.xml添加一个监听器:

    <listener>
    <listener-class>listener.MySessionListener</listener-class>
    </listener>

    根据sessionId获取Session对象:

    String sessionId = request.getParameter("sessionId");

    HttpSession session = MySessionContext.getSession(sessionId);

  • 相关阅读:
    数字证书原理(转)
    python update from 2.6 to 2.7
    python uwsgi 部署以及优化
    uWSGI配置(转 )
    Python程序的性能分析指南(转)
    mysql 暴力破解 root账号密码
    VMware虚拟机实用经验总结十一条
    小技巧之指定refer
    cookie和session
    web相关
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13317866.html
Copyright © 2011-2022 走看看