如果您对web.xml配置详解感兴趣,那么本文将是一篇不错的选择,我们将为您详在本文中,您将会了解到关于web.xml配置详解的详细内容,我们还将为您解答web.xml配置详解在哪儿的相关问题,并且为
如果您对web.xml配置详解感兴趣,那么本文将是一篇不错的选择,我们将为您详在本文中,您将会了解到关于web.xml配置详解的详细内容,我们还将为您解答web.xml配置详解在哪儿的相关问题,并且为您提供关于bulid.xml配置详解、dwr.xml配置详解、Ehache.xml配置详解、ehcache.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配置详解
- <!--由于工作上用到才去学习O(∩_∩)O哈哈~-->
- Ant的优点
- Ant是Apache软件基金会JAKARTA目录中的一个子项目,它有以下的优点。
- 跨平台性。Ant是存Java语言编写的,所示具有很好的跨平台性。
- 操作简单。Ant是由一个内置任务和可选任务组成的。Ant运行时需要一个XML文件(构建文件)。
- Ant通过调用target树,就可以执行各种task。每个task实现了特定接口对象。由于Ant构建文件
- 时XML格式的文件,所以和容易维护和书写,而且结构很清晰。
- Ant可以集成到开发环境中。由于Ant的跨平台性和操作简单的特点,它很容易集成到一些开发环境中去。
- Ant开发
- Ant的构建文件
- 当开始一个新的项目时,首先应该编写Ant构建文件。构建文件定义了构建过程,并被团队开发
- 中每个人使用。Ant构建文件默认命名为build.xml,也可以取其他的名字。只不过在运行的时候
- 把这个命名当作参数传给Ant。构建文件可以放在任何的位置。一般做法是放在项目顶层目录中
- ,这样可以保持项目的简洁和清晰。下面是一个典型的项目层次结构。
- (1)src存放文件。
- (2)class存放编译后的文件。
- (3)lib存放第三方jar包。
- (4)dist存放打包,发布以后的代码。
- Ant构建文件是XML文件。每个构建文件定义一个唯一的项目(Project元素)。每个项目下可以定
- 义很多目标(target元素),这些目标之间可以有依赖关系。当执行这类目标时,需要执行他们所
- 依赖的目标。
- 每个目标中可以定义多个任务,目标中还定义了所要执行的任务序列。Ant在构建目标时必须调
- 用所定义的任务。任务定义了Ant实际执行的命令。Ant中的任务可以为3类。
- (1)核心任务。核心任务是Ant自带的任务。
- (2)可选任务。可选任务实来自第三方的任务,因此需要一个附加的JAR文件。
- (3)用户自定义的任务。用户自定义的任务实用户自己开发的任务。
- 1.<project>标签
- 每个构建文件对应一个项目。<project>标签时构建文件的根标签。它可以有多个内在属性,
- 就如代码中所示,其各个属性的含义分别如下。
- (1)default表示默认的运行目标,这个属性是必须的。
- (2)basedir表示项目的基准目录。
- (3)name表示项目名。
- (4)description表示项目的描述。
- 每个构建文件都对应于一个项目,但是大型项目经常包含大量的子项目,每一个子项目都可以有
- 自己的构建文件。
- 2.<target>标签
- 一个项目标签下可以有一个或多个target标签。一个target标签可以依赖其他的target标签。例
- 如,有一个target用于编译程序,另一个target用于声称可执行文件。在生成可执行文件之前必
- 须先编译该文件,因策可执行文件的target依赖于编译程序的target。Target的所有属性如下。
- (1).name表示标明,这个属性是必须的。
- (2).depends表示依赖的目标。
- (3)if表示仅当属性设置时才执行。
- (4)unless表示当属性没有设置时才执行。
- (5)description表示项目的描述。
- Ant的depends属性指定了target的执行顺序。Ant会依照depends属性中target出现顺序依次执行
- 每个target。在执行之前,首先需要执行它所依赖的target。程序中的名为run的target的
- depends属性compile,而名为compile的target的depends属性是prepare,所以这几个target执
- 行的顺序是prepare->compile->run。
- 一个target只能被执行一次,即使有多个target依赖于它。如果没有if或unless属性,target总
- 会被执行。
- 3.<mkdir>标签
- 该标签用于创建一个目录,它有一个属性dir用来指定所创建的目录名,其代码如下:
- <mkdirdirmkdirdir=”${class.root}”/>
- 通过以上代码就创建了一个目录,这个目录已经被前面的property标签所指定。
- 4<jar>标签
- 该标签用来生成一个JAR文件,其属性如下。
- (1)destfile表示JAR文件名。
- (2)basedir表示被归档的文件名。
- (3)includes表示别归档的文件模式。
- (4)exchudes表示被排除的文件模式。
- 5.<javac标签>
- 该标签用于编译一个或一组java文件,其属性如下。
- (1).srcdir表示源程序的目录。
- (2).destdir表示class文件的输出目录。
- (3).include表示被编译的文件的模式。
- (4).excludes表示被排除的文件的模式。
- (5).classpath表示所使用的类路径。
- (6).debug表示包含的调试信息。
- (7).optimize表示是否使用优化。
- (8).verbose表示提供详细的输出信息。
- (9).fileonerror表示当碰到错误就自动停止。
- 6.<java>标签
- 该标签用来执行编译生成的.class文件,其属性如下。
- (1).classname表示将执行的类名。
- (2).jar表示包含该类的JAR文件名。
- (3).classpath所表示用到的类路径。
- (4).fork表示在一个新的虚拟机中运行该类。
- (5).failonerror表示当出现错误时自动停止。
- (6).output表示输出文件。
- (7).append表示追加或者覆盖默认文件。
- 7.<delete>标签
- 该标签用于删除一个文件或一组文件,去属性如下。
- (1)/file表示要删除的文件。
- (2).dir表示要删除的目录。
- (3).includeEmptyDirs表示指定是否要删除空目录,默认值是删除。
- (4).failonerror表示指定当碰到错误是否停止,默认值是自动停止。
- (5).verbose表示指定是否列出所删除的文件,默认值为不列出。
- 8.<copy>标签
- 该标签用于文件或文件集的拷贝,其属性如下。
- (1).file表示源文件。
- (2).tofile表示目标文件。
- (3).todir表示目标目录。
- (4).overwrite表示指定是否覆盖目标文件,默认值是不覆盖。
- (5).includeEmptyDirs表示制定是否拷贝空目录,默认值为拷贝。
- (6).failonerror表示指定如目标没有发现是否自动停止,默认值是停止。
- (7).verbose表示制定是否显示详细信息,默认值不显示。
- Ant的数据类型
- 在构建文件中为了标识文件或文件组,经常需要使用数据类型。数据类型包含在
- org.apache.tool.ant.types包中。下面镜简单介绍构建文件中一些常用的数据类型。
- 1.argument类型
- 由Ant构建文件调用的程序,可以通过<arg>元素向其传递命令行参数,如apply,exec和java任
- 务均可接受嵌套<arg>元素,可以为各自的过程调用指定参数。以下是<arg>的所有属性。
- (1).values是一个命令参数。如果参数种有空格,但又想将它作为单独一个值,则使用此属性
- 。
- (2).file表示一个参数的文件名。在构建文件中,此文件名相对于当前的工作目录。
- (3).line表示用空格分隔的多个参数列表。
- (4).path表示路径。
- 2.ervironment类型
- 由Ant构建文件调用的外部命令或程序,<env>元素制定了哪些环境变量要传递给正在执行的系
- 统命令,<env>元素可以接受以下属性。
- (1).file表示环境变量值得文件名。此文件名要被转换位一个绝对路径。
- (2).path表示环境变量的路径。Ant会将它转换为一个本地约定。
- (3).value表示环境变量的一个直接变量。
- (4).key表示环境变量名。
- 注意filepath或value只能取一个。
- 3.filelist类型
- Filelist是一个支持命名的文件列表的数据类型,包含在一个filelist类型中的文件不一定是
- 存在的文件。以下是其所有的属性。
- (1).dir是用于计算绝对文件名的目录。
- (2).files是用逗号分隔的文件名列表。
- (3).refid是对某处定义的一个<filelist>的引用。
- 注意dir和files都是必要的,除非指定了refid(这种情况下,dir和files都不允许使用)。
- 4.fileset类型
- Fileset数据类型定义了一组文件,并通常表示为<fileset>元素。不过,许多ant任务构建成了
- 隐式的fileset,这说明他们支持所有的fileset属性和嵌套元素。以下为fileset的属性列表。
- (1).dir表示fileset的基目录。
- (2).casesensitive的值如果为false,那么匹配文件名时,fileset不是区分大小写的,其默认
- 值为true.
- (3).defaultexcludes用来确定是否使用默认的排除模式,默认为true。
- (4).excludes是用逗号分隔的需要派出的文件模式列表。
- (5).excludesfile表示每行包含一个排除模式的文件的文件名。
- (6).includes是用逗号分隔的,需要包含的文件模式列表。
- (7).includesfile表示每行包括一个包含模式的文件名。
- 5.patternset类型
- Fileset是对文件的分组,而patternset是对模式的分组,他们是紧密相关的概念。
- <patternset>支持4个属性:includesexcludexincludexfile和excludesfile,与fileset相
- 同。Patternset还允许以下嵌套元素:include,exclude,includefile和excludesfile.
- 6.filterset类型
- Filterset定义了一组过滤器,这些过滤器将在文件移动或复制时完成文件的文本替换。
- 主要属性如下:
- (1).begintoken表示嵌套过滤器所搜索的记号,这是标识其开始的字符串。
- (2).endtoken表示嵌套过滤器所搜索的记号这是标识其结束的字符串。
- (3).id是过滤器的唯一标志符。
- (4).refid是对构建文件中某处定义一个过滤器的引用。
- 7.Path类型
- Path元素用来表示一个类路径,不过它还可以用于表示其他的路径。在用作揖个属性时,路经中
- 的各项用分号或冒号隔开。在构建的时候,此分隔符将代替当前平台中所有的路径分隔符,其拥
- 有的属性如下。
- (1).location表示一个文件或目录。Ant在内部将此扩展为一个绝对路径。
- (2).refid是对当前构建文件中某处定义的一个path的引用。
- (3).path表示一个文件或路径名列表。
- 8.mapper类型
- Mapper类型定义了一组输入文件和一组输出文件间的关系,其属性如下。
- (1).classname表示实现mapper类的类名。当内置mapper不满足要求时,用于创建定制mapper.
- (2).classpath表示查找一个定制mapper时所用的类型路径。
- (3).classpathref是对某处定义的一个类路径的引用。
- (4).from属性的含义取决于所用的mapper.
- (5).to属性的含义取决于所用的mapper.
- (6).type属性的取值为identity,flattenglobmergeregexp其中之一,它定义了要是用的
- 内置mapper的类型。
- Ant的运行
- 安装好Ant并且配置好路径之后,在命令行中切换到构建文件的目录,输入Ant命令就可以运行
- Ant.若没有指定任何参数,Ant会在当前目录下查询build.xml文件。如果找到了就用该文件作为
- 构建文件。如果使用了–find选项,Ant就会在上级目录中找构建文件,直至到达文件系统得
- 跟目录。如果构建文件的名字不是build.xml,则Ant运行的时候就可以使用–buildfilefile
- ,这里file指定了要使用的构建文件的名称,示例如下:
- Ant
- 如下说明了表示当前目录的构建文件为build.xml运行ant执行默认的目标。
- ===============================build.xml配置=========================
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!--官方网站:http://ant.apache.org/-->
- <projectnameprojectname="MyAntProject"basedir="."default="package">
- <!--用ant连接数据库创建表-->
- <!--
- 要是报错请,右击build.xml==>>Runas=>>Antbuild找到Classpath==>>AddExternalJARs
- 添加报错所需要的jar即可...
- 例如:BUILDFailedClassNotFound:(这句是在你没写检测才会输出.)
- JDBCdrivercom.MysqL.jdbc.DriverCouldnotbeloaded
- -->
- <propertynamepropertyname="driver"value="com.MysqL.jdbc.Driver"/>
- <propertynamepropertyname="url"value="jdbc:MysqL://localhost:3306/test?useUnicode=true"/>
- <propertynamepropertyname="user"value="root"/>
- <propertynamepropertyname="password"value="root"/>
- <!--检查Classpath是否有安装mysql-connector-java-5.1.7-bin.jar(一般程序员知道classpath加载什么jar才会写上提醒)-->
- <availableclassnameavailableclassname="com.MysqL.jdbc.Driver"property="MysqL.present"/>
- <!--<availablefile="mysql-connector-java-5.1.7-bin.jar"property="MysqLjar.present"/>-->
- <failunlessfailunless="MysqL.present"message="mysql-connector-java-5.1.7-bin.jar没安装,请你在run的时候添加.."/>
- <!-------------------target:创建表------------------->
- <targetnaMetargetname="createTable">
- <!--person表-->
- <sqldriversqldriver="${driver}"password="${password}"url="${url}"userid="${user}">
- createtableant_person(
- idintprimarykey,
- namevarchar(20)notnull,
- ageint
- );
- <!--
- insertintoant_personvalues(1,'jilong',23);
- 为了临时表有数据就放在这里.要是比较专业的一般在初始化数据插入数据
- -->
- createtableant_tempselect*fromant_person;<!--创建临时表-->
- </sql>
- </target>
- <!-------------------target:删除表----------------->
- <targetnaMetargetname="dropTable">
- <sqldriversqldriver="${driver}"password="${password}"url="${url}"userid="${user}">
- droptableant_person;
- droptableant_temp;
- </sql>
- </target>
- <!-------------------target:初始化数据.------------------->
- <targetnaMetargetname="InitData">
- <sqldriversqldriver="${driver}"password="${password}"url="${url}"userid="${user}">
- insertintoant_personvalues(2,23);
- </sql>
- </target>
- <!-----------------target:同时执行创建表和插入数据.---------------->
- <targetnaMetargetname="create_init"depends="createTable,InitData"/>
- <!--=======================================================================================-->
- <!--定义文件目录的name和value-->
- <propertynamepropertyname="compile"value="compile"/>
- <propertynamepropertyname="dist"value="dist"/>
- <propertynamepropertyname="src"value="src"/>
- <targetnaMetargetname="init"/>
- <!--定义两个文件的根目录-->
- <targetnaMetargetname="preprocess"depends="init">
- <mkdirdirmkdirdir="${compile}"/>
- <mkdirdirmkdirdir="${dist}"/>
- </target>
- <targetnaMetargetname="compile"depends="init,preprocess"/>
- <targetnaMetargetname="package"depends="compile"/>
- <!--编译java类成.class文件-->
- <targetnaMetargetname="myCompile"depends="preprocess">
- <javacsrcdirjavacsrcdir="src"destdir="${compile}"fork="true"memorymaximumsize="4m"/>
- </target>
- <!--创建一个.jar夹-->
- <targetnaMetargetname="dist"depends="myCompile">
- <!--设置时间格式的有${TSTAMP}/${TODAY}-->
- <tstamp/>
- <jardestfilejardestfile="${dist}/package1-${TODAY}.jar"basedir="${compile}">
- <manifest>
- <!--user.name是操作系统的用户名-->
- <attributenameattributename="Built-By"value="${user.name}"/>
- <attributenameattributename="Main-Class"value="com.test.Test1"/>
- </manifest>
- </jar>
- </target>
- <!--删除jar-->
- <targetnaMetargetname="deleteFile">
- <deletefiledeletefile="${dist}/package1-${TSTAMP}.jar"/>
- </target>
- <!--拷貝文件,一般在打包项目的用来备份项目,或者把打包的jar拷贝到服务器部署目录下,
- 那就可以不用手工拷贝夹部署demo..-->
- <targetnaMetargetname="copyFile">
- <copyfilecopyfile="src/com/test/Test1.java"tofile="D:/Testcopy.java"/>
- <copyfilecopyfile="src/com/test/Test1.java"todir="D:\"/>
- </target>
- <!--剪切/移動文件-->
- <targetnaMetargetname="moveFile">
- <movefilemovefile="src/com/test/Test1.java"todir="D:"/>
- </target>
- <!--打包成.zip夹包-->
- <targetnaMetargetname="compress"depends="compile">
- <zipdestfilezipdestfile="${dist}/package.zip"basedir="${compile}"/>
- </target>
- <!--打包成.ear夹包-->
- <targetnaMetargetname="earFile"depends="compile">
- <eardestfileeardestfile="${dist}/ant_ear.ear"basedir="${compile}"/>
- </target>
- <!--打包成.war夹包-->
- <targetnaMetargetname="warFile"depends="compile">
- <wardestfilewardestfile="${dist}/ant_war.war"basedir="${compile}"/>
- </target>
- <!--不打包/解压-->
- <targetnaMetargetname="umcompress"depends="compress">
- <unzipdestunzipdest="${dist}"src="${dist}/package.zip"/>
- </target>
- <!--找文字替换summary可以输出提示替换了几个-->
- <targetnaMetargetname="replaceFile">
- <replacefilereplacefile="input.txt"token="old"value="new"summary="on"/>
- </target>
- <!--拷貝所有.java的文件-->
- <targetnaMetargetname="copy">
- <copytodircopytodir="${dist}">
- <filesetdirfilesetdir="src">
- <includenameincludename="**/*.java"/>
- </fileset>
- </copy>
- </target>
- <!--自定义一个类来處理Task-->
- <taskdefnametaskdefname="MyTaskExample"classname="com.ant.tool.extend.AntTasks"classpath="bin"/>
- <!--引用自定标签的namemyTaskExample-->
- <targetnaMetargetname="MyAntTasks">
- <myTaskExamplesrcFilemyTaskExamplesrcFile="input.txt"destFile="output.txt"/>
- </target>
- <!--用echo显示各种的属性-->
- <targetnaMetargetname="showProperty">
- <echomessageechomessage="当前系统的用户名:${user.name}"/>
- <echomessageechomessage="当前系统的版本:${os.version}"/>
- <echomessageechomessage="当前系统的安装路径:${user.home}"/>
- <echomessageechomessage="ant的xml文件:${ant.file}"/>
- <echomessageechomessage="当前系统的语言:${user.language}"/>
- <echomessageechomessage="ant发现Java虚拟机的版本:${ant.java.version}"/>
- <echomessageechomessage="项目的绝对路径:${basedir}"/>
- <echomessageechomessage="lib类库:${ant.library.dir}"/>
- <echomessageechomessage="ApacheAntversion:${ant.version}"/>
- <echomessageechomessage="jre目录:${java.home}"/>
- <echomessageechomessage="安装系统:${os.name}"/>
- <echomessageechomessage="${user.country}"/>
- </target>
- </project>
运行的结果:
Buildfile: D:\Eclipse-Source\Ant\build.xml
showProperty:
[echo]当前系统的用户名:Administrator
[echo]当前系统的版本:6.1
[echo]当前系统的安装路径:C:\Users\Administrator
[echo] ant的xml文件: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很实用,所以想多了解一下。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+)
<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配置文件案例
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。
1、FIFO ,first in first out (先进先出).
2、LFU , Less Frequently Used (最少使用).意思是一直以来最少被使用的。缓存的元素有一个hit 属性,hit 值最小的将会被清出缓存。
3、LRU ,Least Recently Used(最近最少使用). (ehcache 默认值).缓存的元素有一个时间戳,当缓存容量满了,而又需要腾出地方来缓存新的元素的时候,那么现有缓存元素中时间戳离当前时间最远的元素将被清出缓存。
ehcache.xml配置详解
1. 在Hibernate配置文件中设置:
<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目录下:
<!-- Setsthepathtothedirectorywherecache.datafilesarecreated.
IfthepathisaJavaSystemPropertyitisreplacedby
itsvalueintherunningVM.
Thefollowingpropertiesaretranslated:
user.home-Usershomedirectory user.dirscurrentworkingdirectory java.io.tmpdirDefaulttempfilepathdiskStorepath/>--> /data/ehcacheDefaultCacheconfiguration.Thesewillappliedtocachesprogrammaticallycreatedthrough
theCacheManager.
Thefollowingattributesarerequired:
maxElementsInMemory- Setsthemaximumnumberofobjectsthatwillbecreatedinmemory
eternalSetswhetherelementsareeternal.Ifeternal,timeoutsare
ignoredandtheelementisneverexpired.
overflowTodiskSetswhetherelementscanoverflowtodiskwhentheinmemorycache
hasreachedthemaxInMemorylimit.
Thefollowingattributesareoptional:
timetoIdleSecondsSetsthetimetoidlefor anelementbeforeitexpires.
i.e.Themaximumamountoftimebetweenaccessesbeforean
elementexpiresIsonlyusedif theelementisnoteternal.
Optionalattribute.Avalueof0 meansthatanElementcanidle
infinity.Thedefaultvalueis.
timetoLiveSecondsSetsthetimetoliveanelementbeforeitexpires.
i.e.Themaximumtimebetweencreationtimeandwhenanelement
expires.IsonlyusedmeansthatandElementcanlive
infinity.
The.
diskPersistentWhetherthediskstorepersistsbetweenrestartsoftheVirtual
Machine.
Thefalse .
diskExpiryThreadIntervalSecondsThenumberofsecondsbetweenrunsofthediskexpirythread.
The120 seconds.
< defaultCache
maxElementsInMemory10000"
eternal false
overflowTodisk true
timetoIdleSeconds 120
timetoLiveSeconds
diskPersistent
diskExpiryThreadIntervalSeconds cachenameorg.hibernate.cache.UpdateTimestampsCachemaxElementsInMemory5000"
eternaloverflowTodiskorg.hibernate.cache.StandardQueryCache5eternaluserCache100000timetoIdleSeconds=
" 600 timetoLiveSecondsdiskPersistentcom.ouou.webapp.util.OuouMethodInteceptertimetoLiveSecondsbbcode
overflowTodiskcom.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配置详解等相关知识,可以在本站进行查询。
本文标签: