web.xml标签详解

Posted z--z

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了web.xml标签详解相关的知识,希望对你有一定的参考价值。

转自https://blog.csdn.net/ee470474137/article/details/45721025


<!--该元素声明应用范围内的初始化参数--> <context-param> <!--声明描述信息--> <description></description> <!--用于指定上下文参数的名称--> <param-name></param-name> <!--用于指定上下文参数的值--> <param-value></param-value> </context-param>

 


<!--声明WEB应用的描述信息-->
<description></description>

 


<!--定义了WEB应用的名字-->
<display-name></display-name>

 


<!--用于-->
<distributable/>

 


<!--声明一个EJB的本地主目录的应用-->
<ejb-local-ref>
    <!--声明描述信息-->
    <description></description>
<!--当前bean从一个不同jar包中引用另外一个bean的名称。通过ejb-link元素定义的名称必须使用"#"和bean注册名与Web应用程序中war文件的位置相关联-->
    <ejb-link></ejb-link>
    <!--java:comp/env的对应的EJB引用名-->
    <ejb-ref-name></ejb-ref-name>
    <!--用于声明实体或会话的bean类型-->
    <ejb-ref-type></ejb-ref-type>
    <!--用于指定包含企业Bean本地接口的完全限定名称-->
    <local></local>
    <!--用于指定包含企业Bean本地Home接口的完全限定名称-->
    <local-home></local-home>
</ejb-local-ref>

 


<!--声明一个EJB的主目录的引用-->
<ejb-ref>
    <!--声明描述信息-->
    <description></description>
<!--当前bean从一个不同jar包中引用另外一个bean的名称。通过ejb-link元素定义的名称必须使用"#"和bean注册名与Web应用程序中war文件的位置相关联-->
    <ejb-link></ejb-link>
    <!--java:comp/env的对应的EJB引用名-->
    <ejb-ref-name></ejb-ref-name>
    <!--用于声明实体或会话的bean类型-->
    <ejb-ref-type></ejb-ref-type>
    <!--用于指定EJB Home接口的完全限定名称-->
    <home></home>
    <!--bean的remote接口的完全限定名称-->
    <remote></remote>
</ejb-ref>

 


<!--声明Web应用的环境项-->
<env-entry>
    <!--声明描述信息-->
    <description></description>
<!--一个相对于java:comp/env环境JNDI名-->
    <env-entry-name></env-entry-name>
<!--(java.lang程序包中一个类型的完全限定类名,java.lang.Boolean、java.lang.String等)组成-->
    <env-entry-type></env-entry-type>
<!--用于指定环境条目的值-->
    <env-entry-value></env-entry-value>
</env-entry>

 


<!--在返回特定HTTP状态代码时,或者特定类型的异常被抛出时,能够制定将要显示的页面-->
<error-page>
    <!--用于指定Http的错误代码-->
    <error-code></error-code>
    <!--用于指定程序中的异常(异常的完整路径)-->
    <exception-type></exception-type>
    <!--用于指定程序出现错误时,跳转到的页面-->
    <location></location>
</error-page>

 


<!--过滤器元素将一个名字与一个实现javax.servlet.Filter接口的类相关联-->
<filter>
    <!--声明描述信息-->
    <description></description>
    <!--用于定义Web应用的名称-->
    <display-name></display-name>
    <!--用于指定当前filter对应的类的路径-->
    <filter-class></filter-class>
    <!--用于对当前filter取一个名称,以便在后面的映射时使用-->
    <filter-name></filter-name>
    <!--指定应用的大图标和小图标-->
    <icon></icon>
    <!--用于指定当前filter的一些初始化参数-->
    <init-param></init-param>
</filter>

 


<!--一旦命名了一个过滤器,就要利用filter-mapping元素把它与一个或多个servlet或JSP页面相关联-->
<filter-mapping>
<!--该元素有四个可能的值:即REQUEST(默认),FORWARD,INCLUDE和ERROR,可以在一个<filter-mapping>元素中加入任意数目的<dispatcher>,使得filter将会作用于直接从客户端过来的request,通过forward过来的request,通过include过来的request和通过<error-page>过来的request。如果没有指定任何< dispatcher >元素,默认值是REQUEST -->
    <dispatcher></dispatcher>
    <!--用于指定上文定义的filter名称-->
    <filter-name></filter-name>
    <!--用于指定上文定义的servlet名称-->
    <servlet-name></servlet-name>
    <!--描述用于解析URL的模式-->
    <url-pattern></url-pattern>
</filter-mapping>

 


<!--Web应用图标:指出IDE和GUI工具用来表示Web应用的大图标和小图标-->
<icon>
    <!--用于指定大图标-->
    <large-icon></large-icon>
    <!--用于指定小图标-->
    <small-icon></small-icon>
</icon>

 


<!--该元素主要用来设定JSP的相关配置-->
<jsp-config>
    <!--定义了一组JSP的特性。这些特性实际上对应JSP的page directive定义的特性-->
    <jsp-property-group>
        <!--声明描述信息-->
        <description></description>
        <!--用于定义Web应用的名称-->
        <display-name></display-name>
        <!--若为true,表示不支持EL语法-->
        <el-ignored></el-ignored>
        <!--指定应用的大图标和小图标-->
        <icon></icon>
        <!--设置JSP网页的结尾,扩展名为.jspf -->
        <include-coda></include-coda>
        <!--设置JSP网页的抬头,扩展名为.jspf -->
        <include-prelude></include-prelude>
<!--如果节点值为:true则表示这个文件为jsp文档(xml格式),如果为false,则表示为标准的jsp文件-->
        <is-xml></is-xml>
        <!--设定JSP网页的编码-->
        <page-encoding></page-encoding>
        <!--若为true表示不支持<%scription%>语法-->
        <scripting-invalid></scripting-invalid>
        <!--设定值所影响的范围,如:/CH2 或者/*.jsp -->
        <url-pattern></url-pattern>
    </jsp-property-group>
    <!--用来设定JSP网页用到的Tag Library路径-->
    <taglib>
        <!--用于指定TLD文件对应Web站台的存放位置-->
        <taglib-location></taglib-location>
<!--用于指定TLD文件的URI,JSP网页的taglib指令可以由这个URI存取到TLD文件-->
        <taglib-uri></taglib-uri>
    </taglib>
 </jsp-config>

 


<!--servlet API的版本2.3增加了对事件监听程序的支持,事件监听程序在建立、修改和删除会话或servlet环境时得到通知。Listener元素指出事件监听程序类-->
<listener>
    <!--声明描述信息-->
    <description></description>
    <!--用于定义Web应用的名称-->
    <display-name></display-name>
    <!--指定应用的大图标和小图标-->
    <icon></icon>
    <!--用于指定监听器的类(完整路径)-->
    <listener-class></listener-class>
</listener>

 


<!--该元素用来设置各种Locale和字符集编码之间的映射关系的集合-->
<locale-encoding-mapping-list>
    <!--该元素用来设置各种Locale和字符集编码之间的映射关系-->
    <locale-encoding-mapping>
        <!--该元素用来指定其Locale的名称,如:zh-CN-->
        <locale></locale>
        <!--该元素用来指定其编码方式-->
        <encoding></encoding>
    </locale-encoding-mapping>
</locale-encoding-mapping-list>

 


<!--指定服务器应该怎样给试图访问受保护页面的用户授权。它与sercurity-constraint元素联合使用-->
<login-config>
    <!--指定对用户身份验证的方法。可能值:
BASIC:使用浏览器进行身份验证(默认),
FORM:使用用户编写的html表单-->
    <auth-method></auth-method>
<!--指定必需相对于文档根目录的web资源的URI,用于对用户进行身份验证。这个可以是HTML页面、JSP或者HTTP Servlet,且必须返回-->
    <form-login-config></form-login-config>
    <!--用于对用户凭据进行身份验证时所引用的领域名称-->
    <realm-name></realm-name>
</login-config>

 


<!--元素指定了一个逻辑目标消息,后者映射到服务器特有部署描述文件中的物理目标信息-->
<message-destination>
    <!--声明描述信息-->
    <description></description>
    <!--用于定义Web应用的名称-->
    <display-name></display-name>
    <!--指定应用的大图标和小图标-->
    <icon></icon>
    <!--为一个目标信息指定一个唯一的名称(仅限于web.xml中)-->
    <message-destination-name></message-destination-name>
</message-destination>

 


<!--用于指出将引用与web.xml中声明资源相关联的信息地址-->
<message-destination-ref>
    <!--声明描述信息-->
    <description></description>
<!--用来连接对一个目标消息的引用。它的值必须通过web.xml文件或者在同一个J2EE应用单元的部署描述文件中message-destination元素的message-destination-name子元素来声明-->
    <message-destination-link></message-destination-link>
<!--定义一个信息地址引用的JNDI名(相对于java:comp/env上下文)。在web.xml中,这个名称必须唯一-->
    <message-destination-ref-name></message-destination-ref-name>
<!--素声明了目标的类型,可以是javax.jms.Queue或javax.jms.Topic-->
    <message-destination-type></message-destination-type>
<!--说明引用所指定的目标信息的使用情况。它的值指出是使用目标信息中的消息,还是产生目标信息,亦或两者兼有(有效值为Consumes,Produces或ConsumesProduces)-->
    <message-destination-usage></message-destination-usage>
</message-destination-ref>

 


<!--如果Web应用具有想到特殊的文件,希望能保证给他们分配特定的MIME类型,则mime-mapping元素提供这种保证-->
<mime-mapping>
    <!--用于指定其扩展名名称-->
    <extension></extension>
    <!--用于指定MIME的格式-->
    <mime-type></mime-type>
</mime-mapping>

 


<!--声明与资源相关的一个管理对象-->
<resource-env-ref>
    <!--声明描述信息-->
    <description></description>
<!--指定资源环境引用的名称,其它值为web应用程序代码中使用的环境条目名称。名称是相对于java:comp/env上下文的JNDI名称,该名称在web应用程序中必须唯一-->
    <resource-env-ref-name></resource-env-ref-name>
    <!--指定资源环境引用的类型,它是java语言的类或者接口的完全限定名称-->
    <resource-env-ref-type></resource-env-ref-type>
</resource-env-ref>

 


<!--声明一个资源工厂使用的外部资源-->
<resource-ref>
    <!--声明描述信息-->
    <description></description>
    <!--用于指定资源由Application或Container来许可-->
    <res-auth></res-auth>
    <!--用于指定资源名称 -->
    <res-ref-name></res-ref-name>
    <!--用于指定资源是否可以共享.默认值为 Shareable -->
    <res-sharing-scope></res-sharing-scope>
    <!--用于指定资源种类-->
    <res-type></res-type> 
</resource-ref>

 


<!--制定应该保护的URL。它与login-config元素联合使用-->
<security-constraint>
    <!--用于定义那些组或委托人可以访问此安全约束内定义的web资源集合-->
    <auth-constraint></auth-constraint>
    <!--用于定义Web应用的名称-->
    <display-name></display-name>
    <!--用于定义客户端如何与服务器进行通信-->
    <user-data-constraint></user-data-constraint>
    <!--用于定义用此安全约束的web应用程序的区域-->
    <web-resource-collection></web-resource-collection>
</security-constraint>

 


<!--给出安全角色的一个列表,这些角色将出现在servlet元素内的security-role-ref元素的role-name子元素中。分别地声明角色可使高级IDE处理安全信息更为容易-->
<security-role>
    <!--声明描述信息-->
    <description></description>
    <!--用于定义那些安全角色可以访问在此安全约束中定义的资源-->
    <role-name></role-name>
</security-role>

 


<!--该元素声明一个对Web服务的引用-->
<service-ref>
    <!--声明描述信息-->
    <description></description>
    <!--用于定义Web应用的名称-->
    <display-name></display-name>
<!--元素为端口组件声明处理器。它包含一个必需的handler-name和handlerclass和可选的init-param,soap-header,soap-role和port-name元素。handler-name元素定义了处理器的名称(在web.xml中是唯一的)。handler-class定义了处理器所实现类的完全限定名-->
    <handler></handler>
    <!--指定应用的大图标和小图标-->
    <icon></icon>
<!--该元素包含将WSDL定义映射到服务终端接口和服务接口的那个文件的位置-->
    <jaxrpc-mapping-file></jaxrpc-mapping-file>
<!--该元素声明了一个在容器中解析服务终端接口到一个WSDL端口的客户端依赖关系。它使用一个特别的端口组件选择性地关联服务终端接口-->
    <port-component-ref></port-component-ref>
    <!--该元素指定Web应用所依赖的JAX-RPC完全限定接口名-->
    <service-interface></service-interface>
<!--该元素与其两个子元素(namespaceURI和localpart)声明了正在引用的WSDL服务元素。如果不指定wsdl-file元素或者WSDL文件只包含一个服务-->
    <service-qname></service-qname>
<!--该元素定义的Web服务(与java:comp/env上下文对应的)-->
    <service-ref-name></service-ref-name>
<!--该元素包含Web服务描述语言文件的位置(相对于Web应用程序的根目录)。这个文件必须放在WEB-INF/wsdl目录中-->
    <wsdl-file></wsdl-file>
</service-ref>

 


<!--在向servlet或JSP页面制定初始化参数或定制URL时,必须首先命名servlet或JSP页面。Servlet元素就是用来完成此项任务的-->
<servlet>
    <!--声明描述信息-->
    <description></description>
    <!--用于定义Web应用的名称-->
    <display-name></display-name>
    <!--指定应用的大图标和小图标-->
    <icon></icon>
    <!--用于指定servlet的一些初始化参数-->
    <init-param></init-param>
    <!--用于指定一个jsp页面来对该servlet进行初始化-->
    <jsp-file></jsp-file>
<!--用于指定应用启动时加载的优先级-->
    <load-on-startup></load-on-startup>
    <!--该元素指定了该web应用程序运行时所需用的运行身份-->
    <run-as></run-as>
<!--该元素将 <security-role> 定义的安全角色名链接到使用Servlet逻辑进行硬编码的备用角色名。使用此附加提取层,可以在部署时配置Servlet,且不必更改Servlet 代码-->
    <security-role-ref></security-role-ref>
    <!--用于指定当前servlet对应的类的路径-->
    <servlet-class></servlet-class>
    <!--用于对当前servlet取一个名称,以便在后面的映射时使用-->
    <servlet-name></servlet-name>
</servlet>

 


<!--服务器一般为servlet提供一个缺省的URL:http://host/webAppPrefix/servlet/ServletName。 但是,常常会更改这个URL,以便servlet可以访问初始化参数或更容易地处理相对URL。在更改缺省URL时,使用servlet-mapping元素-->
<servlet-mapping>
    <!--用于指定上文配置的servlet的名称-->
    <servlet-name></servlet-name>
<!--描述用于解析URL的模式-->
    <url-pattern></url-pattern>
</servlet-mapping>

 


<!--如果某个会话在一定时间内未被访问,服务器可以抛弃它以节省内存。可通过使用HttpSession的setMaxInactiveInterval方法明确设置单个会话对象的超时值,或者可利用session-config元素制定缺省超时值-->
<session-config>
    <!--用于session的超时时间-->
    <session-timeout></session-timeout>
</session-config>

 


<!--指示服务器在收到引用一个目录名而不是文件名的URL时,使用哪个文件-->
<welcome-file-list>
    <!--用于指定欢迎页面的路径-->
    <welcome-file></welcome-file>
</welcome-file-list>



以上是关于web.xml标签详解的主要内容,如果未能解决你的问题,请参考以下文章

web.xml加载顺序详解

Python中verbaim标签使用详解

Servlet 工程 web.xml 中的 servlet 和 servlet-mapping 标签

Servlet 工程 web.xml 中的 servlet 和 servlet-mapping 标签

Servlet 工程 web.xml 中的 servlet 和 servlet-mapping 标签 《转载》

Servlet 工程 web.xml 中的 servlet 和 servlet-mapping 标签