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. 运行结果
来源: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