Servlet,Filter的url-pattern详解 - LuckyFox - JavaEye技术网站

来源:百度文库 编辑:神马文学网 时间:2022/09/24 23:38:17
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不同,后文会提到)。其匹配规则和顺序如下:
1.     精确路径匹配。例子:比如servletA 的url-pattern为 /test,servletB的url-pattern为 /* ,这个时候,如果我访问的url为http://localhost/test ,这个时候容器就会先 进行精确路径匹配,发现/test正好被servletA精确匹配,那么就去调用servletA,也不会去理会其他的servlet了。
2.     最长路径匹配。例子:servletA的url-pattern为/test/*,而servletB的url-pattern为/test/a/*,此时访问http://localhost/test/a时,容器会选择路径最长的servlet来匹配,也就是这里的servletB。
3.     扩展匹配,如果url最后一段包含扩展,容器将会根据扩展选择合适的servlet。例子:servletA的url-pattern:*.action
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文件中,以下语法用于定义映射:
l  以”/’开头和以”/*”结尾的是用来做路径映射的。
l  以前缀”*.”开头的是用来做扩展映射的。
l  “/” 是用来定义default servlet映射的。
l  剩下的都是用来定义详细映射的。比如: /aa/bb/cc.action
所以,为什么定义”/*.action”这样一个看起来很正常的匹配会错?因为这个匹配即属于路径映射,也属于扩展映射,导致容器无法判断。
【参考内容】
Java  Servlet 2.4 Specification
17:58
浏览 (13763)
评论 (17)
进入论坛
相关推荐
评论
janh2007-05-17
是啊,感觉servlet的匹配功能太弱了。
spiritfrog2007-05-17
受益匪浅,以前一直都不知道,原来有精确匹配,路径匹配,扩展名匹配之分,更不知道原来精确匹配是最优先的.
wuyunlong2006-12-21
yyjun 写道
好文章,如果确实存在”/*.action”这样一个匹配,在url-pattern里应该怎么定义吗??
可以自己写个filter/servlet去实现这样的匹配功能,目前servlet规范还不支持这样的功能。
leelun2006-12-20
yyjun 写道
好文章,如果确实存在”/*.action”这样一个匹配,在url-pattern里应该怎么定义吗??
是不是应该”/**.action"这样写
sizhefang2006-12-18
受益匪浅
somebody2006-12-18
江南白衣 写道
简单的说,它不支持ant-style的path mapping, 比如/applicationContext*.xml ,/mymodule.*.action之类的,比较让人气馁。
是啊.有好多人碰到这个问题.
所以现在我用urlrewrite来做这个事情.
江南白衣2006-12-17
简单的说,它不支持ant-style的path mapping, 比如/applicationContext*.xml ,/mymodule.*.action之类的,比较让人气馁。
foxty2006-12-17
zhangqidi 写道
仔细看了一下规范 SRV11



猜测可能是这样(没有测试,请指正错误):




  • 通配符*只在前三种类型中有用。在精确匹配类型中,*没有任何特殊含义(或者做为一个配置错误?)



  • 楼主说的那个例子(/*.action)的问题,按照定义,肯定不属于前三种任何一种类型。注意第一种类型的“and”逻辑。

  • 究竟什么是一个extension类型?原文中对extension的定义是:最后一个“."字符后面的部分中的最后一个分段(fragment)






如果包含了*,那就不会做为一个精确匹配的条件了。
正是因为/*.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是针对配置来讲的。
zhangqidi2006-12-17
仔细看了一下规范 SRV11
猜测可能是这样(没有测试,请指正错误):
通配符*只在前三种类型中有用。在精确匹配类型中,*没有任何特殊含义(或者做为一个配置错误?)
楼主说的那个例子(/*.action)的问题,按照定义,肯定不属于前三种任何一种类型。注意第一种类型的“and”逻辑。
究竟什么是一个extension类型?原文中对extension的定义是:最后一个“."字符后面的部分中的最后一个分段(fragment)
yyjun2006-12-17
好文章,如果确实存在”/*.action”这样一个匹配,在url-pattern里应该怎么定义吗??
deafwolf2006-12-17
我一般都理解为按正则式匹配,不像楼主分得那么清楚
受教了,多谢
foxty2006-12-17
downpour 写道
最好再举点例子说明一下。
另外没有说清楚类似:aaa/bbb/ccc.jsp?id=1这种带有问号的方式是如何映射的。
问号在映射里面,不代表什么特殊的含义。就跟aaa,bbb一样。
对于一个需要映射的url,只要按照上面所说的顺序,就能知道会被映射到哪个servlet。
downpour2006-12-17
最好再举点例子说明一下。
另外没有说清楚类似:aaa/bbb/ccc.jsp?id=1这种带有问号的方式是如何映射的。
ahuaxuan2006-12-17
谢谢楼主,以前我大概也是知道,但是知道得没有楼主这么深刻,受教了
foxty2006-12-17
fins 写道
正需要 以前问过相关问题 无人回答
谢谢lz!!!!
发之前搜索过论坛,看到过你发的那个帖子了。而且正好今天我也碰到类似的一个问题。所以后面就一起提了出来。:)
fins2006-12-16
正需要 以前问过相关问题 无人回答
谢谢lz!!!!
foxty2006-12-16
PS:以上内容,仅供参考,很多都是依靠自己理解写的,如果有错误,请一定指出,以免误导了别人。