Java web.xml配置解读与加载分析

一 启动

1、启动一个WEB项目的时候,WEB容器会去读取它的配置文件web.xml,读取两个结点。

2、紧接着,容器会创建一个ServletContext(servlet上下文),这个web项目的所有部分都将共享这个上下文。

3、容器将转换为键值对,并交给servletContext。

4、容器创建中的类实例,创建监听器。

二 Load-on-startup

Load-on-startup元素在web应用启动的时候指定了servlet被加载的顺序,它的值必须是一个整数。

如果它的值是一个负整数或是这个元素不存在,容器会在该servlet被调用的时候才加载这个servlet;如果值是正整数或零,容器在配置的时候就加载并初始化这个servlet;容器必须保证值小的先被加载;如果值相等,容器可以自动选择先加载谁。

在servlet的配置当中,5的含义是:

标记容器是否在启动的时候就加载这个servlet。

当值为0或者大于0时,表示容器在应用启动时就加载这个servlet;

当是一个负数时或者没有指定时,则指示容器在该servlet被选择时才加载。

正数的值越小,启动该servlet的优先级越高。

三 加载顺序

首先可以肯定的是,加载顺序与它们在 web.xml 文件中的先后顺序无关。即不会因为 filter 写在 listener的前面而会先加载 filter。最终得出的结论是:

ServletContext-> listener ->filter -> servlet

同时还存在着这样一种配置节点:context-param,它用于向 ServletContext提供键值对,即应用程序上下文信息。我们的 listener, filter 等在初始化时会用到这些上下文中的信息,context-param配置可写在任意位置,因此真正的加载序为:

context-param -> listener-> filter -> servlet