Spring MVC中自定义 * 的实例讲解

作者:jingxian 时间:2023-12-19 05:09:04 

1. 引言

* (Interceptor)实现对每一个请求处理前后进行相关的业务处理,类似于Servlet的Filter。

我们可以让普通的Bean实现HandlerIntercpetor接口或继承HandlerInterceptorAdapter类来实现自定义 * 。

通过重写WebMvcConfigurerAdapter的addIntercetors方法来注册一个计算每一次请求的处理时间的 * 。

2. 自定义 * 的实现

2.1 定义 *

新建LogInterceptor类,并继承HandlerInterceptorAdapter类,重写preHandle、postHandle这两个方法。

1.preHandle方法表示在请求发生前执行,内容如下:


public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
request.setAttribute("begin", System.currentTimeMillis());
return true;
}

2.postHandle方法表示在请求完成后执行,内容如下:


@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
long begin = (long)request.getAttribute("begin");
request.removeAttribute("begin");
long end = System.currentTimeMillis();
System.out.println("本次请求消耗时间为:"+new Long(end-begin)+"ms");
}

2.2 配置 *

2.2.1 使用xml配置

1.在配置文件中添加支持MVC的schema


xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation=" http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"

2.使用mvc:interceptors标签声明 *


<mvc:interceptors>
<!-- 使用bean定义一个Interceptor,直接定义在mvc:interceptors根下面的Interceptor将拦截所有的请求 -->
<bean class="org.aming.demo.springmvc.interceptor.LogInterceptor"/>
<mvc:interceptor>
<mvc:mapping path="${指定的URL}"/>
<!-- 定义在mvc:interceptor下面的表示是对特定的请求才进行拦截的 -->
<bean class="${其他 * }"/>
</mvc:interceptor>
</mvc:interceptors>

说明:没有测试过!!!

2.2.2 使用JavaConfig配置

3.配置 * 的Bean


@Bean
public LogInterceptor logInterceptor() {
return new LogInterceptor();
}

4.重写addInterceptors方法,注册 *


@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(logInterceptor());
}

说明:配置类需要继承WebMvcConfigurerAdapter类

3. 运行结果

Spring MVC中自定义 * 的实例讲解

来源:http://www.cnblogs.com/xiao2/p/7412389.html

标签:自定义, , ,Spring,MVC
0
投稿

猜你喜欢

  • Java 数据结构与算法系列精讲之单向链表

    2023-07-10 08:22:12
  • 从零实现一个简单的Spring Bean容器的代码案例

    2022-07-24 11:42:16
  • Java分布式服务框架Dubbo介绍

    2022-09-16 01:27:53
  • java动态口令登录实现过程详解

    2022-01-01 10:16:28
  • startJVM错误Unable to load native library: libjvm.so解决方法

    2023-03-24 08:54:29
  • Java数组(Array)最全汇总(中篇)

    2022-09-05 06:01:02
  • IntelliJ IDEA 15款超级牛逼插件推荐(自用,超级牛逼)

    2023-10-10 05:51:22
  • redisson 实现分布式锁的源码解析

    2022-06-05 05:38:47
  • 使用JPA自定义VO类型转换(EntityUtils工具类)

    2023-08-26 14:56:17
  • Unity实现图片轮播组件

    2023-03-19 05:12:33
  • java 线程方法join简单用法实例总结

    2022-10-26 19:27:38
  • 浅谈单例模式和线程安全问题

    2023-11-25 06:27:34
  • java方法及this关键字原理分析详解

    2021-08-16 07:51:35
  • 解决springboot生成bean名称冲突(AnnotationBeanNameGenerator)

    2023-01-09 22:27:11
  • C#实现SMTP邮件附件发送功能详解

    2022-08-14 10:09:38
  • Java设计模式之装饰模式详解

    2022-09-27 05:55:32
  • mybatis一直加载xml,找到错误的解决方案

    2022-08-12 14:55:26
  • 轻松实现Rxjava定时器功能

    2022-03-12 06:23:27
  • java实现文件下载的两种方式

    2023-11-11 06:37:14
  • java程序员如何编写更好的单元测试的7个技巧

    2023-09-05 14:57:24
  • asp之家 软件编程 m.aspxhome.com