初学者很实用:Web.xml常用元素

来源:互联网 发布:微信打开淘宝二维码 编辑:程序博客网 时间:2024/04/28 17:37
java web开发中最基本的配置本件:Web.xml,很多新手看不大懂,没关系,一起来看看常用的配置有哪些?
首先我们来看一个最精简的Struts2+Spring+hibernate集合框架的Web.xml
<?xml version="1.0" encoding="UTF-8"?>  <web-app version="3.0"       xmlns="http://java.sun.com/xml/ns/javaee"       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"       xsi:schemaLocation="http://java.sun.com/xml/ns/javaee       http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">    <display-name>SSHDemo-<span style="line-height: 21.6000003814697px; font-family: Consolas, 'Bitstream Vera Sans Mono', 'Courier New', Courier, monospace;">挨踢界小人物</span><span style="line-height: 1.8em; font-family: Consolas, 'Bitstream Vera Sans Mono', 'Courier New', Courier, monospace;"></display-name>   </span>     <!-- 添加对spring的支持,也就是配置监听器 -->    <context-param>      <param-name>contextConfigLocation</param-name>      <param-value>classpath:applicationContext.xml</param-value>    </context-param>          <listener>          <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>      </listener>          <!-- 添加对struts2的支持,也就是配置struts2 拦截器,这个拦截器会拦截请求 -->    <filter>      <filter-name>struts2</filter-name>      <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>    </filter>     <!-- 当hibernate+spring配合使用的时候,如果设置了lazy=true,那么在读取数据的时候,当读取了父数据后,       hibernate会自动关闭session,这样,当要使用子数据的时候,系统会抛出lazyinit的错误,        这时就需要使用spring提供的 OpenSessionInViewFilter,OpenSessionInViewFilter主要是保持Session状态        知道request将全部页面发送到客户端,这样就可以解决延迟加载带来的问题 -->     <filter>      <filter-name>openSessionInViewFilter</filter-name>      <filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>      <init-param>        <param-name>singleSession</param-name>        <param-value>true</param-value>      </init-param>    </filter>      <!-- struts2拦截匹配符号,/*表示匹配所有,当然你可以写成*.action 或者*.do-->  <filter-mapping>      <filter-name>struts2</filter-name>      <url-pattern>/*</url-pattern>    </filter-mapping>     <filter-mapping>      <filter-name>openSessionInViewFilter</filter-name>      <url-pattern>*.do,*.action</url-pattern>    </filter-mapping>      <!-- 这里最简单,欢迎页,也就是访问这个web项目弹出的以一个页面 -->  <welcome-file-list>      <welcome-file>index.jsp</welcome-file>    </welcome-file-list>  </web-app>  

---------------------------------------------------下面给出常用标签的介绍:---------------------------------------------------
<web-app>    <display-name></display-name>定义了WEB应用的名字    <description></description> 声明WEB应用的描述信息     <context-param></context-param> context-param元素声明应用范围内的初始化参数。    <filter></filter> 过滤器元素将一个名字与一个实现javax.servlet.Filter接口的类相关联(例如struts2的拦截器:org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter)。    <filter-mapping></filter-mapping> 一旦命名了一个过滤器,就要利用filter-mapping元素把它与一个或多个servlet或JSP页面相关联。    <listener></listener>servlet API的版本2.3增加了对事件监听程序的支持,事件监听程序在建立、修改和删除会话或servlet环境时得到通知。                         Listener元素指出事件监听程序类。(常用到的例如Spring监听器:org.springframework.web.context.ContextLoaderListener)    <servlet></servlet> 在向servlet或JSP页面制定初始化参数或定制URL时,必须首先命名servlet或JSP页面。Servlet元素就是用来完成此项任务的。    <servlet-mapping></servlet-mapping> 服务器一般为servlet提供一个缺省的URL:http://host/webAppPrefix/servlet/ServletName。                <span style="color: #008000;">  但是,常常会更改这个URL,以便servlet可以访问初始化参数或更容易地处理相对URL。</span>在更改缺省URL时,使用servlet-mapping元素。     <session-config></session-config> 如果某个会话在一定时间内未被访问,服务器可以抛弃它以节省内存。              可通过使用HttpSession的setMaxInactiveInterval方法明确设置单个会话对象的超时值,或者可利用session-config元素制定缺省超时值。     <mime-mapping></mime-mapping>如果Web应用具有想到特殊的文件,希望能保证给他们分配特定的MIME类型,则mime-mapping元素提供这种保证。    <welcome-file-list></welcome-file-list> 指示服务器在收到引用一个目录名而不是文件名的URL时,使用哪个文件。    <error-page></error-page> 在返回特定HTTP状态代码时,或者特定类型的异常被抛出时,能够制定将要显示的页面。    <taglib></taglib> 对标记库描述符文件(Tag Libraryu Descriptor file)指定别名。此功能使你能够更改TLD文件的位置,                      而不用编辑使用这些文件的JSP页面。    <resource-env-ref></resource-env-ref>声明与资源相关的一个管理对象。    <resource-ref></resource-ref> 声明一个资源工厂使用的外部资源。    <security-constraint></security-constraint> 制定应该保护的URL。它与login-config元素联合使用    <login-config></login-config> 指定服务器应该怎样给试图访问受保护页面的用户授权。它与sercurity-constraint元素联合使用。    <security-role></security-role>给出安全角色的一个列表,这些角色将出现在servlet元素内的security-role-ref元素                       的role-name子元素中。分别地声明角色可使高级IDE处理安全信息更为容易。    <env-entry></env-entry>声明Web应用的环境项。    <ejb-ref></ejb-ref>声明一个EJB的主目录的引用。    < ejb-local-ref></ ejb-local-ref>声明一个EJB的本地主目录的应用。    </web-app>    
---------------------------------------------------想看更多Web.xml介绍?---------------------------------------------------

这是给初学者看的,基本上是够用了。当然,Web.xml还有很多的配置,查看更多详细配置。
0 0
原创粉丝点击