java实现当前用户登录挤掉后台用户登录

思路说明:首先创建一个map,因为map是不可重复的键值对。使用登录用户的id作为key,当用户登录的时候,就产生一个session作为value。将其保存一起。此时改账号在别处登录的时候,会产生一个相当的key,但是不同的value。这是使用拦截器写代码清楚上一次的map。然后保存这一次的。这样已登录的用户就会被当前用户挤下来。

核心代码如下:

1.登录的时候创建map

        ServletContext application=request.getSession().getServletContext();
            String userIdSession = String.valueOf(user.get(0).getUserid());
            @SuppressWarnings("unchecked")
            Map<String, String> loginMap = (Map<String, String>)application.getAttribute("loginMap");
            if(loginMap==null){
                loginMap = new HashMap<String, String>();
            }
            loginMap.put(userIdSession,request.getSession().getId());
            application.setAttribute("loginMap", loginMap);

2.写一个全局拦截器,实现Filter接口,在doFiter方法里面写如下代码

      // 获取request
        HttpServletRequest request=(HttpServletRequest)args0;
        SessionInfo sessionInfo=SessionHelper.getSessionInfo(request);
        SessionInfo adminSession = SessionHelper.getAdminSessionInfo(request);
        
        HttpServletResponse response=(HttpServletResponse)args1;
        
        String uri = request.getRequestURI();
        
        if(uri.indexOf("login")!=-1 || uri.indexOf("changeImage")!=-1){
            chain.doFilter(request, response);
            return;
        }
        
        //前台同时只能一个账号在线
        ServletContext application=request.getSession().getServletContext();
        Map<String, String> loginMap = (Map<String, String>)application.getAttribute("loginMap");
        if(loginMap!=null && !StringUtils.isNull(sessionInfo)){
            for(String key:loginMap.keySet()) {
                
                if (String.valueOf(sessionInfo.getUser().getUserid()).equals(key)) {
                    if(!request.getSession().getId().equals(loginMap.get(key))) {
                        String content_path = request.getContextPath();
                        request.removeAttribute("loginMap");
                        response.sendRedirect(content_path+"/visitor/users/login.do?flag=VALID");
                        System.out.println(content_path+"/visitor/users/login.do?flag=VALID");
                        return;
                    }
                }
            }
        }

3.web.xml里面配置

  <listener>
    <description>spring监听器</description>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <listener>
    <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
  </listener>
  <listener>
    <listener-class>org.springframework.web.context.request.RequestContextListener </listener-class>
  </listener>
  <filter>
    <filter-name>characterEncodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
      <param-name>forceEncoding</param-name>
      <param-value>true</param-value>
    </init-param>
  </filter>
  <filter-mapping>
    <filter-name>characterEncodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
  <filter>
    <filter-name>SecurityInvalidate</filter-name>
    <filter-class>com.project.filter.EmallAntiSqlInjectionfilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>SecurityInvalidate</filter-name>
    <url-pattern>*.do</url-pattern>
  </filter-mapping>

  • 9
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值