全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解Spring MVC拦截器实现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> 

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


# spring  # session  # 拦截  # session拦截器  # SpringMVC配置拦截器实现登录控制的方法  # Spring MVC--拦截器实现和用户登陆例子  # 使用spring拦截器实现日志管理实例  # Spring MVC 拦截器实现代码  # SpringMVC拦截器实现登录认证  # Spring AOP拦截-三种方式实现自动代理详解  # 拦截器  # 的人都  # 使其  # 写在  # 大家多多  # 如何实现  # 如何判断  # 包中  # SystemLoggerService  # DataUtil  # Constants  # private  # Javadoc 


相关文章: 建站主机如何安装配置?新手必看操作指南  实现点击下箭头变上箭头来回切换的两种方法【推荐】  建站之星代理如何获取技术支持?  清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?  移民网站制作流程,怎么看加拿大移民官网?  香港服务器租用每月最低只需15元?  如何选择高效便捷的WAP商城建站系统?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  如何快速生成ASP一键建站模板并优化安全性?  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  香港服务器WordPress建站指南:SEO优化与高效部署策略  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  ,怎么在广州志愿者网站注册?  ,在苏州找工作,上哪个网站比较好?  如何通过PHP快速构建高效问答网站功能?  洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?  建站主机是否属于云主机类型?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?  临沂网站制作企业,临沂第三中学官方网站?  广东企业建站网站优化与SEO营销核心策略指南  小型网站制作HTML,*游戏网站怎么搭建?  Android使用GridView实现日历的简单功能  如何用y主机助手快速搭建网站?  香港服务器租用费用高吗?如何避免常见误区?  Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解  如何快速生成凡客建站的专业级图册?  如何选择香港主机高效搭建外贸独立站?  金*站制作公司有哪些,金华教育集团官网?  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  如何用VPS主机快速搭建个人网站?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  如何用西部建站助手快速创建专业网站?  如何快速启动建站代理加盟业务?  如何在景安云服务器上绑定域名并配置虚拟主机?  PHP正则匹配日期和时间(时间戳转换)的实例代码  潮流网站制作头像软件下载,适合母子的网名有哪些?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  h5网站制作工具有哪些,h5页面制作工具有哪些?  制作宣传网站的软件,小红书可以宣传网站吗?  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  建站主机CVM配置优化、SEO策略与性能提升指南  建站之星如何保障用户数据免受黑客入侵?  建站之星后台密码遗忘如何找回?  如何通过万网虚拟主机快速搭建网站?  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  ,有什么在线背英语单词效率比较高的网站?  如何快速辨别茅台真假?关键步骤解析 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。