客户端通过URL地址访问服务器(servlet容器)资源,所以servlet若要能对外提供服务,必须要将程序按照java规范将其映射到对应的URL上,映射的规则是需要开发人员在WEB.XML中显示指定,指定的方法如下:

<servlet>
<servlet-name>BlogServlet</servlet-name>
<servlet-class>com.p**ghty.userapp.module1.BlogServlet</servlet-class>
</servlet> <servlet-mapping>
<servlet-name>BlogServlet</servlet-name>
<url-pattern>/module1/BlogServlet</url-pattern>
</servlet-mapping>

  

servlet容器对客户端请求的匹配过程

一个请求发送到servlet容器的时候,容器先会将请求的url减去当前应用上下文的路径作为servlet的映射url。如客户端输入http://www.p**ghty.com/platform/blog/article/index,servlet容器会将

http://www.p**ghty.com/platform减去,剩下platform/blog/article/index与web.xml中设定的匹配规则进行匹配,而这种匹配是按照一定的规则进行的,并且有一个servlet匹配成功后,就不会取匹配其他servlet(注意

filter与此不同):
(1)匹配精确路径:以“/”开头,以字母(非”*”)结束,如<url-pattern>/blog/article/add</url-pattern>。
如web.xml中配置如下:

<servlet-mapping>
<servlet-name>BlogServlet</servlet-name>
<url-pattern>/blog/article/index.jsp</url-pattern>
<url-pattern>/blog/article/add</url-pattern>
</servlet-mapping>

  

则以下路径都会被匹配到该servlet
  http://www.p**ghty.com/platform/blog/article/index.jsp
  http://www.p**ghty.com/platform/blog/article/add

(2)匹配扩展名:以* 开头,以扩展名结束,如<url-pattern>*.do</url-pattern>。
如web.xml中配置如下:

<servlet-mapping>
<servlet-name>BlogServlet</servlet-name>
<url-pattern>*.jsp</url-pattern>
<url-pattern>*.do</url-pattern>
</servlet-mapping>

则任何扩展名为jsp或do的url请求都会匹配,比如下面的url都会被匹配
  http://www.p**ghty.com/platform/blog/article/index.jsp
  http://www.p**ghty.com/platform/index.do

(3)匹配最长路径:以“/”开头,并以 /* 结尾,如<url-pattern>/blog/*</url-pattern>
如web.xml中配置如下:

<servlet-mapping>
<servlet-name>BlogServlet</servlet-name>
<url-pattern>/blog/article/*</url-pattern>
</servlet-mapping>

则以下路径都会被匹配到该servlet
  http://www.p**ghty.com/platform/blog/article/index.jsp
  http://www.p**ghty.com/platform/blog/article/add

(4)匹配默认:“/” 用来表示对应的servlet 为默认的servelet

几个注意点:

(1)http://www.p**ghty.com/platform/blog/article/是非法url

(2)匹配的url后面可以跟任意的查询条件,如:http://www.p**ghty.com/platform/blog/article/add?username=davee

(3)以上四种匹配规则中,(1)(2)(3)不可同时使用,如<url-pattern>/blog/*.do</url-pattern>是非法的,但是<url-pattern>/blog/*/add</url-pattern>是合法的。

(4)“/*”和“/”含义是不一样的,“/*”属于路径匹配,并且可以匹配所有请求,由于路径匹配的优先级仅次于精确匹配,所以“/*”会覆盖所有的扩展名匹配,故不推荐使用。“/”是servlet中特殊的匹配模式,优先

级最低(第(4)级),不会覆盖其他任何匹配模式,只是会替换servlet容器的内建default servlet ,该模式同样会匹配所有请求。

(5)tomcat在%CATALINA_HOME%\conf\web.xml文件中配置了默认的Servlet,对“/”和“.jsp|.jspx|jsp”这两种匹配规则进行了默认设定,
故开发人员配置“/”后,一种可能的现象是BlogServlet会拦截http://www.p**ghty.com/platform/blog/article/add.do等格式的请求,但是并不会拦截http://www.p**ghty.com/platform/blog/article/index.jsp,这是应

为servlet容器有内置默认的“*.jsp”匹配器,而扩展名匹配的优先级高于缺省匹配,所以jsp不被拦截,而servlet会被拦截。

(6)“/*”和“/”均会拦截静态资源请求

servlet的匹配规则,兼谈/与/*的更多相关文章

  1. Servlet拦截匹配规则可以自已定义,拦截哪种URL合适?

    Servlet拦截匹配规则可以自已定义,拦截哪种URL合适? 当映射为@RequestMapping("/user/add")时,为例: 1.拦截*.do.*.htm, 例如:/u ...

  2. servlet的url-pattern匹配规则详细描述

    一.概述 在利用servlet或Filter进行url请求的匹配时,很关键的一点就是匹配规则,但servlet容器中的匹配规则既不是简单的通配,也不是正则表达式,而是由自己的规则,比较容易混淆.本文来 ...

  3. 转:servlet的url-pattern匹配规则详细描述

    原文地址:servlet的url-pattern匹配规则详细描述   原文写的很详细 另外可以参考一下:Web.xml中设置Servlet和Filter时的url-pattern匹配规则 一.概述 在 ...

  4. servlet配置url-pattern的匹配规则

    <servlet> <servlet-name>hello</servlet-name> <servlet-class>com.qf.servlet.H ...

  5. web.xml的<url-parttern>的匹配规则

    <url-parttern>顾名思义是对url(统一资源定位符)的一种匹配,是对“http:........."地址的匹配,但是会减去应用上下文,就是你的web程序的名字,如果你 ...

  6. java-servlet的url-pattern匹配规则详细描述

    http://www.cnblogs.com/51kata/p/5152400.html http://www.cnblogs.com/canger/p/6084846.html 一.概述 在利用se ...

  7. web.xml中url-pattern匹配规则

    小知识 一般的URL组成 URL = 服务器地址 + RequestURI 例如URI:http://localhost:8080/practice/main [http://localhost:80 ...

  8. Web.xml中设置Servlet和Filter时的url-pattern匹配规则

    一.servlet容器对url的匹配过程: 当一个请求发送到servlet容器的时候,容器先会将请求的url减去当前应用上下文的路径作为servlet的映射url,比如我访问的是http://loca ...

  9. servlet的url-pattern匹配规则

    首先需要明确几容易混淆的规则: servlet容器中的匹配规则既不是简单的通配,也不是正则表达式,而是特定的规则.所以不要用通配符或者正则表达式的匹配规则来看待servlet的url-pattern. ...

随机推荐

  1. STM32解密STM32F103芯片解密STM32F103R6单片机破解多少钱?

    STM32解密STM32F103芯片解密STM32F103R6单片机破解多少钱? STM32F系列单片机芯片解密型号: STM32F100  |  STM32F101  |  STM32F102  | ...

  2. CodeForces 551E 分块

    题目链接:http://codeforces.com/problemset/problem/551/E 题意:给定一个长度为N的序列. 有2个操作 1 l r v:序列第l项到第r项加v(区间加), ...

  3. 分布式缓存技术memcached学习(二)——memcached基础命令

    上文<linux环境下编译memcahed>介绍了memcahed在linux环境下的安装以及登录,下面介绍memcahed的基本命令的使用. Add 功能:往内存增加一条新的缓存记录 语 ...

  4. JQuery上传插件Uploadify使用详解

    本文转载http://www.cnblogs.com/oec2003/archive/2010/01/06/1640027.html Uploadify是JQuery的一个上传插件,实现的效果非常不错 ...

  5. CF #375 (Div. 2) D. bfs

    1.CF #375 (Div. 2)  D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...

  6. jpa语句报 org.springframework.dao.InvalidDataAccessApiUsageException: Parameter with that position [2] did not exist; nested exception is java.lang.IllegalArgumentException: Parameter with that position

    @Query("SELECT area from Area AS area WHERE area.state=0 AND area.name like %?1% ")Area fi ...

  7. [转][Starling] 神器——原生Swf一键导出到Starling!

    Swf一键导出到Starling中的工具,在Starling使用原生的MovieClip 来自:http://zmliu.github.io/2013/11/09/StarlingSwfTool/ 如 ...

  8. centos关闭防火墙

    Centos7 关闭防火墙 CentOS 7.0默认使用的是firewall作为防火墙,使用iptables必须重新设置一下 1.直接关闭防火墙 systemctl stop firewalld.se ...

  9. Clang比 gcc/g++更人性化代码出错提示的C/C++编译器

    编译器方面的几个命令 gcc/g++ 一. 常用编译命令选项 常用用法 gcc -Wall test.c -o test gcc编译过程 .c ->(-E)-> .i[中间文件] -> ...

  10. web自动化测试中绕开验证码登陆的方式

    web自动化测试中登陆需验证码是很大的一个困扰.现推荐一种简单的避开验证码登陆的方式,先代码进入登录页,人工输入验证码登录后浏览器自动保存cookie,再在新的标签中登录. 具体代码如下: publi ...