在基于注解风格的Spring-MVC中使用拦截器

本文介绍Spring MVC框架中如何使用注解方式配置拦截器。主要通过DefaultAnnotationHandlerMapping实现自定义拦截器的注册,并提供了一个ExceptionInterceptor的具体实现示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Spring-MVC如何使用拦截器,今天看了一下官方文档,没有找到注解的例子,只给出了非注解风格的例子。基于注解风格如何使用拦截器呢?

基于注解有两个可以使用的定义类,分别是DefaultAnnotationHandlerMapping

AnnotationMethodHandlerAdapter

<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>

 DefaultAnnotationHandlerMapping本身支持自定义拦截器,配置如下

<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping">
		<property name="interceptors">
			<list>
				<bean class="com.chenzhou.blog.comment.interceptor.ExceptionInterceptor"/>
			</list>
		</property>
</bean>

 Interceptor的定义如下:

public class ExceptionInterceptor extends HandlerInterceptorAdapter {
	@Override
	public boolean preHandle(HttpServletRequest request,
			HttpServletResponse response, Object handler) throws Exception {
		
		// TODO Auto-generated method stub
		return super.preHandle(request, response, handler);
		
	}
	@Override
	public void postHandle(HttpServletRequest request,
			HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		
		// TODO Auto-generated method stub
		super.postHandle(request, response, handler, modelAndView);
		
	}
}
 

在AnnotationMethodHandlerAdapter中还没有找到如何配置自定义Interceptor的方法!

 

 

### Spring MVC 拦截器相关注解及其用法 在Spring MVC中,拦截器可以通过多种方式定义和使用。为了更好地理解这些概念并展示其应用,以下是关于如何利用特定注解来实现和配置拦截器的内容。 #### 定义自定义拦截器类 通常情况下,开发者会创建一个新的Java类,并让其实现`HandlerInterceptor`接口或扩展`HandlerInterceptorAdapter`抽象类。此类可以重写三个主要的方法——`preHandle()`、`postHandle()`以及`afterCompletion()`,它们分别对应于请求处理前后的不同阶段操作[^4]。 对于希望更方便地运用AOP风格编程模式的情况,则可以选择标注有`@Component`的组件级bean形式编写拦截逻辑,并配合其他必要的元数据标签一起工作: ```java @Component public class MyCustomInterceptor extends HandlerInterceptorAdapter { private static final Logger logger = LoggerFactory.getLogger(MyCustomInterceptor.class); @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 执行前置动作... return true; // 返回false表示中断后续执行链路 } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 处理视图渲染之前的操作... } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // 清理资源或其他收尾事宜... } } ``` #### 配置全局/局部作用域内的拦截器 为了让上述自定义拦截器生效,还需要将其注册至Spring上下文中。这一步骤可通过两种途径完成:一是基于XML配置文件的方式;二是采用更为现代且推荐的做法即借助Java Config代码片段来进行声明式的装配管理。这里重点介绍后者所涉及的关键知识点。 当不启用`@EnableWebMvc`特性开关时,默认情况下所有的内置映射处理器都会自动调用`AbstractHandlerMapping.initApplicationContext()`钩子函数去扫描整个IoC容器内所有符合条件的对象实例作为候选者加入到内部维护着的一组拦截链条之中[^3]。因此只需简单地标记好目标Bean即可达成目的。 而一旦激活了该选项之后,则意味着完全接管住了HTTP请求分发过程中的控制权转移给用户自己掌控下的策略定制化空间变得更大也更加灵活多变。此时应当考虑显式指定哪些地方应该被监控起来,具体做法是在实现了`WebMvcConfigurer`接口的服务提供方里边覆写`addInterceptors(Registry registry)`方法并向参数对象传递进去一系列由`MappedInterceptor`封装而成的新成员[^2]。 ```java @Configuration @EnableWebMvc public class WebConfig implements WebMvcConfigurer { @Autowired private MyCustomInterceptor myCustomInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(myCustomInterceptor).addPathPatterns("/api/**"); } } ``` 另外值得注意的是,在某些特殊场景下可能还会涉及到跨多个模块共享相同行为的需求场合,这时就可以充分利用起`@Order`这样的优先级指示符来确保各个参与者之间能够按照预期顺序依次发挥作用而不至于相互干扰冲突[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值