GVKun编程网logo

web.xml配置详解(web.xml配置详解在哪儿)

18

如果您对web.xml配置详解感兴趣,那么本文将是一篇不错的选择,我们将为您详在本文中,您将会了解到关于web.xml配置详解的详细内容,我们还将为您解答web.xml配置详解在哪儿的相关问题,并且为

如果您对web.xml配置详解感兴趣,那么本文将是一篇不错的选择,我们将为您详在本文中,您将会了解到关于web.xml配置详解的详细内容,我们还将为您解答web.xml配置详解在哪儿的相关问题,并且为您提供关于bulid.xml配置详解、dwr.xml配置详解、Ehache.xml配置详解、ehcache.xml配置详解的有价值信息。

本文目录一览:

web.xml配置详解(web.xml配置详解在哪儿)

web.xml配置详解(web.xml配置详解在哪儿)

1、spring 框架解决字符串编码问题:过滤器 CharacterEncodingFilter(filter-name) 
2、在web.xml配置监听器ContextLoaderListener(listener-class) 
ContextLoaderListener的作用就是启动Web容器时,自动装配ApplicationContext的配置信息。因为它实现了ServletContextListener这个接口,在web.xml配置这个监听器,启动容器时,就会默认执行它实现的方法。 
3、部署applicationContext的xml文件:contextConfigLocation(context-param下的param-name) 
4、DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自已定义,把拦截下来的请求,依据某某规则分发到目标Controller(我们写的Action)来处理。 
DispatcherServlet(servlet-name、servlet-class、init-param、param-name(contextConfigLocation)、param-value) 
在DispatcherServlet的初始化过程中,框架会在web应用的 WEB-INF文件夹下寻找名为[servlet-name]-servlet.xml 的配置文件,生成文件中定义的bean

<?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"> <!-- 在Spring框架中是如何解决从页面传来的字符串的编码问题的呢? 下面我们来看看Spring框架给我们提供过滤器CharacterEncodingFilter 这个过滤器就是针对于每次浏览器请求进行过滤的,然后再其之上添加了父类没有的功能即处理字符编码。 其中encoding用来设置编码格式,forceEncoding用来设置是否理会 request.getCharacterEncoding()方法,设置为true则强制覆盖之前的编码格式。--> <filter> <filter-name>characterEncodingFilter</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>characterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- 项目中使用Spring 时,applicationContext.xml配置文件中并没有BeanFactory,要想在业务层中的class 文件中直接引用Spring容器管理的bean可通过以下方式--> <!--1、在web.xml配置监听器ContextLoaderListener--> <!--ContextLoaderListener的作用就是启动Web容器时,自动装配ApplicationContext的配置信息。因为它实现了ServletContextListener这个接口,在web.xml配置这个监听器,启动容器时,就会默认执行它实现的方法。 在ContextLoaderListener中关联了ContextLoader这个类,所以整个加载配置过程由ContextLoader来完成。 它的API说明 第一段说明ContextLoader可以由 ContextLoaderListener和ContextLoaderServlet生成。 如果查看ContextLoaderServlet的API,可以看到它也关联了ContextLoader这个类而且它实现了HttpServlet这个接口 第二段,ContextLoader创建的是 XmlWebApplicationContext这样一个类,它实现的接口是WebApplicationContext->ConfigurableWebApplicationContext->ApplicationContext-> BeanFactory这样一来spring中的所有bean都由这个类来创建 IUploaddatafileManager uploadmanager = (IUploaddatafileManager) ContextLoaderListener.getCurrentWebApplicationContext().getBean("uploadManager"); --> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!--2、部署applicationContext的xml文件--> <!--如果在web.xml中不写任何参数配置信息,默认的路径是"/WEB-INF/applicationContext.xml, 在WEB-INF目录下创建的xml文件的名称必须是applicationContext.xml。 如果是要自定义文件名可以在web.xml里加入contextConfigLocation这个context参数: 在<param-value> </param-value>里指定相应的xml文件名,如果有多个xml文件,可以写在一起并以“,”号分隔。 也可以这样applicationContext-*.xml采用通配符,比如这那个目录下有applicationContext-ibatis-base.xml, applicationContext-action.xml,applicationContext-ibatis-dao.xml等文件,都会一同被载入。 在ContextLoaderListener中关联了ContextLoader这个类,所以整个加载配置过程由ContextLoader来完成。--> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/applicationContext.xml</param-value> </context-param> <!--如果你的DispatcherServlet拦截"/",为了实现REST风格,拦截了所有的请求,那么同时对*.js,*.jpg等静态文件的访问也就被拦截了。--> <!--方案一:激活Tomcat的defaultServlet来处理静态文件--> <!--要写在DispatcherServlet的前面, 让 defaultServlet先拦截请求,这样请求就不会进入Spring了,我想性能是最好的吧。--> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.css</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.swf</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.gif</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.jpg</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.png</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.js</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.html</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.xml</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.json</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.map</url-pattern> </servlet-mapping> <!--使用Spring MVC,配置DispatcherServlet是第一步。DispatcherServlet是一个Servlet,,所以可以配置多个DispatcherServlet--> <!--DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自已定义,把拦截下来的请求,依据某某规则分发到目标Controller(我们写的Action)来处理。--> <servlet> <servlet-name>DispatcherServlet</servlet-name><!--在DispatcherServlet的初始化过程中,框架会在web应用的 WEB-INF文件夹下寻找名为[servlet-name]-servlet.xml 的配置文件,生成文件中定义的bean。--> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!--指明了配置文件的文件名,不使用默认配置文件名,而使用dispatcher-servlet.xml配置文件。--> <init-param> <param-name>contextConfigLocation</param-name> <!--其中<param-value>**.xml</param-value> 这里可以使用多种写法--> <!--1、不写,使用默认值:/WEB-INF/<servlet-name>-servlet.xml--> <!--2、<param-value>/WEB-INF/classes/dispatcher-servlet.xml</param-value>--> <!--3、<param-value>classpath*:dispatcher-servlet.xml</param-value>--> <!--4、多个值用逗号分隔--> <param-value>classpath:spring/dispatcher-servlet.xml</param-value> </init-param> <load-on-startup>1</load-on-startup><!--是启动顺序,让这个Servlet随Servletp容器一起启动。--> </servlet> <servlet-mapping> <!--这个Servlet的名字是dispatcher,可以有多个DispatcherServlet,是通过名字来区分的。每一个DispatcherServlet有自己的WebApplicationContext上下文对象。同时保存的ServletContext中和Request对象中.--> <!--ApplicationContext是Spring的核心,Context我们通常解释为上下文环境,我想用“容器”来表述它更容易理解一些,ApplicationContext则是“应用的容器”了:P,Spring把Bean放在这个容器中,在需要的时候,用getBean方法取出--> <servlet-name>DispatcherServlet</servlet-name> <!--Servlet拦截匹配规则可以自已定义,当映射为@RequestMapping("/user/add")时,为例,拦截哪种URL合适?--> <!--1、拦截*.do、*.htm, 例如:/user/add.do,这是最传统的方式,最简单也最实用。不会导致静态文件(jpg,js,css)被拦截。--> <!--2、拦截/,例如:/user/add,可以实现现在很流行的REST风格。很多互联网类型的应用很喜欢这种风格的URL。弊端:会导致静态文件(jpg,js,css)被拦截后不能正常显示。 --> <url-pattern>/</url-pattern> <!--会拦截URL中带“/”的请求。--> </servlet-mapping> <welcome-file-list><!--指定欢迎页面--> <welcome-file>login.html</welcome-file> </welcome-file-list> <error-page> <!--当系统出现404错误,跳转到页面nopage.html--> <error-code>404</error-code> <location>/nopage.html</location> </error-page> <error-page> <!--当系统出现java.lang.NullPointerException,跳转到页面error.html--> <exception-type>java.lang.NullPointerException</exception-type> <location>/error.html</location> </error-page> <session-config><!--会话超时配置,单位分钟--> <session-timeout>360</session-timeout> </session-config> </web-app>

bulid.xml配置详解

bulid.xml配置详解

Xml代码
  1. <!--由于工作上用到才去学习O(∩_∩)O哈哈~-->
  2. Ant的优点
  3. Ant是Apache软件基金会JAKARTA目录中的一个子项目,它有以下的优点。
  4. 跨平台性。Ant是存Java语言编写的,所示具有很好的跨平台性。
  5. 操作简单。Ant是由一个内置任务和可选任务组成的。Ant运行时需要一个XML文件(构建文件)。
  6. Ant通过调用target树,就可以执行各种task。每个task实现了特定接口对象。由于Ant构建文件
  7. 时XML格式的文件,所以和容易维护和书写,而且结构很清晰。
  8. Ant可以集成到开发环境中。由于Ant的跨平台性和操作简单的特点,它很容易集成到一些开发环境中去。
  9. Ant开发
  10. Ant的构建文件
  11. 当开始一个新的项目时,首先应该编写Ant构建文件。构建文件定义了构建过程,并被团队开发
  12. 中每个人使用。Ant构建文件默认命名为build.xml,也可以取其他的名字。只不过在运行的时候
  13. 把这个命名当作参数传给Ant。构建文件可以放在任何的位置。一般做法是放在项目顶层目录中
  14. ,这样可以保持项目的简洁和清晰。下面是一个典型的项目层次结构。
  15. (1)src存放文件。
  16. (2)class存放编译后的文件。
  17. (3)lib存放第三方jar包。
  18. (4)dist存放打包,发布以后的代码。
  19. Ant构建文件是XML文件。每个构建文件定义一个唯一的项目(Project元素)。每个项目下可以定
  20. 义很多目标(target元素),这些目标之间可以有依赖关系。当执行这类目标时,需要执行他们所
  21. 依赖的目标。
  22. 每个目标中可以定义多个任务,目标中还定义了所要执行的任务序列。Ant在构建目标时必须调
  23. 用所定义的任务。任务定义了Ant实际执行的命令。Ant中的任务可以为3类。
  24. (1)核心任务。核心任务是Ant自带的任务。
  25. (2)可选任务。可选任务实来自第三方的任务,因此需要一个附加的JAR文件。
  26. (3)用户自定义的任务。用户自定义的任务实用户自己开发的任务。
  27. 1.<project>标签
  28. 每个构建文件对应一个项目。<project>标签时构建文件的根标签。它可以有多个内在属性,
  29. 就如代码中所示,其各个属性的含义分别如下。
  30. (1)default表示默认的运行目标,这个属性是必须的。
  31. (2)basedir表示项目的基准目录。
  32. (3)name表示项目名。
  33. (4)description表示项目的描述。
  34. 每个构建文件都对应于一个项目,但是大型项目经常包含大量的子项目,每一个子项目都可以有
  35. 自己的构建文件。
  36. 2.<target>标签
  37. 一个项目标签下可以有一个或多个target标签。一个target标签可以依赖其他的target标签。例
  38. 如,有一个target用于编译程序,另一个target用于声称可执行文件。在生成可执行文件之前必
  39. 须先编译该文件,因策可执行文件的target依赖于编译程序的target。Target的所有属性如下。
  40. (1).name表示标明,这个属性是必须的。
  41. (2).depends表示依赖的目标。
  42. (3)if表示仅当属性设置时才执行。
  43. (4)unless表示当属性没有设置时才执行。
  44. (5)description表示项目的描述。
  45. Ant的depends属性指定了target的执行顺序。Ant会依照depends属性中target出现顺序依次执行
  46. 每个target。在执行之前,首先需要执行它所依赖的target。程序中的名为run的target的
  47. depends属性compile,而名为compile的target的depends属性是prepare,所以这几个target执
  48. 行的顺序是prepare->compile->run。
  49. 一个target只能被执行一次,即使有多个target依赖于它。如果没有if或unless属性,target总
  50. 会被执行。
  51. 3.<mkdir>标签
  52. 该标签用于创建一个目录,它有一个属性dir用来指定所创建的目录名,其代码如下:
  53. <mkdirdirmkdirdir=”${class.root}”/>
  54. 通过以上代码就创建了一个目录,这个目录已经被前面的property标签所指定。
  55. 4<jar>标签
  56. 该标签用来生成一个JAR文件,其属性如下。
  57. (1)destfile表示JAR文件名。
  58. (2)basedir表示被归档的文件名。
  59. (3)includes表示别归档的文件模式。
  60. (4)exchudes表示被排除的文件模式。
  61. 5.<javac标签>
  62. 该标签用于编译一个或一组java文件,其属性如下。
  63. (1).srcdir表示源程序的目录。
  64. (2).destdir表示class文件的输出目录。
  65. (3).include表示被编译的文件的模式。
  66. (4).excludes表示被排除的文件的模式。
  67. (5).classpath表示所使用的类路径。
  68. (6).debug表示包含的调试信息。
  69. (7).optimize表示是否使用优化。
  70. (8).verbose表示提供详细的输出信息。
  71. (9).fileonerror表示当碰到错误就自动停止。
  72. 6.<java>标签
  73. 该标签用来执行编译生成的.class文件,其属性如下。
  74. (1).classname表示将执行的类名。
  75. (2).jar表示包含该类的JAR文件名。
  76. (3).classpath所表示用到的类路径。
  77. (4).fork表示在一个新的虚拟机中运行该类。
  78. (5).failonerror表示当出现错误时自动停止。
  79. (6).output表示输出文件。
  80. (7).append表示追加或者覆盖默认文件。
  81. 7.<delete>标签
  82. 该标签用于删除一个文件或一组文件,去属性如下。
  83. (1)/file表示要删除的文件。
  84. (2).dir表示要删除的目录。
  85. (3).includeEmptyDirs表示指定是否要删除空目录,默认值是删除。
  86. (4).failonerror表示指定当碰到错误是否停止,默认值是自动停止。
  87. (5).verbose表示指定是否列出所删除的文件,默认值为不列出。
  88. 8.<copy>标签
  89. 该标签用于文件或文件集的拷贝,其属性如下。
  90. (1).file表示源文件。
  91. (2).tofile表示目标文件。
  92. (3).todir表示目标目录。
  93. (4).overwrite表示指定是否覆盖目标文件,默认值是不覆盖。
  94. (5).includeEmptyDirs表示制定是否拷贝空目录,默认值为拷贝。
  95. (6).failonerror表示指定如目标没有发现是否自动停止,默认值是停止。
  96. (7).verbose表示制定是否显示详细信息,默认值不显示。
  97. Ant的数据类型
  98. 在构建文件中为了标识文件或文件组,经常需要使用数据类型。数据类型包含在
  99. org.apache.tool.ant.types包中。下面镜简单介绍构建文件中一些常用的数据类型。
  100. 1.argument类型
  101. 由Ant构建文件调用的程序,可以通过<arg>元素向其传递命令行参数,如apply,exec和java任
  102. 务均可接受嵌套<arg>元素,可以为各自的过程调用指定参数。以下是<arg>的所有属性。
  103. (1).values是一个命令参数。如果参数种有空格,但又想将它作为单独一个值,则使用此属性
  104. (2).file表示一个参数的文件名。在构建文件中,此文件名相对于当前的工作目录。
  105. (3).line表示用空格分隔的多个参数列表。
  106. (4).path表示路径。
  107. 2.ervironment类型
  108. 由Ant构建文件调用的外部命令或程序,<env>元素制定了哪些环境变量要传递给正在执行的系
  109. 统命令,<env>元素可以接受以下属性。
  110. (1).file表示环境变量值得文件名。此文件名要被转换位一个绝对路径。
  111. (2).path表示环境变量的路径。Ant会将它转换为一个本地约定。
  112. (3).value表示环境变量的一个直接变量。
  113. (4).key表示环境变量名。
  114. 注意filepath或value只能取一个。
  115. 3.filelist类型
  116. Filelist是一个支持命名的文件列表的数据类型,包含在一个filelist类型中的文件不一定是
  117. 存在的文件。以下是其所有的属性。
  118. (1).dir是用于计算绝对文件名的目录。
  119. (2).files是用逗号分隔的文件名列表。
  120. (3).refid是对某处定义的一个<filelist>的引用。
  121. 注意dir和files都是必要的,除非指定了refid(这种情况下,dir和files都不允许使用)。
  122. 4.fileset类型
  123. Fileset数据类型定义了一组文件,并通常表示为<fileset>元素。不过,许多ant任务构建成了
  124. 隐式的fileset,这说明他们支持所有的fileset属性和嵌套元素。以下为fileset的属性列表。
  125. (1).dir表示fileset的基目录。
  126. (2).casesensitive的值如果为false,那么匹配文件名时,fileset不是区分大小写的,其默认
  127. 值为true.
  128. (3).defaultexcludes用来确定是否使用默认的排除模式,默认为true。
  129. (4).excludes是用逗号分隔的需要派出的文件模式列表。
  130. (5).excludesfile表示每行包含一个排除模式的文件的文件名。
  131. (6).includes是用逗号分隔的,需要包含的文件模式列表。
  132. (7).includesfile表示每行包括一个包含模式的文件名。
  133. 5.patternset类型
  134. Fileset是对文件的分组,而patternset是对模式的分组,他们是紧密相关的概念。
  135. <patternset>支持4个属性:includesexcludexincludexfile和excludesfile,与fileset相
  136. 同。Patternset还允许以下嵌套元素:include,exclude,includefile和excludesfile.
  137. 6.filterset类型
  138. Filterset定义了一组过滤器,这些过滤器将在文件移动或复制时完成文件的文本替换。
  139. 主要属性如下:
  140. (1).begintoken表示嵌套过滤器所搜索的记号,这是标识其开始的字符串。
  141. (2).endtoken表示嵌套过滤器所搜索的记号这是标识其结束的字符串。
  142. (3).id是过滤器的唯一标志符。
  143. (4).refid是对构建文件中某处定义一个过滤器的引用。
  144. 7.Path类型
  145. Path元素用来表示一个类路径,不过它还可以用于表示其他的路径。在用作揖个属性时,路经中
  146. 的各项用分号或冒号隔开。在构建的时候,此分隔符将代替当前平台中所有的路径分隔符,其拥
  147. 有的属性如下。
  148. (1).location表示一个文件或目录。Ant在内部将此扩展为一个绝对路径。
  149. (2).refid是对当前构建文件中某处定义的一个path的引用。
  150. (3).path表示一个文件或路径名列表。
  151. 8.mapper类型
  152. Mapper类型定义了一组输入文件和一组输出文件间的关系,其属性如下。
  153. (1).classname表示实现mapper类的类名。当内置mapper不满足要求时,用于创建定制mapper.
  154. (2).classpath表示查找一个定制mapper时所用的类型路径。
  155. (3).classpathref是对某处定义的一个类路径的引用。
  156. (4).from属性的含义取决于所用的mapper.
  157. (5).to属性的含义取决于所用的mapper.
  158. (6).type属性的取值为identity,flattenglobmergeregexp其中之一,它定义了要是用的
  159. 内置mapper的类型。
  160. Ant的运行
  161. 安装好Ant并且配置好路径之后,在命令行中切换到构建文件的目录,输入Ant命令就可以运行
  162. Ant.若没有指定任何参数,Ant会在当前目录下查询build.xml文件。如果找到了就用该文件作为
  163. 构建文件。如果使用了–find选项,Ant就会在上级目录中找构建文件,直至到达文件系统得
  164. 跟目录。如果构建文件的名字不是build.xml,则Ant运行的时候就可以使用–buildfilefile
  165. ,这里file指定了要使用的构建文件的名称,示例如下:
  166. Ant
  167. 如下说明了表示当前目录的构建文件为build.xml运行ant执行默认的目标。
Xml代码
  1. ===============================build.xml配置=========================
  2. <?xmlversion="1.0"encoding="UTF-8"?>
  3. <!--官方网站:http://ant.apache.org/-->
  4. <projectnameprojectname="MyAntProject"basedir="."default="package">
  5. <!--用ant连接数据库创建表-->
  6. <!--
  7. 要是报错请,右击build.xml==>>Runas=>>Antbuild找到Classpath==>>AddExternalJARs
  8. 添加报错所需要的jar即可...
  9. 例如:BUILDFailedClassNotFound:(这句是在你没写检测才会输出.)
  10. JDBCdrivercom.MysqL.jdbc.DriverCouldnotbeloaded
  11. -->
  12. <propertynamepropertyname="driver"value="com.MysqL.jdbc.Driver"/>
  13. <propertynamepropertyname="url"value="jdbc:MysqL://localhost:3306/test?useUnicode=true"/>
  14. <propertynamepropertyname="user"value="root"/>
  15. <propertynamepropertyname="password"value="root"/>
  16. <!--检查Classpath是否有安装mysql-connector-java-5.1.7-bin.jar(一般程序员知道classpath加载什么jar才会写上提醒)-->
  17. <availableclassnameavailableclassname="com.MysqL.jdbc.Driver"property="MysqL.present"/>
  18. <!--<availablefile="mysql-connector-java-5.1.7-bin.jar"property="MysqLjar.present"/>-->
  19. <failunlessfailunless="MysqL.present"message="mysql-connector-java-5.1.7-bin.jar没安装,请你在run的时候添加.."/>
  20. <!-------------------target:创建表------------------->
  21. <targetnaMetargetname="createTable">
  22. <!--person表-->
  23. <sqldriversqldriver="${driver}"password="${password}"url="${url}"userid="${user}">
  24. createtableant_person(
  25. idintprimarykey,
  26. namevarchar(20)notnull,
  27. ageint
  28. );
  29. <!--
  30. insertintoant_personvalues(1,'jilong',23);
  31. 为了临时表有数据就放在这里.要是比较专业的一般在初始化数据插入数据
  32. -->
  33. createtableant_tempselect*fromant_person;<!--创建临时表-->
  34. </sql>
  35. </target>
  36. <!-------------------target:删除表----------------->
  37. <targetnaMetargetname="dropTable">
  38. <sqldriversqldriver="${driver}"password="${password}"url="${url}"userid="${user}">
  39. droptableant_person;
  40. droptableant_temp;
  41. </sql>
  42. </target>
  43. <!-------------------target:初始化数据.------------------->
  44. <targetnaMetargetname="InitData">
  45. <sqldriversqldriver="${driver}"password="${password}"url="${url}"userid="${user}">
  46. insertintoant_personvalues(2,23);
  47. </sql>
  48. </target>
  49. <!-----------------target:同时执行创建表和插入数据.---------------->
  50. <targetnaMetargetname="create_init"depends="createTable,InitData"/>
  51. <!--=======================================================================================-->
  52. <!--定义文件目录的name和value-->
  53. <propertynamepropertyname="compile"value="compile"/>
  54. <propertynamepropertyname="dist"value="dist"/>
  55. <propertynamepropertyname="src"value="src"/>
  56. <targetnaMetargetname="init"/>
  57. <!--定义两个文件的根目录-->
  58. <targetnaMetargetname="preprocess"depends="init">
  59. <mkdirdirmkdirdir="${compile}"/>
  60. <mkdirdirmkdirdir="${dist}"/>
  61. </target>
  62. <targetnaMetargetname="compile"depends="init,preprocess"/>
  63. <targetnaMetargetname="package"depends="compile"/>
  64. <!--编译java类成.class文件-->
  65. <targetnaMetargetname="myCompile"depends="preprocess">
  66. <javacsrcdirjavacsrcdir="src"destdir="${compile}"fork="true"memorymaximumsize="4m"/>
  67. </target>
  68. <!--创建一个.jar夹-->
  69. <targetnaMetargetname="dist"depends="myCompile">
  70. <!--设置时间格式的有${TSTAMP}/${TODAY}-->
  71. <tstamp/>
  72. <jardestfilejardestfile="${dist}/package1-${TODAY}.jar"basedir="${compile}">
  73. <manifest>
  74. <!--user.name是操作系统的用户名-->
  75. <attributenameattributename="Built-By"value="${user.name}"/>
  76. <attributenameattributename="Main-Class"value="com.test.Test1"/>
  77. </manifest>
  78. </jar>
  79. </target>
  80. <!--删除jar-->
  81. <targetnaMetargetname="deleteFile">
  82. <deletefiledeletefile="${dist}/package1-${TSTAMP}.jar"/>
  83. </target>
  84. <!--拷貝文件,一般在打包项目的用来备份项目,或者把打包的jar拷贝到服务器部署目录下,
  85. 那就可以不用手工拷贝夹部署demo..-->
  86. <targetnaMetargetname="copyFile">
  87. <copyfilecopyfile="src/com/test/Test1.java"tofile="D:/Testcopy.java"/>
  88. <copyfilecopyfile="src/com/test/Test1.java"todir="D:\"/>
  89. </target>
  90. <!--剪切/移動文件-->
  91. <targetnaMetargetname="moveFile">
  92. <movefilemovefile="src/com/test/Test1.java"todir="D:"/>
  93. </target>
  94. <!--打包成.zip夹包-->
  95. <targetnaMetargetname="compress"depends="compile">
  96. <zipdestfilezipdestfile="${dist}/package.zip"basedir="${compile}"/>
  97. </target>
  98. <!--打包成.ear夹包-->
  99. <targetnaMetargetname="earFile"depends="compile">
  100. <eardestfileeardestfile="${dist}/ant_ear.ear"basedir="${compile}"/>
  101. </target>
  102. <!--打包成.war夹包-->
  103. <targetnaMetargetname="warFile"depends="compile">
  104. <wardestfilewardestfile="${dist}/ant_war.war"basedir="${compile}"/>
  105. </target>
  106. <!--不打包/解压-->
  107. <targetnaMetargetname="umcompress"depends="compress">
  108. <unzipdestunzipdest="${dist}"src="${dist}/package.zip"/>
  109. </target>
  110. <!--找文字替换summary可以输出提示替换了几个-->
  111. <targetnaMetargetname="replaceFile">
  112. <replacefilereplacefile="input.txt"token="old"value="new"summary="on"/>
  113. </target>
  114. <!--拷貝所有.java的文件-->
  115. <targetnaMetargetname="copy">
  116. <copytodircopytodir="${dist}">
  117. <filesetdirfilesetdir="src">
  118. <includenameincludename="**/*.java"/>
  119. </fileset>
  120. </copy>
  121. </target>
  122. <!--自定义一个类来處理Task-->
  123. <taskdefnametaskdefname="MyTaskExample"classname="com.ant.tool.extend.AntTasks"classpath="bin"/>
  124. <!--引用自定标签的namemyTaskExample-->
  125. <targetnaMetargetname="MyAntTasks">
  126. <myTaskExamplesrcFilemyTaskExamplesrcFile="input.txt"destFile="output.txt"/>
  127. </target>
  128. <!--用echo显示各种的属性-->
  129. <targetnaMetargetname="showProperty">
  130. <echomessageechomessage="当前系统的用户名:${user.name}"/>
  131. <echomessageechomessage="当前系统的版本:${os.version}"/>
  132. <echomessageechomessage="当前系统的安装路径:${user.home}"/>
  133. <echomessageechomessage="ant的xml文件:${ant.file}"/>
  134. <echomessageechomessage="当前系统的语言:${user.language}"/>
  135. <echomessageechomessage="ant发现Java虚拟机的版本:${ant.java.version}"/>
  136. <echomessageechomessage="项目的绝对路径:${basedir}"/>
  137. <echomessageechomessage="lib类库:${ant.library.dir}"/>
  138. <echomessageechomessage="ApacheAntversion:${ant.version}"/>
  139. <echomessageechomessage="jre目录:${java.home}"/>
  140. <echomessageechomessage="安装系统:${os.name}"/>
  141. <echomessageechomessage="${user.country}"/>
  142. </target>
  143. </project>

运行的结果:


Buildfile: D:\Eclipse-Source\Ant\build.xml

showProperty:

[echo]当前系统的用户名:Administrator

[echo]当前系统的版本:6.1

[echo]当前系统的安装路径:C:\Users\Administrator

[echo] antxml文件:D:\Eclipse-Source\Ant\build.xml

[echo]当前系统的语言:zh

[echo] ant发现Java虚拟机的版本:1.6

[echo]项目的绝对路径:D:\Eclipse-Source\Ant

[echo] lib类库:C:\Users\Administrator\AppData\Local\Genuitec\Common\plugins\org.apache.ant_1.7.1.v20090120-1145\lib

[echo] Apache Ant version :Apache Ant version 1.7.1 compiled on June 27 2008

[echo] jre目录:C:\Users\Administrator\AppData\Local\Genuitec\Common\binary\com.sun.java.jdk.win32.x86_1.6.0.013\jre

[echo]安装系统:Windows Vista

[echo] CN

BUILD SUCCESSFUL

Total time: 175 milliseconds

图解:


dwr.xml配置详解

dwr.xml配置详解

       感觉dwr很实用,所以想多了解一下。dwr的核心就是这个dwr.xml。在网上收集整理了一些dwr.xml的配置信息。现拿出来与大家分享。


       dwr.xml的大体结构如下:

<!DOCTYPE dwr PUBLIC
    "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN"
    "http://www.getahead.ltd.uk/dwr/dwr20.dtd">
//整个配置文件的大体结构如下:
<dwr>
  <init>
    <creator id="..."/>
    <converter id="..."/>
  </init>
  <allow>
    <create creator="..." javascript="..." scope="...">
      <param name="..." value="..."/>
    </create>
    <convert convertor="..." match="..."/>
  </allow>
  <signatures>
    ...
  </signatures>

       <init> 部分声明那些用于建立远程bean和在方法调用中转换bean的类.这部分是可选择性配置的,如果你想定义一个新的creator(创造器)或者converter(转换器),那么就必须在部分中声明,每个creator和converter需要有个id属性来允许以后进行引用。

       <allow> 部分定义了DWR能够创建和转换的类,以供 javascript 访问。

       <create> 标签中指定 javascript 中可以访问的 java 类,并定义 dwr 应当如何获得要进行远程的类的实例。

其中 javascript=" testClass " 属性指定 javascript 代码访问对象时使用的名称。

creator是类构造器,creator="new" 属性指定 java 类实例的生成方式, new 意味着 DWR 应当调用类的默认构造函数来获得实例,其他的还有 spring 方式,通过与 IOC 容器 Spring 进行集成来获得实例等等。 

       默认情况下DWR1.1有8种创造器。它们是:

    • new: 用Java的new关键字创造对象。
    • none: 它不创建对象。 (v1.1+)
    • scripted: 通过BSF使用脚本语言创建对象,例如BeanShell或Groovy。
    • spring: 通过Spring框架访问Bean。
    • jsf: 使用JSF的Bean。 (v1.1+)
    • struts: 使用Struts的FormBean。 (v1.1+)
    • pageflow: 访问Beehive或Weblogic的PageFlow。 (v1.1+)
       还有一个属性为scope默认为page ,其值还有application、session、request、script。
       <creator>下的配置节点:

<param> 标签指定要公开给 javascript 的 java 类名。

<include> 标签指定要公开给 javascript 的方法。不指定的话就公开所有方法

<exclude> 标签指定要防止被访问的方法。

<auth> 标签指定一个J2EE角色作为访问控制检查。


       <convert> 标签由于dwr只支持json的数据格式,因此在dwr中我们要读取javaBean中的属性,就必须将其转换成json的数据格式,这需要配置convert进行转换。

       DWR已经默认定义和初始化了常用的Converter,他们分别如下: 

<converter id="null"/>
<converter id="primitive"/>
<converter id="bignumber"/>
<converter id="string"/>
<converter id="date"/>
<converter id="array"/>
<converter id="map"/>
<converter id="collection"/>
<converter id="bean"/>
<converter id="hibernate"/>
<converter id="dom"/>
<converter id="dom4j"/>
<converter id="jdom"/>
<converter id="xom"/>
<converter id="servlet"/>
       在convert中,还可以设定param进行授权访问控制,例如:

<convert converter="bean" match="com.tgb.DwrTest"/>
  <param name="include" value="property1, property2"/>
</convert>
       其中include表示只允许value中的属性可以访问,exclude表示除了value中的属性,其他属性均可访问。如果不设定param,则所有属性均可访问。

       参考:

dwr配置文件dwr.xml详解

dwr.xml 配置文件详解

dwr.xml的配置


版权声明:本文为博主原创文章,未经博主允许不得转载。

Ehache.xml配置详解

Ehache.xml配置详解

 
Ehache.xml配置文件案例
 1    <ehcache>
 2    
 3     <!-- 
 4         磁盘存储:将缓存中暂时不使用的对象,转移到硬盘,类似于Windows系统的虚拟内存
 5         path:指定在硬盘上存储对象的路径可以使用JavaVM环境变量(user.home,user.dir,java.io.tmpdir)
 6      -->
 7     <diskStore path="java.io.tmpdir" />
 8     
11     <!-- name:Cache的唯一标识 maxElementsInMemory:内存中最大缓存对象数 maxElementsOndisk:磁盘中最大缓存对象数,若是0表无穷大 12  eternal:Element是否永久有效,一但设置了,timeout将不起作用 
13 overflowTodisk:配置此属性,当内存中Element数量达到maxElementsInMemory时,Ehcache将会Element写到磁盘中
14	   timetoIdleSeconds:设置Element在失效前的允许闲置时间。仅当element不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大
15  timetoLiveSeconds:设置Element在失效前允许存活时间。最大时间介于创建时间和失效时间之间。仅当element不是永久有效时使用,默认是0.
16 也就是element存活时间无穷大 17  diskPersistent:是否缓存虚拟机重启期数据 diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒 18  diskSpoolBufferSizeMB:这个参数设置diskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区 19  memoryStoreevictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。默认策略是LRU(最近最少使用)。
20 你可以设置为FIFO(先进先出)或是LFU(较少使用) -->
21     defaultCache maxElementsInMemory="10000" eternal="false" maxElementsOndisk="10000000" diskPersistent="false"   diskExpiryThreadIntervalSeconds="120" memoryStoreevictionPolicy="LRU"timetoIdleSeconds="120" 
           timetoLiveSeconds overflowTodisk="true" 23     
24     25         cache:为指定名称的对象进行缓存的特殊配置
26         name:指定对象的完整名
27      28     cache name="com.zbaccp.entity.Person" maxElementsInMemory eternal="false"
29         timetoIdleSeconds="300" timetoLiveSeconds="600"/> 
30 </>

二、defaultCache : 默认的管理策略

以下属性是必须的:

  1、name: Cache的名称,必须是唯一的(ehcache会把这个cache放到HashMap里)。
  2、maxElementsInMemory:在内存中缓存的element的最大数目。
  3、maxElementsOndisk:在磁盘上缓存的element的最大数目,默认值为0,表示不限制。
  4、eternal:设定缓存的elements是否永远不过期。如果为true,则缓存的数据始终有效,如果为false那么还要根据timetoIdleSeconds, timetoLiveSeconds判断。
  5、overflowTodisk: 如果内存中数据超过内存限制,是否要缓存到磁盘上。

以下属性是可选的:
  1、timetoIdleSeconds: 对象空闲时间,指对象在多长时间没有被访问就会失效。只对eternal为false的有效。默认值0,表示一直可以访 问。
  2、timetoLiveSeconds: 对象存活时间,指对象从创建到失效所需要的时间。只对eternal为false的有效。默认值0,表示一直可以访问。
  3、diskPersistent: 是否在磁盘上持久化。指重启jvm后,数据是否有效。默认为false。
  4、diskExpiryThreadIntervalSeconds: 对象检测线程运行时间间隔。标识对象状态的线程多长时间运行一次。
  5、diskSpoolBufferSizeMB: diskStore使用的磁盘大小,默认值30MB。每个cache使用各自的diskStore。
  6、memoryStoreevictionPolicy: 如果内存中数据超过内存限制,向磁盘缓存时的策略。默认值LRU,可选FIFO、LFU。

三、缓存的3 种清空策略 :
  1、FIFO ,first in first out (先进先出).
  2、LFU , Less Frequently Used (最少使用).意思是一直以来最少被使用的。缓存的元素有一个hit 属性,hit 值最小的将会被清出缓存。
  3、LRU ,Least Recently Used(最近最少使用). (ehcache 默认值).缓存的元素有一个时间戳,当缓存容量满了,而又需要腾出地方来缓存新的元素的时候,那么现有缓存元素中时间戳离当前时间最远的元素将被清出缓存。

ehcache.xml配置详解

ehcache.xml配置详解

配置ehcache.xml文件

1. 在Hibernate配置文件中设置:

<!--HibernateSessionFactory-->
<beanid="sessionFactoryclassorg.springframework.orm.hibernate3.LocalSessionfactorybean> propertynamedataSourceref/> mappingResourceslistvalue>com/ououmodelVideos.hbm.xml</>
propertyhibernatePropertiespropspropkeyhibernate.dialectorg.hibernate.dialect.MysqLDialectprophibernate.current_session_context_classthreadhibernate.cglib.use_reflection_optimizerfalsehibernate.query.substitutionstrue'Y,Naddehcachehibernate.cache.provider_classorg.hibernate.cache.EhCacheProviderhibernate.cache.use_query_cache><!--是否使用查询缓存
<!-- hibernate.cache.provider_configuration_file_resource_path>/ehcache.xmlhibernate.show_sql--> <!--<hibernate.transaction.auto_close_session>-->
connection.provider_classorg.hibernate.connection.C3P0ConnectionProviderCreate/ updatethedatabasetablesautomaticallywhentheJVMstartsup
hibernate.hbm2ddl.autoupdateTurnbatchingoffforbettererrormessagesunderPostgresqlhibernate.jdbc.batch_size25hibernate.connection.pool_size10bean>


如果不设置“查询缓存”,那么hibernate只会缓存使用load()方法获得的单个持久化对象,如果想缓存使用findall()、 list()、Iterator()、createCriteria()、createquery()等方法获得的数据结果集的话,就需要设置hibernate.cache.use_query_cache true 才行

2.首先设置EhCache,建立配置文件ehcache.xml,默认的位置在class-path,可以放到你的src目录下:

ehcache

<!-- Setsthepathtothedirectorywherecache.datafilesarecreated.

IfthepathisaJavaSystemPropertyitisreplacedby
itsvalueintherunningVM.
Thefollowingpropertiesaretranslated:
user.home
-Usershomedirectory
user.dirscurrentworkingdirectory java.io.tmpdirDefaulttempfilepathdiskStorepath/>--> /data/ehcacheDefaultCacheconfiguration.Thesewillappliedtocachesprogrammaticallycreatedthrough
theCacheManager.

Thefollowingattributesarerequired:

maxElementsInMemory
- Setsthemaximumnumberofobjectsthatwillbecreatedinmemory
eternal
Setswhetherelementsareeternal.Ifeternal,timeoutsare
ignoredandtheelementisneverexpired.
overflowTodisk
Setswhetherelementscanoverflowtodiskwhentheinmemorycache
hasreachedthemaxInMemorylimit.

Thefollowingattributesareoptional:
timetoIdleSeconds
Setsthetimetoidlefor
anelementbeforeitexpires.
i.e.Themaximumamountoftimebetweenaccessesbeforean
elementexpiresIsonlyused
if
theelementisnoteternal.
Optionalattribute.Avalueof
0
meansthatanElementcanidle
infinity.Thedefaultvalueis.
timetoLiveSeconds
Setsthetimetoliveanelementbeforeitexpires.
i.e.Themaximumtimebetweencreationtimeandwhenanelement
expires.Isonlyused
meansthatandElementcanlive
infinity.
The
.
diskPersistent
WhetherthediskstorepersistsbetweenrestartsoftheVirtual
Machine.
The
false
.
diskExpiryThreadIntervalSeconds
Thenumberofsecondsbetweenrunsofthediskexpirythread.
The
120
seconds.
< defaultCache
maxElementsInMemory
10000"

eternal
false
overflowTodisk
true
timetoIdleSeconds
120
timetoLiveSeconds

diskPersistent

diskExpiryThreadIntervalSeconds
cachenameorg.hibernate.cache.UpdateTimestampsCachemaxElementsInMemory5000"
eternal
overflowTodiskorg.hibernate.cache.StandardQueryCache5eternaluserCache100000timetoIdleSeconds=

"
600 timetoLiveSecondsdiskPersistentcom.ouou.webapp.util.OuouMethodInteceptertimetoLiveSecondsbbcode
overflowTodisk
com.ouou.model.Videoscom.ouou.model.Tags>


以com.ouou.model.Videos为例子 在Videos.hbm.xml中配置: <class table="TEST" lazy="false"> <cache usage="read-write" region="ehcache.xml中的name的属性值"/>注意:这一句需要紧跟在class标签下面,其他位置无效。 hbm文件查找cache方法名的策略:如果不指定hbm文件中的region="ehcache.xml中的name的属性值",则使用name名为com.ouou.model.Videos的cache, 如果不存在与类名匹配的cache名称,则用defaultCache。 如果Videos包含set集合,则需要另行指定其cache 例如Videos包含Tags集合,则需要 添加如下配置到ehcache.xml中 <cache name="com.ouou.model.Tags" maxElementsInMemory="10000" eternal="false" timetoIdleSeconds="120" timetoLiveSeconds="120" overflowTodisk="false" /> 另,针对查询缓存的配置如下: <cache name="org.hibernate.cache.UpdateTimestampsCache" maxElementsInMemory="5000" eternal="true" overflowTodisk="true"/> <cache name="org.hibernate.cache.StandardQueryCache" maxElementsInMemory="10000" eternal="false" timetoLiveSeconds="120" overflowTodisk="true"/> 3、 选择缓存策略依据: <cache usage="transactional|read-write|nonstrict-read-write|read-only" (1)/> ehcache不支持transactional,其他三种可以支持。 read-only:无需修改, 那么就可以对其进行只读 缓存,注意,在此策略下,如果直接修改数据库,即使能够看到前台显示效果, 但是将对象修改至cache中会报error,cache不会发生作用。另:删除记录会报错,因为不能在read-only模式的对象从cache中删除。 read-write:需要更新数据,那么使用读/写缓存 比较合适,前提:数据库不可以为serializable transaction isolation level (序列化事务隔离级别) nonstrict-read-write:只偶尔需要更新数据(也就是说,两个事务同时更新同一记录的情况很不常见),也不需要十分严格的事务隔离, 那么比较适合使用非严格读/写缓存策略。 4、 调试时候使用log4j的log4j.logger.org.hibernate.cache=debug,更方便看到ehcache的操作过程,主要用于调试过程,实际应用发布时候,请注释掉,以免影响性能。 5、 使用ehcache,打印sql语句是正常的,因为query cache设置为true将会创建两个缓存区域:一个用于保存查询结果集 ( org.hibernate.cache.StandardQueryCache);另一个则用于保存最近查询的一系列表的时间戳(org.hibernate.cache.UpdateTimestampsCache)。 请注意:在查询缓存中,它并不缓存结果集中所包含的实体的确切状态;它只缓存这些实体的标识符属性的值、以及各值类型的结果。 需要将打印sql语句与最近的cache内容相比较,将不同之处修改到cache中,所以查询缓存通常会和二级缓存一起使用。 英文参考资料:http://ehcache.sourceforge.net/documentation/#mozTocId258426 博文参考:http://blog.csdn.net/yun15291li/archive/2006/02/21/604095.aspx http://zyl.javaeye.com/blog/68369 其他:http://dev.yesky.com/157/2557157.shtml

今天关于web.xml配置详解web.xml配置详解在哪儿的分享就到这里,希望大家有所收获,若想了解更多关于bulid.xml配置详解、dwr.xml配置详解、Ehache.xml配置详解、ehcache.xml配置详解等相关知识,可以在本站进行查询。

本文标签: