spring mvc 拦截器路径匹配原则

本文介绍 Spring MVC 中的路径匹配方法,包括通配符的使用及HandlerMapping的工作原理。详细解析了不同通配符的意义,并通过案例说明了如何配置拦截器和映射处理器。

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

 

一 案例

<mvc:interceptors>
		<mvc:interceptor>
			<!-- 对所有的.do结尾的进行拦截,/**表示/下面任何字段,起初我用/*/*.do后来发现/*不能代表所有的字段,要使用/** -->
			<mvc:mapping path="/**/*.do" />
			<!-- 登录 -->
			<mvc:exclude-mapping path="/**/login.do" />
			<mvc:exclude-mapping path="/**/findDepartmentsBeforLogin.do" />
			<!--退出 -->
			<mvc:exclude-mapping path="/**/loginOut.do" />
			<!-- 跳转登录页面 -->
			<mvc:exclude-mapping path="/**/toLogin.do" />
			<bean class="com.xxx.interceptor.login.LoginInterceptor">
				<!--adminId 配置是为了开发人员使用的权限 -->
				      <!-- <property name="adminId" value="1"/>     -->
			</bean>
		</mvc:interceptor>
	</mvc:interceptors> 

二 路径通配符匹配方法
 

 

WildcardDescription 
?匹配任何单字符 
*匹配0或者任意数量的字符 
**匹配0或者更多的目录

1案例

 

PathDescription 
/app/*.x匹配(Matches)所有在app路径下的.x文件 
/app/p?ttern匹配(Matches) /app/pattern 和 /app/pXttern,但是不包括/app/pttern 
/**/example匹配(Matches) /app/example, /app/foo/example, 和 /example 
/app/**/dir/file.匹配(Matches) /app/dir/file.jsp, /app/foo/dir/file.html,/app/foo/bar/dir/file.pdf, 和 /app/dir/file.java 
/**/*.jsp匹配(Matches)任何的.jsp 文件

三 HandlerMapping

 

  1. Spring提供了URL的映射处理, 并且处理路径模式的顺序和方法并没有限定到任何的接口上。
  2. Spring MVC的默认实现org.springframework.web.servlet.handler. AbstractUrlHandlerMapping, 会以最长符合路径模式来匹配一个路径。
    1. 例如:
      • 给定一个请求是 /app/dir/file.jsp 并且现在存在两个路径匹配模式/**/*.jsp 和/app/dir/*.jsp, 那么,URL会匹配那个模式呢?最后的那个模式/app/dir/*.jsp,会因为最长的原则被匹配,它比/**/*.jsp拥有更多的字符,注意的是,这个原则并没有在任何高级别的接口中指定,但却是一种实现细节。

3.1 下面看一下默认的两个HandlerMapping

1. BeanNameUrlHandlerMapping

默认的映射策略实现是org.springframework.web. servlet.handler.BeanNameUrlHandlerMapping类.

这个类要求任何有可能处理请求的Bean都要起一个以反斜杠(/)字符开头的名称或者别名,这个名称或者别名可以是符合URL Path匹配原则中的任何名字。

案例

xml 代码
 

<bean name="/home"  class="com.apress.expertspringmvc.flight.web.HomeController">  

<property name="flightService" ref="flightService" /> 

</bean>

1.1.注意:

  1. 你不能使用id这个属性来指定任何的URL路径,因为在XML规格定中禁止(/)字符来指定XML的id,不过你可以在一个Bean定义中同时拥有id和name属性
  2. 它非常便于使用的同时,也拥有一些缺点。它不能影射一个Prototype的Bean.换句话说,当使用 BeanNameUrlHandlerMapping时, 所有的请求处理类只能是单例的(singletons) . 一般来说,Controllers都是按照单例建立的,所以这个并不是一个很严重的问题 
  3. Prototype bean 是一种非单例(non-singleton)的bean. 任何一次调用ApplicationContext的getBean()方法时都会返回一个新的Bean实例.

 

1.2 BeanNameUrlHandlerMapping的另外一个问题存在于应用拦截(interceptor).

因为请求的映射(handler mapping )和Bean(beans imapping)的映射给绑定在一起了,没有分开,这样就不可能在Controller和拦截之间创建复杂的关系。如果有复杂的请求映射需求,你可以用 SimpleUrlHandlerMapping 来代替BeanNameUrlHandlerMapping.

2. SimpleUrlHandlerMapping

  1. 它可以映射 prototype类型的请求处理器,并且它允许你为处理器(handlers)和拦截器(interceptors)之间创建复杂灵活的映射路径的映射算法
  2. 这个模式依然是映射URL到请求处理器的(request handler) ,你简单的在ApplicationContext中声明一下,就可以使用SimpleUrlHandlerMapping了. DispatcherServlet会根据类型找到的,并

 

 

Spring MVC拦截器是一种强大的功能,它允许开发者在请求处理之前、之后或特定的处理器方法调用期间添加额外的功能。要注册和配置Spring MVC拦截器,你可以按照以下步骤操作: 1. 创建拦截器类:首先创建一个实现了`HandlerInterceptor`接口或其子接口(如`WebRequestInterceptor`)的Java类。这个接口定义了三种方法:preHandle(), postHandle(), 和 postHandle(),分别对应请求处理前、处理中和处理后的操作。 ```java import org.springframework.web.servlet.HandlerInterceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class CustomInterceptor implements HandlerInterceptor { // 实现相应的方法... } ``` 2. 配置拦截器:在Spring MVC的配置文件中,通常是`web.xml`或XML配置文件(如`applicationContext-servlet.xml`),你需要添加一个`<mvc:interceptors>`元素,并配置你的自定义拦截器。可以使用`<bean>`标签定义拦截器,并指定它的`order`属性来控制拦截顺序,值越小优先级越高。 ```xml <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**" /> <!-- 匹配所有URL --> <bean class="com.example.CustomInterceptor"> <property name="order" value="1" /> </bean> </mvc:interceptor> </mvc:interceptors> ``` 3. 配置全局或特定处理程序的拦截:如果你想让拦截器对整个应用程序生效,就使用全局映射。如果只需要对某些控制器或方法进行拦截,则可以配置`<mvc:handlerMapping>`或`<mvc:annotation-driven>`。 ```xml <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/protected/*" /> <!-- 只对特定路径下的请求生效 --> <bean class="com.example.ProtectedInterceptor" /> </mvc:interceptor> </mvc:interceptors> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值