SpringMVC入门(五)SpringMVC拦截器的使用

前言

     本章讲解SpringMVC拦截器的使用

方法

1.概念

首先要明确一点,在我们的web开发中,有过滤器、监听器等简单的工具,接下来要讲解的是基于SpringMVC的拦截器,可以理解为一个精细化的过滤器。

对于过滤器和监听器我们应该不陌生,它们都是配置在web.xml中的,在之前的学习中我们或多或少的也见到过,只不过在我的博客中没有进行专门的讲解,或许我会专门讲解一下这两个!

比如SpringMVC的字符编码过滤器:

<!-- 配置字符编码过滤器 -->
<filter>
    <filter-name>characterEncoding</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>
</filter>

<filter-mapping>
    <filter-name>characterEncoding</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

再比如加载spring配置文件的监听器:

<!-- 加载Spring配置文件 -->
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
</context-param>

拦截器原理与过滤器类似,但是要比过滤器更加的细化!

它的作用在于拦截用户发送的请求,也就是在controller方法执行前后进行相应的操作!

唉?这个和AOP好像有点相似啊!但是要注意一点,AOP是拦截任意方法的,而我们的拦截器只拦截controller方法

2.使用拦截器

1)新建拦截器类testInterceptor.java

package cn.edu.ccut.interceptor;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * @Auther:jwang
 * @Date:2019/1/10
 * @Description:cn.edu.ccut.interceptor
 * @Version 1.0
 **/
public class TestInterceptor implements HandlerInterceptor {
    //进入控制器之前执行,true表示可以执行控制器,false表示不能执行控制器
    @Override
    public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
        System.out.println("我是preHandle");
        return true;
    }

    //控制器执行完成,进入jsp之前执行
    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
        System.out.println("我是postHandle");
    }
    //jsp执行完成后执行
    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
        System.out.println("我是afterCompletion");
    }
}

2)在spring-servlet.xml中配置拦截器

<!-- 配置拦截器 -->
<mvc:interceptors>
    <mvc:interceptor>
        <!-- 配置拦截器拦截请求的url -->
        <mvc:mapping path="/test1"/>
        <!-- 配置拦截器类 -->
        <bean class="cn.edu.ccut.interceptor.TestInterceptor"></bean>
    </mvc:interceptor>
</mvc:interceptors>

3)配置controller并执行程序,查看运行结果

到这里,一个最简单的拦截器就配置好了!

那么拦截器主要有什么应用呢?

 它主要有一些日志记录,过滤敏感词语等功能

实例:过滤敏感词语

配置如下controller方法,模拟用户输入敏感词语:

@RequestMapping("/test1")
public String test1(HttpServletRequest request){
    request.setAttribute("username","垃圾");
    request.setAttribute("password","李某某");
    System.out.println("我是controller方法");
    return "test";
}

这里我们认为垃圾是敏感词汇,此时我们应该将其过滤为**

编写拦截器代码如下:

//控制器执行完成,进入jsp之前执行
@Override
public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
    String username = httpServletRequest.getAttribute("username").toString();
    if(username.contains("垃圾")){
        username = username.replace("垃圾", "**");
    }
    httpServletRequest.setAttribute("username",username);
    System.out.println("我是postHandle");
}

查看运行结果:

成功的处理掉了用户提交的敏感词汇! 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值