JavaWeb学习——web.xml文件说明

摘要:本文主要学习了web.xml文件的作用以及如果配置。

是什么

web.xml文件是用来在JavaWeb项目里面初始化配置信息的,比如:访问的首页、Servlet信息、Filter信息、Listener信息、启动信息等。

如果项目用到了Servlet、Filter、Listener等组件,就需要配置web.xml,如果没有用到,也可以不需要web.xml。

标签说明

文档有效性检查

一般是xml文件的声明,定义了xml文件的版本和编码格式,指明xml文件遵循的约束,指明xsd文件的位置,xsd文件定义了xml可用使用的标签元素。

 <?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id="WebApp_ID" version="3.0">
...
</web-app>

项目图标

定义表示项目的大图标和小图标,可以没有。

 <icon>
<small-icon>/images/app_small.gif</small-icon>
<large-icon>/images/app_large.gif</large-icon>
</icon>

项目名称

定义项目的名称,可以没有。

 <display-name>HelloWorld</display-name>

欢迎页面

定义项目的欢迎页面,按照从上到下的优先级顺序,若没有配置将默认使用index.html作为欢迎页,若所有页面都不存在,将会提示“The requested resource (/XXX) is not available”。

 <welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>

错误页面

通过错误码指定错误处理页面。

 <error-page>
<error-code>404</error-code>
<location>/error404.jsp</location>
</error-page>

通过异常类型指定错误处理页面。

 <error-page>
<exception-type>java.lang.Exception<exception-type>
<location>/exception.jsp<location>
</error-page>

上下文参数

设置当前应用的初始化参数。

在Jsp页面中可以使用 ${initParam.param_name} 获取,在Servlet程序里可以使用 this.getServletConfig().getServletContext().getInitParameter(param_name); 获取。

 <context-param>
<param-name>param_name</param-name>
<param-value>param_value</param-value>
</context-param>

会话参数

设置项目的session参数, session-timeout 元素用来指定会话超时时间,以分钟为单位,该元素值必须为整数,如果值为零或负数,则表示会话将永远不会超时。

 <session-config>
<session-timeout>120</session-timeout>
</session-config>

Servlet

设置项目的Servlet。

可以使用 init-param 将初始化参数名和参数值传递给Servlet,访问Servlet配置参数可以通过 this.getServletConfig().getInitParameter(param_name); 获取。

ServletConfig获取配置参数的方法和ServletContext获取配置参数的方法完全一样,只是ServletConfig是取得当前Servlet的配置参数,而ServletContext是获取整个Web应用的配置参数。

使用 load-on-startup 元素可以控制容器在启动时是否要初始化Servlet,取值必须是整数。如果值大于或者等于0,表示在启动时间就加载并初始化Servlet,元素的值越小,启动的优先级越高。如果值为负数,则表示在用到的时候才去加载和初始化。

 <servlet>
<servlet-name>TestServlet</servlet-name>
<servlet-class>com.TestServlet</servlet-class>
<init-param>
<param-name>publishContext</param-name>
<param-value>false</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>TestServlet</servlet-name>
<url-pattern>/TestServlet</url-pattern>
</servlet-mapping>

Filter

设置项目的Filter。

在 filter-mapping 元素里可以使用 url-pattern 或者 servlet-name 两种方式指定要过滤的访问路径,这两种方式使用一个即可。

版本规范在部署描述符中新增了 dispatcher 元素,这个元素有四个可能的取值,这四种方式可以组合使用,配置多个元素即可。需要注意的是, dispatcher 元素必须写在 filter-mapping 元素的最后。

四种可能的取值如下:

1)REQUEST:只要发起的操作是一次HTTP请求,比如请求某个URL、发起了一个GET请求或者POST请求。一次重定向则前后相当于发起了两次请求,这些情况下有几次请求就会走几次指定过滤器。

2)FOWARD:只有在当前页面是通过请求转发过来的情况下,才会走指定的过滤器。

3)INCLUDE:只要是通过 <jsp:include page="xxx.jsp" /> ,嵌入进来的页面,每嵌入的一个页面,都会走指定的过滤器。

4)ERROR:假如配置了 error-page 元素,并且触发了配置里的状态码,就会走指定的过滤器。需要注意的是,虽然把请求转发到error.jsp是一次转发的过程,但并不会走FORWARD指定的过滤器。

 <filter>
<filter-name>EncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>EncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
<servlet-name>TestServlet</servlet-name>
<dispatcher>INCLUDE</dispatcher>
</filter-mapping>

Listener

设置项目的Listener。

配置Listener只需要使用元素 listener-class 指定Listener的实现类即可。

 <listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

路径的通配符匹配

配置方式

1)精确匹配

在 url-pattern 元素中配置的项必须与URL完全精确匹配。

 <servlet-mapping>
<servlet-name>TestServlet</servlet-name>
<url-pattern>/test/show.html</url-pattern>
<url-pattern>/index.html</url-pattern>
<url-pattern>/demo</url-pattern>
</servlet-mapping>

2)路径匹配

在 url-pattern 元素中配置的项只匹配了一部分URL。

 <servlet-mapping>
<servlet-name>TestServlet</servlet-name>
<url-pattern>/test/*</url-pattern>
</servlet-mapping>

3)扩展匹配

在 url-pattern 元素中配置的项只匹配了URL的扩展名。

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

优先顺序

当一个URL与多个Servlet的匹配规则可以匹配时,则按照“精确路径 > 最长路径 > 扩展名”这样的优先级匹配到对应的Servlet。

注意:不要既有路径匹配,又有扩展匹配,这样做会导致容器无法去判断匹配哪个,例如: <url-pattern>/*.action</url-pattern> 就是错误的写法。

/和/*的区别

/:会匹配到/login这样的路径型URL,不会匹配到*.jsp这样的后缀型URL。

/*:会匹配所有URL,包括路径型的和后缀型的。

文件加载过程

当启动一个Web项目容器时,首先会去读取web.xml配置文件里的配置,当这一步骤没有出错并且完成之后,项目才能正常的被启动起来。

启动Web项目的时候,容器首先会去读取web.xml配置文件中的两个元素: listener 和 context-param 。

紧接着,容器创建一个ServletContext,这个Web项目的所有部分都将共享这个上下文。容器以 context-param 元素的 name 作为键,以 value 作为值,将其转化为键值对,存入ServletContext。  

容器创建 listener 元素中的类实例,根据 listener-class 元素里配置的class类路径来创建监听,在监听中会有初始化方法。

接着,容器会读取 filter 元素的内容,根据指定的类路径来实例化过滤器。

以上都是在WEB项目还没有完全启动起来的时候就已经完成了的工作。如果系统中有Servlet,则Servlet是在第一次发起请求的时候被实例化的,而且一般不会被容器销毁,它可以服务于多个用户的请求。所以,Servlet的初始化都要比上面提到的那几个要迟。

总的来说,web.xml的加载顺序是: context-param -> listener -> filter -> servlet 。

其中,如果web.xml中出现了相同的元素,则按照在配置文件中出现的先后顺序来加载。

最新文章

  1. iOS 面试题(五):weak 的内部实现原理 --转自唐巧
  2. Razor 中的@helper 与 @function 用法
  3. Markdown 简明语法手册
  4. github上的版本和本地版本冲突的解决方法
  5. find_in_set mysql
  6. Careercup - Microsoft面试题 - 5700293077499904
  7. hdu2021(很闲~~)
  8. 【模拟】XMU 1599 斐波那契汤
  9. 初识C(2)---从printf函数开始
  10. 编译kernel:配置
  11. HDU 5001 概率DP || 记忆化搜索
  12. Vmware下centos与windows能ping通并能上网
  13. 兼容IE8浏览器移除class样式的方法
  14. 牛客练习赛24-B-贪心
  15. 项目构建之maven篇:5.仓库及nexus创建私服-2
  16. CRM 2016 升级CRM365之注意事项
  17. win10管理员已阻止你运行此应用”解决方法
  18. RN项目中关于父子组件的通信
  19. php 数字 的简单加解密
  20. 改变mysql数据库用户的权限

热门文章

  1. sbt assembly a fat jar for spark-submit cluster model
  2. 可能是全网最简单的 OpenStack 安装方式
  3. SX1276/SX1278和SXSX1262的详细参数对比
  4. autoLayout+sizeClass屏幕适配
  5. 数据挖掘算法(三)--logistic回归
  6. linux命令之head、tail命令详解
  7. 2018HDU多校训练一 D Distinct Values
  8. 如何正确的使用Python解释器?你之前肯定用错了
  9. CyAPI环境搭建
  10. 海思HI3518EV200+AR0130开发板DIY——前篇