论坛首页 Java企业应用论坛

Servlet,Filter的url-pattern详解

浏览 32740 次
该帖已经被评为良好帖
作者 正文
   发表时间:2006-12-16  
 

ServletFilterurl匹配以及url-pattern详解<o:p></o:p>

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

    一,servlet容器对url的匹配过程:<o:p></o:p>

      <o:p></o:p>

当一个请求发送到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 /testservletBurl-pattern /* ,这个时候,如果我访问的urlhttp://localhost/test ,这个时候容器就会先 进行精确路径匹配,发现/test正好被servletA精确匹配,那么就去调用servletA,也不会去理会其他的servlet了。<o:p></o:p>

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

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

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

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

      对于filter,不会像servlet那样只匹配一个servlet,因为filter的集合是一个链,所以只会有处理的顺序不同,而不会出现只选择一个filterFilter的处理顺序和filter-mappingweb.xml中定义的顺序相同。<o:p></o:p>

    二,url-pattern详解<o:p></o:p>

         web.xml文件中,以下语法用于定义映射:

l  ”/’开头和以”/*”结尾的是用来做路径映射的。

l  以前缀”*.”开头的是用来做扩展映射的。

l  “/” 是用来定义default servlet映射的。

l  剩下的都是用来定义详细映射的。比如: /aa/bb/cc.action

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

<o:p> </o:p>

【参考内容】

                            Java  Servlet 2.4 Specification<o:p></o:p>

   发表时间:2006-12-16  
PS:以上内容,仅供参考,很多都是依靠自己理解写的,如果有错误,请一定指出,以免误导了别人。
0 请登录后投票
   发表时间:2006-12-16  
正需要 以前问过相关问题 无人回答
谢谢lz!!!!
0 请登录后投票
   发表时间:2006-12-17  
fins 写道
正需要 以前问过相关问题 无人回答
谢谢lz!!!!
发之前搜索过论坛,看到过你发的那个帖子了。而且正好今天我也碰到类似的一个问题。所以后面就一起提了出来。:)
0 请登录后投票
   发表时间:2006-12-17  
谢谢楼主,以前我大概也是知道,但是知道得没有楼主这么深刻,受教了
0 请登录后投票
   发表时间:2006-12-17  
最好再举点例子说明一下。

另外没有说清楚类似:aaa/bbb/ccc.jsp?id=1这种带有问号的方式是如何映射的。
0 请登录后投票
   发表时间:2006-12-17  
downpour 写道
最好再举点例子说明一下。

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

对于一个需要映射的url,只要按照上面所说的顺序,就能知道会被映射到哪个servlet。
0 请登录后投票
   发表时间:2006-12-17  
我一般都理解为按正则式匹配,不像楼主分得那么清楚

受教了,多谢
0 请登录后投票
   发表时间:2006-12-17  
好文章,如果确实存在”/*.action”这样一个匹配,在url-pattern里应该怎么定义吗??
0 请登录后投票
   发表时间:2006-12-17  
仔细看了一下规范 SRV11

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

  • 通配符*只在前三种类型中有用。在精确匹配类型中,*没有任何特殊含义(或者做为一个配置错误?)
  • 楼主说的那个例子(/*.action)的问题,按照定义,肯定不属于前三种任何一种类型。注意第一种类型的“and”逻辑。
  • 究竟什么是一个extension类型?原文中对extension的定义是:最后一个“."字符后面的部分中的最后一个分段(fragment)


0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics