web应用发布描述文件(即l文件)是在Servlet规范中定义的。他是web应用的配置文件。l和tomcat容器完全独立。
<web-app>
</web-app>为顶层元素,其他所有子元素都必须定义在它的里面,而且要按元素定义的先后顺序不能颠倒。
下面介绍下它的子元素:
1.<display-name> 该web站点的名称
2.<description> 该web站点的说明
3.<context-param> 用来设定该web站点的环境参数(context「配置应用上下文参数」),并初始化它
①<param-name> 参数名称
②<param-value> 参数值
4.<filter> 设定该web站点的过滤器
①<filter-name> 过滤器的名称
②<filter-class> 指定过滤器的实现类,负责具体的过滤事务
5.<filter-mapping> 设定该web站点的过滤器的映射
①<filter-name> 过滤器的名称
②<url-pattern> 指定过滤器负责过滤的URL
6.<servlet> 设定该web站点的Servlet的名称和映射
①<servlet-name> Servlet的名称
②<servlet-class> 指定Servlet的实现类
③<init-param> 定义servlet的初始化参数(包括参数名和参数值)
(1)<param-name> 指定参数的参数名
(2)<param-value> 指定参数的参数值
④<load-on-startup> 指定当web应用启动时,装载servlet的次序。当值为0或正数时,servlet容器先加载小的;如果值为负数或者没有设定,那么servlet容器将在web客户首次访问这个servlet时加载它。
{
Config参数:以相对路径的方式指明struts应用程序的配置文件的位置,如果不设置,则默认值为/l
Debug参数:社会自servlet的debug级别,空值日志记录的详细程度。默认为0,记录相对最少的日志信息。
Detail参数:设置Digester的debug级别,Digester是Struts框架所使用的用来解析xml配置文件的一个框架,通过此设置,可以查看不同详细等级的解析日志。默认为0,记录相对最少的日志信息。
}
7.<servlet-mapping> 设定该web站点的Servlet的映射
①<servlet-name> Servlet的名称
②<url-pattern> 指定访问这个Servlet的URL。这里只需给出对于整个web应用的相对URL路径
8.<session-config> 设定该web站点的httpSession的生命周期(单位:分钟)
①<session-timeout> 指定该httpSession得有效时间。
9.<welcome-file-list> 设定该web站点的欢迎文件列表
①<welcome-file> 指定欢迎文件名称。
10.<taglib> 设定该web站点所使用的taglib
①<taglib-uri> 设定taglib的唯一标识符,在web应用中将根据这一标识符来引用tablib。
②<taglib-location> 指定和taglib对应的tld文件的位置。
11.<resource-ref> 设定该web站点所应用的资源
①<description> 对所引用资源的说明
②<res-ref-name> 指定所引用资源的JNDI名字
③<res-type> 指定所引用资源的类名字
④<res-auth> 指定管理所引用资源的Manager,它有两个可选值:Container和Application。Container表示由容器来创建和管理Resource,Application表示由web应用来创建和管理Resource。
12.<security-role> 设定该web站点对应Tomcat的l中设置的角名
①<security-role> 对应Tomcat的l中设置的角名
13.<login-config> 设定该web站点四种认证类型
①BASIC:HTTP规范,Base64
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
②DIGEST:HTTP规范,数据完整性强一些,但不是java上下文contextSSL
<login-config>
<auth-method>DIGEST</auth-method>
</login-config>
③CLIENT-CERT:J2EE规范,数据完整性很强,公共钥匙(PKC)
<login-config>
<auth-method>CLIENT-CERT</auth-method>
</login-config>
④FORM:J2EE规范,数据完整性非常弱,没有加密,允许有定制的登陆界面。
<login-config>
<auth-method>FORM</auth-method>
<form-login-config>
<form-login-page>/login.jsp</form-login-page>
<form-error-page>/error.jsp</form-error-page>
</form-login-config>
</login-config>
<auth-method>FORM</auth-method>
<form-login-config>
<form-login-page>/login.jsp</form-login-page>
<form-error-page>/error.jsp</form-error-page>
</form-login-config>
</login-config>
14.<error-page> 设定该web站点的错误页面
<!-- 根据HTTP状态码定制错误页面 -->
<error-page>
<error-code>404</error-code>
<location>NotFoundRuntimeException.html</location>
</error-page>
<!-- 根据异常类型定制错误页面 -->
<error-page>
<exception-type>java.lang.Throwable</exception-type>
<location>InternalServerErrorRuntimeException.html</location>
</error-page>
15.配置:
<web-app>
<web-app>
........
<listener>
<listener-class>com.jj.MyServletContextListener</listener-class>
</listener>
........
</web-app>
<listener>
<listener-class>com.jj.MyServletContextListener</listener-class>
</listener>
........
</web-app>
16.EJB相关和MIME映射:
<web-app>
......
<!-- 本地Bean的引用 -->
<ejb-local-ref>
<ejb-ref-name>ejb/customer</ejb-ref-name>
<ejb-ref-type>Entity</ejb-ref-type>
<local-home>com.jj.CustomerHome</local-home>
<web-app>
......
<!-- 本地Bean的引用 -->
<ejb-local-ref>
<ejb-ref-name>ejb/customer</ejb-ref-name>
<ejb-ref-type>Entity</ejb-ref-type>
<local-home>com.jj.CustomerHome</local-home>
<local>com.jj.Customer</local>
</ejb-local-ref>
<!-- 远程Bean的引用 -->
<ejb-ref>
<ejb-ref-name>ejb/LocalCustomer</ejb-ref-name>
<ejb-ref-type>Entity</ejb-ref-type>
<home>com.jj.CustomerHome</home>
<remote>com.jj.Customer</remote>
</ejb-ref>
<!-- 声明应用的JNDI环境项 -->
<env-entry>
<env-entry-name>rates/discountRate</env-entry-name>
<env-entry-type>java.lang.Integer</env-entry-type>
</ejb-local-ref>
<!-- 远程Bean的引用 -->
<ejb-ref>
<ejb-ref-name>ejb/LocalCustomer</ejb-ref-name>
<ejb-ref-type>Entity</ejb-ref-type>
<home>com.jj.CustomerHome</home>
<remote>com.jj.Customer</remote>
</ejb-ref>
<!-- 声明应用的JNDI环境项 -->
<env-entry>
<env-entry-name>rates/discountRate</env-entry-name>
<env-entry-type>java.lang.Integer</env-entry-type>
<env-entry-value>10</env-entry-value>
</env-entry>
<!-- 配置扩展名和MIME类型之间的映射 -->
<mime-mapping>
<extension>mpg</extension>
<mime-type>video/mpeg</mime-type>
</mime-mapping>
......
</web-app>
</env-entry>
<!-- 配置扩展名和MIME类型之间的映射 -->
<mime-mapping>
<extension>mpg</extension>
<mime-type>video/mpeg</mime-type>
</mime-mapping>
......
</web-app>
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论