详解Spring MVC拦截器实现session控制

 更新时间:2017年01月09日 10:47:19   作者:geloin  
这篇文章主要介绍了详解Spring MVC拦截器实现session控制,使用session监听,重复登录后,强制之前登录的session过期。有兴趣的可以了解一下。

未登录,不允许访问background文件夹内的页面,那如何判断是否登录呢?background是关键目录,每个操作该目录的人都需要写在日志表中,如何实现呢?拦截器是实现方案之一。 

(1) 在com.geloin.spring.interceptor包中添加SystemInterceptor,并使其继承HandlerInterceptor

/** 
 * 
 * @author geloin 
 */ 
package com.geloin.spring.interceptor; 
 
import java.io.PrintWriter; 
import java.util.Iterator; 
import java.util.Map; 
 
import javax.annotation.Resource; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
 
import org.springframework.stereotype.Repository; 
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter; 
 
import com.embest.ruisystem.form.SystemLoggerForm; 
import com.embest.ruisystem.form.SystemUserForm; 
import com.embest.ruisystem.service.SystemLoggerService; 
import com.embest.ruisystem.util.Constants; 
import com.embest.ruisystem.util.DataUtil; 
 
/** 
 * 
 * @author geloin 
 */ 
@Repository 
public class SystemInterceptor extends HandlerInterceptorAdapter { 
 
  @Resource(name = "systemLoggerService") 
  private SystemLoggerService systemLoggerService; 
 
  /* 
   * (non-Javadoc) 
   * 
   * @see 
   * org.springframework.web.servlet.handler.HandlerInterceptorAdapter#preHandle 
   * (javax.servlet.http.HttpServletRequest, 
   * javax.servlet.http.HttpServletResponse, java.lang.Object) 
   */ 
  @SuppressWarnings({ "rawtypes", "unchecked" }) 
  @Override 
  public boolean preHandle(HttpServletRequest request, 
      HttpServletResponse response, Object handler) throws Exception { 
 
    request.setCharacterEncoding("UTF-8"); 
    response.setCharacterEncoding("UTF-8"); 
    response.setContentType("text/html;charset=UTF-8"); 
 
    // 后台session控制 
    String[] noFilters = new String[] { "login.html", "veriCode.html", 
        "index.html", "logout.html" }; 
    String uri = request.getRequestURI(); 
 
    if (uri.indexOf("background") != -1) { 
      boolean beFilter = true; 
      for (String s : noFilters) { 
        if (uri.indexOf(s) != -1) { 
          beFilter = false; 
          break; 
        } 
      } 
      if (beFilter) { 
        Object obj = request.getSession().getAttribute( 
            Constants.LOGINED); 
        if (null == obj) { 
 
          // 未登录 
          PrintWriter out = response.getWriter(); 
          StringBuilder builder = new StringBuilder(); 
          builder.append("<script type=\"text/javascript\" charset=\"UTF-8\">"); 
          builder.append("alert(\"页面过期,请重新登录\");"); 
          builder.append("window.top.location.href=\""); 
          builder.append(Constants.basePath); 
          builder.append("/background/index.html\";</script>"); 
          out.print(builder.toString()); 
          out.close(); 
          return false; 
        } else { 
          // 添加日志 
          String operateContent = Constants.operateContent(uri); 
          if (null != operateContent) { 
            String url = uri.substring(uri.indexOf("background")); 
            String ip = request.getRemoteAddr(); 
            Integer userId = ((SystemUserForm) obj).getId(); 
            SystemLoggerForm form = new SystemLoggerForm(); 
            form.setUserId(userId); 
            form.setIp(ip); 
            form.setOperateContent(operateContent); 
            form.setUrl(url); 
            this.systemLoggerService.edit(form); 
          } 
        } 
      } 
    } 
 
    Map paramsMap = request.getParameterMap(); 
 
    for (Iterator<Map.Entry> it = paramsMap.entrySet().iterator(); it 
        .hasNext();) { 
      Map.Entry entry = it.next(); 
      Object[] values = (Object[]) entry.getValue(); 
      for (Object obj : values) { 
        if (!DataUtil.isValueSuccessed(obj)) { 
          throw new RuntimeException("有非法字符:" + obj); 
        } 
      } 
    } 
 
    return super.preHandle(request, response, handler); 
  } 
 
} 

(2) 修改context-dispatcher.xml,让spring管理拦截器

<mvc:interceptors> 
  <bean class="com.geloin.spring.interceptor.SystemInterceptor" /> 
</mvc:interceptors> 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Java8新特性之重复注解与类型注解详解

    Java8新特性之重复注解与类型注解详解

    这篇文章主要使介绍了Java8新特性重复注解与类型注解,文章还介绍了JDK5中的注解与之对比,感兴趣的朋友可以参考下面具体文章内容
    2021-09-09
  • springboot后端如何实现携带token登陆

    springboot后端如何实现携带token登陆

    这篇文章主要介绍了springboot后端如何实现携带token登陆,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • JAVA异常分类和处理解析

    JAVA异常分类和处理解析

    这篇文章主要介绍了JAVA异常分类和处理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • Java四种常用线程池的详细介绍

    Java四种常用线程池的详细介绍

    今天小编就为大家分享一篇关于Java四种常用线程池的详细介绍,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • Java线程状态及同步锁的操作方法

    Java线程状态及同步锁的操作方法

    Java中的thread类自带有线程的一些方法,这些方法可以让线程睡眠,插队,提高线程调度的优先级等等,它们提供了改变线程状态的操作手段,这篇文章主要介绍了Java线程状态及同步锁,需要的朋友可以参考下
    2021-11-11
  • Mybatis in条件传参的三种实现方式(直接$,List,[])

    Mybatis in条件传参的三种实现方式(直接$,List,[])

    这篇文章主要介绍了Mybatis in条件传参的三种实现方式(直接$,List,[]),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • java开发中基于JDBC连接数据库实例总结

    java开发中基于JDBC连接数据库实例总结

    这篇文章主要介绍了java开发中基于JDBC连接数据库的方法,以实例形式较为详细的总结分析了Java使用JDBC的具体步骤与注意事项,并附带了一个完整实例加以说明,需要的朋友可以参考下
    2015-11-11
  • Java遍历Json的简单实例

    Java遍历Json的简单实例

    这篇文章主要介绍了Java遍历Json的简单实例,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • Spring Boot拦截器和监听器实现对请求和响应处理实战

    Spring Boot拦截器和监听器实现对请求和响应处理实战

    这篇文章主要介绍了Spring Boot拦截器和监听器实现对请求和响应处理实战,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • Spring Data Jpa框架最佳实践示例

    Spring Data Jpa框架最佳实践示例

    这篇文章主要为大家介绍了Spring Data Jpa框架最佳实践示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-02-02

最新评论