SpringMVC 自定义拦截器

1.跟过滤器比较像的技术.

2.发送请求时被拦截器拦截,在控制器的前后添加额外功能.

    2.1 跟 AOP 区分开.AOP 在特定方法前后扩充(对 ServiceImpl)

    2.2 拦截器,请求的拦截.针对点是控制器方法.(对 Controller)

3.SpringMVC 拦截器和 Filter 的区别

    3.1 拦截器只能拦截器 Controller

    3.2 Filter 可以拦截任何请求.

4.实现自定义拦截器的步骤:

    4.1 新建类实现 HandlerInterceptor

public class DemoInterceptor implements
HandlerInterceptor {
    //在进入控制器之前执行
    //如果返回值为 false,阻止进入控制器
    //控制代码
@Override
public boolean preHandle(HttpServletRequest arg0,HttpServletResponse arg1, Object arg2) throws Exception{
    System.out.println("arg2:"+arg2);
    System.out.println("preHandle");
    return true;
}
    //控制器执行完成,进入到 jsp 之前执行.
    //日志记录.
    //敏感词语过滤
@Override
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3) throws Exception {
    System.out.println("往"+arg3.getViewName()+"跳转");
    System.out.println("model 的值"+arg3.getModel().get("model"));
    String word =arg3.getModel().get("model").toString();
    String newWord = word.replace("祖国", "**");
    arg3.getModel().put("model", newWord);
    System.out.println("postHandle");
}
    //jsp 执行完成后执行
    //记录执行过程中出现的异常.
    //可以把异常记录到日志中
@Override
public void afterCompletion(HttpServletRequest arg0,HttpServletResponse arg1, Object arg2, Exception arg3)throws Exception {
    System.out.println("afterCompletion"+arg3.getMessage());
}
}

    4.2 在 springmvc.xml 配置拦截器需要拦截哪些控制器

        4.2.1 拦截所有控制器

<mvc:interceptors>
    <bean class="com.bjsxt.interceptor.DemoInterceptor"></bean>
</mvc:interceptors>

        4.2.2 拦截特定的的 url

<mvc:interceptors>
    <mvc:interceptor>
        <mvc:mapping path="/demo"/>
        <mvc:mapping path="/demo1"/>
        <mvc:mapping path="/demo2"/>
        <bean class="com.bjsxt.interceptor.DemoInterceptor"></bean>
    </mvc:interceptor>
</mvc:interceptors>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring MVC自定义拦截器有以下步骤: 1. 创建一个实现HandlerInterceptor接口的拦截器类。在该类中实现preHandle、postHandle、afterCompletion三个方法。 2. 在Spring配置文件中配置该拦截器。可以使用<mvc:interceptors>标签配置,也可以使用注解@Configuration和@EnableWebMvc配置。 3. 配置拦截器拦截规则。可以使用<mvc:interceptor>标签配置,也可以使用注解@Interceptor和@Order配置。 4. 使用拦截器。在Controller类或方法上使用注解@Interceptor或@WebMvcConfigurerAdapter.addInterceptors()方法添加拦截器。 以下是一个简单的示例: 1. 创建拦截器类 public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("MyInterceptor preHandle"); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { System.out.println("MyInterceptor postHandle"); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { System.out.println("MyInterceptor afterCompletion"); } } 2. 配置拦截器 <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <bean class="com.example.MyInterceptor"/> </mvc:interceptor> </mvc:interceptors> 3. 配置拦截规则 @Interceptor @Order(1) public class MyInterceptor implements HandlerInterceptor { ... } 4. 使用拦截器 @Controller public class MyController { @Interceptor(MyInterceptor.class) @RequestMapping("/hello") public String hello() { return "hello"; } }

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值