`
foxty
  • 浏览: 136508 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Servlet,Filter的url-pattern详解

阅读更多

 

Servlet和Filter的url匹配以及url-pattern详解

      Servlet和filter是J2EE开发中常用的技术,使用方便,配置简单,老少皆宜。估计大多数朋友都是直接配置用,也没有关心过具体的细节,今天遇到一个问题,上网查了servlet的规范才发现,servlet和filter中的url-pattern还是有一些文章在里面的,总结了一些东西,放出来供大家参考,以免遇到问题又要浪费时间。

    一,servlet容器对url的匹配过

当一个请求发送到servlet容器的时候,容器先会将请求的url减去当前应用上下文的路径作为servlet的映射url,比如我访问的是http://localhost/test/aaa.html,我的应用上下文是test,容器会将http://localhost/test去掉,剩下的/aaa.html部分拿来做servlet的映射匹配。这个映射匹配过程是有顺序的,而且当有一个servlet匹配成功以后,就不会去理会剩下的servlet了(filter不同,后文会提到)。其匹配规则和顺序如下:<o:p></o:p>

1.     精确路径匹配。例子:比如servletA 的url-pattern为 /test,servletB的url-pattern为 /* ,这个时候,如果我访问的url为http://localhost/test ,这个时候容器就会先进行精确路径匹配,发现/test正好被servletA精确匹配,那么就去调用servletA,也不会去理会其他的servlet了。<o:p></o:p>

2.     最长路径匹配。例子:servletA的url-pattern为/test/*,而servletB的url-pattern为/test/a/*,此时访问http://localhost/test/a时,容器会选择路径最长的servlet来匹配,也就是这里的servletB。<o:p></o:p>

3.     扩展匹配,如果url最后一段包含扩展,容器将会根据扩展选择合适的servlet。例子:servletA的url-pattern:*.action<o:p></o:p>

4.     如果前面三条规则都没有找到一个servlet,容器会根据url选择对应的请求资源。如果应用定义了一个default servlet,则容器会将请求丢给default servlet(什么是default servlet?后面会讲)。

     根据这个规则表,就能很清楚的知道servlet的匹配过程,所以定义servlet的时候也要考虑url-pattern的写法,以免出错。

      对于filter,不会像servlet那样只匹配一个servlet,因为filter的集合是一个链,所以只会有处理的顺序不同,而不会出现只选择一个filter。Filter的处理顺序和filter-mapping在web.xml中定义的顺序相同。

    二,url-pattern详解

  •  web.xml文件中,以下语法用于定义映射:
  •  以”/’开头和以”/*”结尾的是用来做路径映射的。
  •  以前缀”*.”开头的是用来做扩展映射的。
  • “/” 是用来定义default servlet映射的。
  • 剩下的都是用来定义详细映射的。比如: /aa/bb/cc.action

所以,为什么定义”/*.action”这样一个看起来很正常的匹配会错?因为这个匹配即属于路径映射,也属于扩展映射,导致容器无法判断

 

【参考内容】  Java  Servlet 2.4 Specification

分享到:
评论
21 楼 ooo456mmm 2013-01-17  
我想问下楼主一个问题啊,url-pattern中配置是/bp/*,能拦截到例如这样的路径吗?
/aa/bp/bb.action或者/aa/bp/bb.action?a=1
20 楼 foxty 2011-10-17  
OpenMind 写道
ant-style的是用**匹配任意层次目录的,/**/*.action可以匹配到/a/b.action。
请问servlet url: /*.action可以匹配到/a/b.action吗?

这个配置是个错误的配置,上面已经提到了。不过最新的servlet规范还没有阅读,你可以自行参考下是否在这块有提升,反正2.4之前的servlet映射确实很弱。
19 楼 OpenMind 2011-10-14  
ant-style的是用**匹配任意层次目录的,/**/*.action可以匹配到/a/b.action。
请问servlet url: /*.action可以匹配到/a/b.action吗?
18 楼 java641 2011-10-12  
ssssssss[[sssss]u]sssssssssss[/u]sss
17 楼 janh 2007-05-17  
是啊,感觉servlet的匹配功能太弱了。
16 楼 spiritfrog 2007-05-17  
受益匪浅,以前一直都不知道,原来有精确匹配,路径匹配,扩展名匹配之分,更不知道原来精确匹配是最优先的.
15 楼 wuyunlong 2006-12-21  
yyjun 写道
好文章,如果确实存在”/*.action”这样一个匹配,在url-pattern里应该怎么定义吗??

可以自己写个filter/servlet去实现这样的匹配功能,目前servlet规范还不支持这样的功能。
14 楼 leelun 2006-12-20  
yyjun 写道
好文章,如果确实存在”/*.action”这样一个匹配,在url-pattern里应该怎么定义吗??

是不是应该”/**.action"这样写
13 楼 sizhefang 2006-12-18  
受益匪浅
12 楼 somebody 2006-12-18  
江南白衣 写道
简单的说,它不支持ant-style的path mapping, 比如/applicationContext*.xml ,/mymodule.*.action之类的,比较让人气馁。



是啊.有好多人碰到这个问题.
所以现在我用urlrewrite来做这个事情.
11 楼 江南白衣 2006-12-17  
简单的说,它不支持ant-style的path mapping, 比如/applicationContext*.xml ,/mymodule.*.action之类的,比较让人气馁。
10 楼 foxty 2006-12-17  
zhangqidi 写道
仔细看了一下规范 SRV11<br />
<br />
猜测可能是这样(没有测试,请指正错误):<br />
<br />
<ul>
    <li>通配符*只在前三种类型中有用。在精确匹配类型中,*没有任何特殊含义(或者做为一个配置错误?)</li>
</ul>
<ul>
    <li>楼主说的那个例子(/*.action)的问题,按照定义,肯定不属于前三种任何一种类型。注意第一种类型的&ldquo;and&rdquo;逻辑。</li>
    <li>究竟什么是一个extension类型?原文中对extension的定义是:最后一个&ldquo;.&quot;字符后面的部分中的最后一个分段(fragment)</li>
</ul>
<br />
<br />
如果包含了*,那就不会做为一个精确匹配的条件了。

正是因为/*.action属于一个比较模糊的范畴(自己推测的),所以设置这样一个urlparttern才会报错。

至于extension类型,原文有两个说法,其实也是一样的。

srv11中提到:
An extension is defined as the part of the last segment after the last ’.’ character.

ser12中提到:
A string beginning with a ‘*.’ prefix is used as an extension mapping.

只是两者针对角度不同,srv11是针对如何来映射一个url而讲的。srv12是针对配置来讲的。
9 楼 zhangqidi 2006-12-17  
仔细看了一下规范 SRV11<br/>
<br/>
猜测可能是这样(没有测试,请指正错误):<br/>
<br/>
<ul>
    <li>通配符*只在前三种类型中有用。在精确匹配类型中,*没有任何特殊含义(或者做为一个配置错误?)</li>
</ul>
<ul>
    <li>楼主说的那个例子(/*.action)的问题,按照定义,肯定不属于前三种任何一种类型。注意第一种类型的“and”逻辑。</li>
    <li>究竟什么是一个extension类型?原文中对extension的定义是:最后一个“."字符后面的部分中的最后一个分段(fragment)</li>
</ul>
<br/>
<br/>
8 楼 yyjun 2006-12-17  
好文章,如果确实存在”/*.action”这样一个匹配,在url-pattern里应该怎么定义吗??
7 楼 deafwolf 2006-12-17  
我一般都理解为按正则式匹配,不像楼主分得那么清楚

受教了,多谢
6 楼 foxty 2006-12-17  
downpour 写道
最好再举点例子说明一下。

另外没有说清楚类似:aaa/bbb/ccc.jsp?id=1这种带有问号的方式是如何映射的。
问号在映射里面,不代表什么特殊的含义。就跟aaa,bbb一样。

对于一个需要映射的url,只要按照上面所说的顺序,就能知道会被映射到哪个servlet。
5 楼 downpour 2006-12-17  
最好再举点例子说明一下。

另外没有说清楚类似:aaa/bbb/ccc.jsp?id=1这种带有问号的方式是如何映射的。
4 楼 ahuaxuan 2006-12-17  
谢谢楼主,以前我大概也是知道,但是知道得没有楼主这么深刻,受教了
3 楼 foxty 2006-12-17  
fins 写道
正需要 以前问过相关问题 无人回答
谢谢lz!!!!
发之前搜索过论坛,看到过你发的那个帖子了。而且正好今天我也碰到类似的一个问题。所以后面就一起提了出来。:)
2 楼 fins 2006-12-16  
正需要 以前问过相关问题 无人回答
谢谢lz!!!!

相关推荐

    servlet的url-pattern匹配规则详细描述(小结)

    在利用servlet或Filter进行url请求的匹配时,很关键的一点就是匹配规则。这篇文章主要介绍了servlet的url-pattern匹配规则详细描述(小结),非常具有实用价值,需要的朋友可以参考下

    tomcat关于配置servlet的url-pattern的问题思路详解

    servlet url-pattern的匹配问题 url-pattern中 / 和 /* 的区别 url-pattern的优先级问题 根路径 / 的匹配问题 1 servlet url-pattern 的匹配问题 url-pattern 有三种匹配模式,分别是路径匹配、精确匹配、后缀...

    JavaWeb Servlet中url-pattern的使用

    主要介绍了JavaWeb Servlet中url-pattern的使用的相关资料,希望通过本文能帮助到大家,让大家学习理解这部分内容,需要的朋友可以参考下

    servlet url-pattern

    我的文章:http://blog.csdn.net/pengdongneng/article/details/66973587 的测试源码

    javax.servlet-api-3.0.1.jar中文文档.zip

    javax.servlet-api-***.jar中文文档.zip,java,javax.servlet-api-***.jar,javax.servlet,javax.servlet-api,***,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,javax,servlet,api,中文API文档,手册,开发...

    URL-pattern解析

    对Servlet技术中的web.xml部署,进行深入解析其中的url-pattern.

    jakarta.servlet-api-4.0.4-API文档-中文版.zip

    赠送jar包:jakarta.servlet-api-4.0.4.jar; 赠送原API文档:jakarta.servlet-api-4.0.4-javadoc.jar; 赠送源代码:jakarta.servlet-api-4.0.4-sources.jar; 赠送Maven依赖信息文件:jakarta.servlet-api-4.0.4....

    javax.servlet-api-3.1.0.jar中文文档.zip

    javax.servlet-api-***.jar中文文档.zip,java,javax.servlet-api-***.jar,javax.servlet,javax.servlet-api,***,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,javax,servlet,api,中文API文档,手册,开发...

    javax.servlet-api-4.0.1-API文档-中英对照版.zip

    赠送jar包:javax.servlet-api-4.0.1.jar; 赠送原API文档:javax.servlet-api-4.0.1-javadoc.jar; 赠送源代码:javax.servlet-api-4.0.1-sources.jar; 赠送Maven依赖信息文件:javax.servlet-api-4.0.1.pom; ...

    详解servlet的url-pattern匹配规则

    本篇文章主要介绍了=servlet的url-pattern匹配规则,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    sentinel-web-servlet-1.8.0-API文档-中英对照版.zip

    赠送jar包:sentinel-web-servlet-1.8.0.jar; 赠送原API文档:sentinel-web-servlet-1.8.0-javadoc.jar; 赠送源代码:sentinel-web-servlet-1.8.0-sources.jar; 赠送Maven依赖信息文件:sentinel-web-servlet-...

    javax.servlet-api-3.1.0.jar

    javax.servlet-api-3.1.0.jar,处理找不到servlet JAR的问题

    javax.servlet-api-4.0.0-API文档-中英对照版.zip

    赠送jar包:javax.servlet-api-4.0.0.jar; 赠送原API文档:javax.servlet-api-4.0.0-javadoc.jar; 赠送源代码:javax.servlet-api-4.0.0-sources.jar; 赠送Maven依赖信息文件:javax.servlet-api-4.0.0.pom; ...

    javax.servlet-api-4.0.0-API文档-中文版.zip

    赠送jar包:javax.servlet-api-4.0.0.jar; 赠送原API文档:javax.servlet-api-4.0.0-javadoc.jar; 赠送源代码:javax.servlet-api-4.0.0-sources.jar; 赠送Maven依赖信息文件:javax.servlet-api-4.0.0.pom; ...

    javax.servlet-api-4.0.1.jar中文文档.zip

    javax.servlet-api-***.jar中文文档.zip,java,javax.servlet-api-***.jar,javax.servlet,javax.servlet-api,***,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,javax,servlet,api,中文API文档,手册,开发...

    servlet-api-3.0.jar包

    servlet-api-3.0.jar

    javax.servlet.jsp-api-2.3.1.jar

    javax.servlet.jsp-api-2.3.1.jar

Global site tag (gtag.js) - Google Analytics