﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-黎素智-文章分类-框架技术</title><link>http://www.blogjava.net/lisuzhi008/category/19775.html</link><description>博客摘录</description><language>zh-cn</language><lastBuildDate>Wed, 11 Apr 2007 07:21:08 GMT</lastBuildDate><pubDate>Wed, 11 Apr 2007 07:21:08 GMT</pubDate><ttl>60</ttl><item><title>Apache project 介绍 </title><link>http://www.blogjava.net/lisuzhi008/articles/108523.html</link><dc:creator>黎素智</dc:creator><author>黎素智</author><pubDate>Wed, 04 Apr 2007 12:11:00 GMT</pubDate><guid>http://www.blogjava.net/lisuzhi008/articles/108523.html</guid><wfw:comment>http://www.blogjava.net/lisuzhi008/comments/108523.html</wfw:comment><comments>http://www.blogjava.net/lisuzhi008/articles/108523.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/lisuzhi008/comments/commentRss/108523.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/lisuzhi008/services/trackbacks/108523.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: &nbsp;                                     Apache Ant Project                                                     Ant                                     众所周知，Ant（蚂蚁）是一套基于java的程序...&nbsp;&nbsp;<a href='http://www.blogjava.net/lisuzhi008/articles/108523.html'>阅读全文</a><img src ="http://www.blogjava.net/lisuzhi008/aggbug/108523.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/lisuzhi008/" target="_blank">黎素智</a> 2007-04-04 20:11 <a href="http://www.blogjava.net/lisuzhi008/articles/108523.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Log4j的介绍</title><link>http://www.blogjava.net/lisuzhi008/articles/98108.html</link><dc:creator>黎素智</dc:creator><author>黎素智</author><pubDate>Mon, 05 Feb 2007 12:22:00 GMT</pubDate><guid>http://www.blogjava.net/lisuzhi008/articles/98108.html</guid><wfw:comment>http://www.blogjava.net/lisuzhi008/comments/98108.html</wfw:comment><comments>http://www.blogjava.net/lisuzhi008/articles/98108.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/lisuzhi008/comments/commentRss/98108.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/lisuzhi008/services/trackbacks/98108.html</trackback:ping><description><![CDATA[Error convertoring HTML to XHTML: System.ArgumentException: Cannot have ']]&gt;' inside an XML CDATA block.
   at System.Xml.XmlTextWriter.WriteCData(String text)
   at System.Xml.XmlWriter.WriteNode(XmlReader reader, Boolean defattr)
   at FreeTextBoxControls.Support.Formatter.HtmlToXhtml(String input)<img src ="http://www.blogjava.net/lisuzhi008/aggbug/98108.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/lisuzhi008/" target="_blank">黎素智</a> 2007-02-05 20:22 <a href="http://www.blogjava.net/lisuzhi008/articles/98108.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>使用Eclipse远程调试发布在Tomcat上的Web应用</title><link>http://www.blogjava.net/lisuzhi008/articles/98105.html</link><dc:creator>黎素智</dc:creator><author>黎素智</author><pubDate>Mon, 05 Feb 2007 12:15:00 GMT</pubDate><guid>http://www.blogjava.net/lisuzhi008/articles/98105.html</guid><wfw:comment>http://www.blogjava.net/lisuzhi008/comments/98105.html</wfw:comment><comments>http://www.blogjava.net/lisuzhi008/articles/98105.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/lisuzhi008/comments/commentRss/98105.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/lisuzhi008/services/trackbacks/98105.html</trackback:ping><description><![CDATA[
		<div class="postbody">
				<font color="#808080" size="2">转自：</font>
				<a href="/justfly/archive/2007/02/05/98090.html">
						<font color="#808080" size="2">http://www.blogjava.net/justfly/archive/2007/02/05/98090.html</font>
				</a>
				<a title="Remote Debugging with Eclipse" href="http://eclipsezone.com/eclipse/forums/t53459.html" target="_blank">
						<font color="#1d58d1">
								<br />Remote Debugging with Eclipse</font>
				</a>说明了远程调试的原理，说明了让java程序支持被远程调用所需要的java参数如下<br />-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=1044<br />以及如何配置远程调试weblogic、jboss和tomcat，但是里面对如何让tomcat支持远程调用并没有仔细说。再搜索，在tomcat的FAQ就找到了：<br /><a title="How do I configure Tomcat to support remote debugging?" href="http://tomcat.apache.org/faq/development.html#rd" target="_blank"><font color="#1d58d1">How do I configure Tomcat to support remote debugging?</font></a><br />如上面所示，其中的关键在于如何正确的启动tomcat。对于非windows平台下的操作来说，需要把%TOMCAT_HOME%/bin/startup.sh中的最后一行exec "$PRGDIR"/"$EXECUTABLE" start "$@" 中的start改成jpda start。如果的8000端口有其他用处的话，那么还需要修改catalina.sh文件，看其中的说明，添加一行JPDA_ADDRESS=”1044”或者其他你指定的端口。这样就可以通过startup.sh或者catalina.sh jpda start来其中支持远程调试的tomcat了。<br />在windows平台上是一样的步骤，只不过.sh文件改成了.bat文件了。然后需要注意以下这些地方，<br />1、 catalina.bat文件默认的JPDA_TRANSPORT是dt_shmem，但是Eclipse只支持dt_socket,所以需要在catalina.bat中添加一行<span style="COLOR: #339966">set JPDA_TRANSPORT=”dt_socket”<br /></span>2、 catalina.bat文件默认的端口是jdbconn，我也不知道这个端口是多少，因此添加一个<span style="COLOR: #339966">set JPDA_ADDRESS="1044"</span></div>
<img src ="http://www.blogjava.net/lisuzhi008/aggbug/98105.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/lisuzhi008/" target="_blank">黎素智</a> 2007-02-05 20:15 <a href="http://www.blogjava.net/lisuzhi008/articles/98105.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Spring2.0与Hibernate3整合</title><link>http://www.blogjava.net/lisuzhi008/articles/98094.html</link><dc:creator>黎素智</dc:creator><author>黎素智</author><pubDate>Mon, 05 Feb 2007 11:26:00 GMT</pubDate><guid>http://www.blogjava.net/lisuzhi008/articles/98094.html</guid><wfw:comment>http://www.blogjava.net/lisuzhi008/comments/98094.html</wfw:comment><comments>http://www.blogjava.net/lisuzhi008/articles/98094.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/lisuzhi008/comments/commentRss/98094.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/lisuzhi008/services/trackbacks/98094.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 转自：														http://www.blogjava.net/chaocai/archive/2007/02/05/98070.html												Sping2										及						Hibernate3						都是如今流行的请量级框架，如何将两者进行整合呢，目前很多资料讨论的都是老版本的整合方式，下面给出这两种框架的新...&nbsp;&nbsp;<a href='http://www.blogjava.net/lisuzhi008/articles/98094.html'>阅读全文</a><img src ="http://www.blogjava.net/lisuzhi008/aggbug/98094.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/lisuzhi008/" target="_blank">黎素智</a> 2007-02-05 19:26 <a href="http://www.blogjava.net/lisuzhi008/articles/98094.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Ant学习 </title><link>http://www.blogjava.net/lisuzhi008/articles/98017.html</link><dc:creator>黎素智</dc:creator><author>黎素智</author><pubDate>Mon, 05 Feb 2007 06:58:00 GMT</pubDate><guid>http://www.blogjava.net/lisuzhi008/articles/98017.html</guid><wfw:comment>http://www.blogjava.net/lisuzhi008/comments/98017.html</wfw:comment><comments>http://www.blogjava.net/lisuzhi008/articles/98017.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/lisuzhi008/comments/commentRss/98017.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/lisuzhi008/services/trackbacks/98017.html</trackback:ping><description><![CDATA[
		<p>
				<b>
						<span style="FONT-SIZE: 18pt">
								<font color="#808080" size="2">转自：</font>
								<a href="http://lincoln.javaeye.com/blog/33187">
										<font color="#808080" size="2">http://lincoln.javaeye.com/blog/33187</font>
								</a>
								<br />Ant简介</span>
				</b>
				<br />Ant的概念 <br />可能有些读者并不连接什么是Ant以及入可使用它，但只要使用通过Linux系统得读者，应该知道make这个命令。当编译Linux内核及一些软件的源程序时，经常要用这个命令。Make命令其实就是一个项目管理工具，而Ant所实现功能与此类似。像make，gnumake和nmake这些编译工具都有一定的缺陷，但是Ant却克服了这些工具的缺陷。最初Ant开发者在开发跨平台的应用时，用样也是基于这些缺陷对Ant做了更好的设计。</p>
		<p>Ant 与 makefile <br />Makefile有一些不足之处，比如很多人都会碰到的烦人的Tab问题。最初的Ant开发者多次强调”只是我在Tab前面加了一个空格，所以我的命令就不能执行”。有一些工具在一定程度上解决了这个问题，但还是有很多其他的问题。Ant则与一般基于命令的工具有所不同，它是Java类的扩展。Ant运行需要的XML格式的文件不是Shell命令文件。它是由一个Project组成的，而一个Project又可分成可多target，target再细分又分成很多task，每一个task都是通过一个实现特定接口的java类来完成的。</p>
		<p>Ant的优点</p>
		<p>Ant是Apache软件基金会JAKARTA目录中的一个子项目，它有以下的优点。 <br />跨平台性。Ant是存Java语言编写的，所示具有很好的跨平台性。 <br />操作简单。Ant是由一个内置任务和可选任务组成的。Ant运行时需要一个XML文件(构建文件)。Ant通过调用target树，就可以执行各种task。每个task实现了特定接口对象。由于Ant构建文件时XML格式的文件，所以和容易维护和书写，而且结构很清晰。 <br />Ant可以集成到开发环境中。由于Ant的跨平台性和操作简单的特点，它很容易集成到一些开发环境中去。</p>
		<p>Ant 开发</p>
		<p>Ant的构建文件 <br />当开始一个新的项目时，首先应该编写Ant构建文件。构建文件定义了构建过程，并被团队开发中每个人使用。Ant构建文件默认命名为build.xml，也可以取其他的名字。只不过在运行的时候把这个命名当作参数传给Ant。构建文件可以放在任何的位置。一般做法是放在项目顶层目录中，这样可以保持项目的简洁和清晰。下面是一个典型的项目层次结构。 <br />(1) src存放文件。 <br />(2) class存放编译后的文件。 <br />(3) lib存放第三方JAR包。 <br />(4) dist存放打包，发布以后的代码。 <br />Ant构建文件是XML文件。每个构建文件定义一个唯一的项目(Project元素)。每个项目下可以定义很多目标(target元素)，这些目标之间可以有依赖关系。当执行这类目标时，需要执行他们所依赖的目标。 每个目标中可以定义多个任务，目标中还定义了所要执行的任务序列。Ant在构建目标时必须调用所定义的任务。任务定义了Ant实际执行的命令。Ant中的任务可以为3类。 <br />（1） 核心任务。核心任务是Ant自带的任务。 <br />（2） 可选任务。可选任务实来自第三方的任务，因此需要一个附加的JAR文件。 <br />（3） 用户自定义的任务。用户自定义的任务实用户自己开发的任务。 <br />1.&lt;project&gt;标签 <br />每个构建文件对应一个项目。&lt;project&gt;标签时构建文件的根标签。它可以有多个内在属性，</p>
		<p>就如代码中所示，其各个属性的含义分别如下。 <br />(1) default表示默认的运行目标，这个属性是必须的。 <br />(2) basedir表示项目的基准目录。 <br />(3) name表示项目名。 <br />(4) description表示项目的描述。 <br />每个构建文件都对应于一个项目，但是大型项目经常包含大量的子项目，每一个子项目都可以有自己的构建文件。</p>
		<p>2.&lt;target&gt;标签 <br />一个项目标签下可以有一个或多个target标签。一个target标签可以依赖其他的target标签。例如，有一个target用于编译程序，另一个target用于声称可执行文件。在生成可执行文件之前必须先编译该文件，因策可执行文件的target依赖于编译程序的target。Target的所有属性如下。 <br />(1).name表示标明，这个属性是必须的。 <br />(2).depends表示依赖的目标。 <br />(3)if表示仅当属性设置时才执行。 <br />(4)unless表示当属性没有设置时才执行。 <br />(5)description表示项目的描述。 <br />Ant的depends属性指定了target的执行顺序。Ant会依照depends属性中target出现顺序依次执行每个target。在执行之前，首先需要执行它所依赖的target。程序中的名为run的target的</p>
		<p>depends属性compile，而名为compile的target的depends属性是prepare，所以这几个target执</p>
		<p>行的顺序是prepare-&gt;compile-&gt;run。 <br />一个target只能被执行一次，即使有多个target依赖于它。如果没有if或unless属性，target总</p>
		<p>会被执行。</p>
		<p>3.&lt;mkdir&gt;标签 <br />该标签用于创建一个目录，它有一个属性dir用来指定所创建的目录名，其代码如下： <br />&lt;mkdir dir=”${class.root}”/&gt; <br />通过以上代码就创建了一个目录，这个目录已经被前面的property标签所指定。</p>
		<p>4&lt;jar&gt;标签 <br />该标签用来生成一个JAR文件，其属性如下。 <br />(1) destfile表示JAR文件名。 <br />(2) basedir表示被归档的文件名。 <br />(3) includes表示别归档的文件模式。 <br />(4) exchudes表示被排除的文件模式。</p>
		<p>5．&lt;javac标签&gt; <br />该标签用于编译一个或一组java文件，其属性如下。 <br />(1).srcdir表示源程序的目录。 <br />(2).destdir表示class文件的输出目录。 <br />(3).include表示被编译的文件的模式。 <br />(4).excludes表示被排除的文件的模式。 <br />(5).classpath表示所使用的类路径。 <br />(6).debug表示包含的调试信息。 <br />(7).optimize表示是否使用优化。 <br />(8).verbose 表示提供详细的输出信息。 <br />(9).fileonerror表示当碰到错误就自动停止。</p>
		<p>6．&lt;java&gt;标签 <br />该标签用来执行编译生成的.class文件，其属性如下。 <br />(1).classname 表示将执行的类名。 <br />(2).jar表示包含该类的JAR文件名。 <br />(3).classpath所表示用到的类路径。 <br />(4).fork表示在一个新的虚拟机中运行该类。 <br />(5).failonerror表示当出现错误时自动停止。 <br />(6).output 表示输出文件。 <br />(7).append表示追加或者覆盖默认文件。</p>
		<p>7.&lt;delete&gt;标签 <br />该标签用于删除一个文件或一组文件，去属性如下。 <br />(1)/file表示要删除的文件。 <br />(2).dir表示要删除的目录。 <br />(3).includeEmptyDirs 表示指定是否要删除空目录，默认值是删除。 <br />(4).failonerror 表示指定当碰到错误是否停止，默认值是自动停止。 <br />(5).verbose表示指定是否列出所删除的文件，默认值为不列出。</p>
		<p>8.&lt;copy&gt;标签 <br />该标签用于文件或文件集的拷贝，其属性如下。 <br />(1).file 表示源文件。 <br />(2).tofile 表示目标文件。 <br />(3).todir 表示目标目录。 <br />(4).overwrite 表示指定是否覆盖目标文件，默认值是不覆盖。 <br />(5).includeEmptyDirs 表示制定是否拷贝空目录，默认值为拷贝。 <br />(6).failonerror 表示指定如目标没有发现是否自动停止，默认值是停止。 <br />(7).verbose 表示制定是否显示详细信息，默认值不显示。</p>
		<p>Ant的数据类型 <br />在构建文件中为了标识文件或文件组，经常需要使用数据类型。数据类型包含在</p>
		<p>org.apache.tool.ant.types包中。下面镜简单介绍构建文件中一些常用的数据类型。</p>
		<p>1. argument 类型 <br />由Ant构建文件调用的程序，可以通过&lt;arg&gt;元素向其传递命令行参数，如apply,exec和java任务均可接受嵌套&lt;arg&gt;元素，可以为各自的过程调用指定参数。以下是&lt;arg&gt;的所有属性。 <br />(1).values 是一个命令参数。如果参数种有空格，但又想将它作为单独一个值，则使用此属性。 <br />(2).file表示一个参数的文件名。在构建文件中，此文件名相对于当前的工作目录。 <br />(3).line表示用空格分隔的多个参数列表。 <br />(4).path表示路径。</p>
		<p>2.ervironment 类型 <br />由Ant构建文件调用的外部命令或程序，&lt;env&gt;元素制定了哪些环境变量要传递给正在执行的系统命令，&lt;env&gt;元素可以接受以下属性。 <br />(1).file表示环境变量值得文件名。此文件名要被转换位一个绝对路径。 <br />(2).path表示环境变量的路径。Ant会将它转换为一个本地约定。 <br />(3).value 表示环境变量的一个直接变量。 <br />(4).key 表示环境变量名。 <br />注意 file path 或 value只能取一个。</p>
		<p>3.filelist类型 <br />Filelist 是一个支持命名的文件列表的数据类型，包含在一个filelist类型中的文件不一定是</p>
		<p>存在的文件。以下是其所有的属性。 <br />(1).dir是用于计算绝对文件名的目录。 <br />(2).files 是用逗号分隔的文件名列表。 <br />(3).refid 是对某处定义的一个&lt;filelist&gt;的引用。 <br />注意 dir 和 files 都是必要的，除非指定了refid(这种情况下，dir和files都不允许使用)。</p>
		<p>4.fileset类型 <br />Fileset 数据类型定义了一组文件，并通常表示为&lt;fileset&gt;元素。不过，许多ant任务构建成了隐式的fileset,这说明他们支持所有的fileset属性和嵌套元素。以下为fileset 的属性列表。 (1).dir表示fileset 的基目录。 <br />(2).casesensitive的值如果为false，那么匹配文件名时，fileset不是区分大小写的，其默认</p>
		<p>值为true. <br />(3).defaultexcludes 用来确定是否使用默认的排除模式，默认为true。 <br />(4).excludes 是用逗号分隔的需要派出的文件模式列表。 <br />(5).excludesfile 表示每行包含一个排除模式的文件的文件名。 <br />(6).includes 是用逗号分隔的，需要包含的文件模式列表。 <br />(7).includesfile 表示每行包括一个包含模式的文件名。</p>
		<p>5.patternset 类型 <br />Fileset 是对文件的分组，而patternset是对模式的分组，他们是紧密相关的概念。&lt;patternset&gt;支持4个属性：includes excludex includexfile 和 excludesfile,与fileset相同。Patternset 还允许以下嵌套元素：include,exclude,includefile 和 excludesfile.</p>
		<p>6.filterset 类型 <br />Filterset定义了一组过滤器，这些过滤器将在文件移动或复制时完成文件的文本替换。 <br />主要属性如下： <br />(1).begintoken 表示嵌套过滤器所搜索的记号，这是标识其开始的字符串。 <br />(2).endtoken表示嵌套过滤器所搜索的记号这是标识其结束的字符串。 <br />(3).id是过滤器的唯一标志符。 <br />(4).refid是对构建文件中某处定义一个过滤器的引用。</p>
		<p>7.Path类型 <br />Path元素用来表示一个类路径，不过它还可以用于表示其他的路径。在用作揖个属性时，路经中的各项用分号或冒号隔开。在构建的时候，此分隔符将代替当前平台中所有的路径分隔符，其拥有的属性如下。 <br />(1).location 表示一个文件或目录。Ant在内部将此扩展为一个绝对路径。 <br />(2).refid 是对当前构建文件中某处定义的一个path的引用。 <br />(3).path表示一个文件或路径名列表。</p>
		<p>8.mapper类型 <br />Mapper类型定义了一组输入文件和一组输出文件间的关系，其属性如下。 <br />(1).classname 表示实现mapper类的类名。当内置mapper不满足要求时，用于创建定制mapper. <br />(2).classpath表示查找一个定制mapper时所用的类型路径。 <br />(3).classpathref是对某处定义的一个类路径的引用。 <br />(4).from属性的含义取决于所用的mapper. <br />(5).to属性的含义取决于所用的mapper. <br />(6).type属性的取值为identity，flatten glob merge regexp 其中之一，它定义了要是用的内置mapper的类型。</p>
		<p>Ant 的运行 <br />安装好Ant并且配置好路径之后，在命令行中切换到构建文件的目录，输入Ant命令就可以运行Ant.若没有指定任何参数，Ant会在当前目录下查询build.xml文件。如果找到了就用该文件作为构建文件。如果使用了 –find 选项，Ant 就会在上级目录中找构建文件，直至到达文件系统得跟目录。如果构建文件的名字不是build.xml ，则Ant运行的时候就可以使用 –buildfile file ,这里file 指定了要使用的构建文件的名称，示例如下： <br />Ant <br />如下说明了表示当前目录的构建文件为build.xml 运行 ant 执行默认的目标。</p>
		<p>Ant –buildfile test.xml <br />使用当前目录下的test.xml 文件运行Ant ,执行默认的目标。</p>
<img src ="http://www.blogjava.net/lisuzhi008/aggbug/98017.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/lisuzhi008/" target="_blank">黎素智</a> 2007-02-05 14:58 <a href="http://www.blogjava.net/lisuzhi008/articles/98017.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>通用日志包学习笔记</title><link>http://www.blogjava.net/lisuzhi008/articles/98002.html</link><dc:creator>黎素智</dc:creator><author>黎素智</author><pubDate>Mon, 05 Feb 2007 06:47:00 GMT</pubDate><guid>http://www.blogjava.net/lisuzhi008/articles/98002.html</guid><wfw:comment>http://www.blogjava.net/lisuzhi008/comments/98002.html</wfw:comment><comments>http://www.blogjava.net/lisuzhi008/articles/98002.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/lisuzhi008/comments/commentRss/98002.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/lisuzhi008/services/trackbacks/98002.html</trackback:ping><description><![CDATA[
		<p>
				<span style="FONT-SIZE: 18pt">
						<font color="#000000" size="2">转自：</font>
						<a href="http://lincoln.javaeye.com/blog/32535">
								<font color="#000000" size="2">http://lincoln.javaeye.com/blog/32535</font>
						</a>
						<br />通用日志包</span>
		</p>
		<p>在构建一个Web系统得过程中，通常要完成的工作不仅仅是编码，还需要完成一些记录日志的工作。这样做是为了更好的监视代码中变量的变化情况和跟踪代码的运行轨迹，同时充当开发环境中的调试器。</p>
		<p>1. 通用日志包概述 <br />Apache通用日志包十是Apache组织的开源项目。它负责向开发者提供一系列通用的日志接口。用户可以自由地选择和实现通用日志接口。通用的日志包目前主要支持以下几个日志器。 <br />Log4j日志器是一个开放源代码项目。它由Logger,Appender,和Layout这三个主要的组件构成。 <br />SimpleLog 日志器在通用日志包中自带了org.apache.commons.logging..impl.Simple Log日志实现类。它实现了Log接口，把日志消息都输出到系统错误流System.err 中。 <br />NoOpLog日志器在通用日志包中自带了org.apache.commons.logging.impl.NoOpLog日志实现类，实现了Log接口。其输出日志的方法中不进行任何操作。 <br />其中，SimpleLog 和NoOpLog 日志器是通用日志包自带的，Log4j日志器是第三方的软件。</p>
		<p>2．配置通用日志接口 <br />要在Web应用系统中使用日志，一般都需要同过以下几个步骤来完成。 <br />(1) 下载相关的JAR文件。 <br />(2) 部署JAR文件。] <br />(3) 在通用日志包的属性文件中指定要使用的日志器(Log4j,SimpleLog或NoOpLog)。 <br />(4) 选择日志器以后，为该日志其设定日志级，输出格式和地点等属性/。</p>
		<p>3.下载相关的JAR文件 <br />通用的日志包通常都是以JAR文件存在。这些JAR文件都可以在http://jakarta.apache.org/commons/loggin/这个地址下载到。(通常，在Struts下载包和Tomcat5.0.*的/Tomcat /common/lib目录下都包含了该包。)该包的包名为commons-logging.jar因为commons-logging.jar 文件之包含有SimpleLog和NoOpLog两种日志器，如果要使用Log4j日志器，还需要到apache的网站上下载Log4j的jar文件。下载下来的JAR文件应该叫做logging-log4j-1.2.13.zip。</p>
		<p>4．部署日志器 <br />如果要使用SimpleLog或者NoOpLog日志器，那么就把commons-logging.jar文件放到工程项目的/Web-INF/lib目录下。如果要使用第三方的Log4j日志器，那么就要把Log4j的JAR文件放到/Web-INF/lib/。然后再工程项目的属性窗口的构建路径中导入commons-logging.jar文件或Log4j的JAR文件。</p>
		<p>5.指定日志器 <br />通用日志包从名为common-logging.properties属性文件中获取实现接口的日志器。如果要使用Log4j日志器，那么就把该行的内容改为org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JCategoryLog,其他几个日志器与Log4j类似。 <br /></p>
		<p>设置日志器属性 <br />(1) 配置SimpleLog日志器 <br />如果是使用SimpleLog日志器，那么其日志输出地点都是System.err系统错误流，用户不用进行配置。但可以在simplelog.properties属性文件中设置其日志级别。如下代码设置SimpleLog的日志级别为info。 <br />Org.apache.commons.logging.simplelog.defaultlog=info <br />最后要把simplelog.properties属性文件保存到Web-INF/classes目录下。</p>
		<p>(2) 配置Log4j日志器 <br />配置Logger组件。通常会配制一个rootLogger,其配制语句如下： <br />Log4j.rootLogger=[日志级别],Appender1,Appender2…… <br />其中，日志级别分别有OFF,FATAL,ERROR,WARN,INFO,DEBUG这六种权限。通过定义日志权限，可以控制程序中的日志是否打印输出等操作。Appender1,Appender2是用来指定Appender组件的。Appender组件用于配置消息的目的地，用户也可以同时指定多个Appender. <br /><br />配置Appender组件。Appender是用来配置日志消息的输出地，其基本配置语法如下： <br />Log4j.appender.AppenderName =…… <br />Log4j.appender.AppenderName.option1=……. <br />Log4j.appender.AppenderName.option2=……. <br /><br />AppenderName由用户自己设置，其值由Log4j提供。Log4j提供了以下几种值。 <br />Org.apache.log4j.ConsoleAppender 输出到控制台 <br />Org.apache.log4j.DaillyRollingFileAppender 每天产生一个文件 <br />Org..apache.log4j.FileAppender 输出到文件 <br />Org,.apache.log4j.RollingFileAppender 文件按固定大小保存，超过固定大小，就新建一个文件。 <br />Org.apache.log4j.WriterAppender 把日志消息以流的形式进行发送。 <br /><br />下面举个实例进行讲解： <br />Log4j.appender.file=org.apache.log4j.FileAppender <br />Log4j.appender.file.File = log4j.txt <br />以上代码定义名为file的Appender把日志消息输出到文件，文件名为log4j.txt。 <br /><br />配置Layout组件。Appender有一个Layout属性来指定日志文件以什么格式进行存储。Log4j提供以下几种格式。 <br />Org.apache.log4j.HTMLLayout 以HTML表单格式存储。 <br />Org.apache.log4j.PatternLayout 以指定的布局模式存储。 <br />Org.apache.log4j.SimpleLayout 以包含日志消息的级别和信息字符窜的简单格式存储 <br />Org.apache.log4j.TTCCLayout 以包含日志产生时间 线程和类别等信息的格式进行存储。 <br /><br />配置语句格式如下： <br />Log4j.appender.AppenderName.layout =….. <br />Log4j.appender.AppenderName.layout.option1 =… <br />Log4j.appender.AppenderName.layout.option2 =….</p>
		<p>//测试属性文件 <br />log4j.rootLogger=DEBUG,stdout <br />log4j.appender.stdout=org.apache.log4j.ConsoleAppender <br />log4j.appender.stdout.layout=org.apache.log4j.PatternLayout <br />log4j.appender.stdout.layout.ConversionPattern=%d %5p (%F:%L) - %m%n<br /><br /></p>
		<p>//测试类 <br /></p>
		<div class="code_title">代码<br /></div>
		<div class="code_title">
				<ol>
						<li class="alt">
								<span>
										<span class="keyword">package</span>
										<span> net.wanjin.testlog4j;   </span>
								</span>
						</li>
						<li class="">
								<span>  </span>
						</li>
						<li class="alt">
								<span>
								</span>
								<span class="keyword">import</span>
								<span> org.apache.commons.logging.Log;   </span>
						</li>
						<li class="">
								<span>
								</span>
								<span class="keyword">import</span>
								<span> org.apache.commons.logging.LogFactory;   </span>
						</li>
						<li class="alt">
								<span>  </span>
						</li>
						<li class="">
								<span>
								</span>
								<span class="keyword">public</span>
								<span> </span>
								<span class="keyword">class</span>
								<span> TestLog {   </span>
						</li>
						<li class="alt">
								<span>  </span>
						</li>
						<li class="">
								<span>     </span>
								<span class="comment">/** </span>  
</li>
						<li class="alt">
								<span>
										<span class="comment">     * @param args </span> </span>
						</li>
						<li class="">
								<span>
										<span class="comment">     */</span>
										<span>  </span>
								</span>
						</li>
						<li class="alt">
								<span>      </span>
								<span class="keyword">public</span>
								<span> </span>
								<span class="keyword">static</span>
								<span> </span>
								<span class="keyword">void</span>
								<span> main(String[] args) {   </span>
						</li>
						<li class="">
								<span>        Log log = LogFactory.getLog(</span>
								<span class="string">"log"</span>
								<span>);   </span>
						</li>
						<li class="alt">
								<span>        log.error(</span>
								<span class="string">"LogAction 中出现异常 -LogAction.java"</span>
								<span>);   </span>
						</li>
						<li class="">
								<span>    }   </span>
						</li>
						<li class="alt">
								<span>  </span>
						</li>
						<li class="">
								<span>}  </span>
						</li>
				</ol>
		</div>
<img src ="http://www.blogjava.net/lisuzhi008/aggbug/98002.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/lisuzhi008/" target="_blank">黎素智</a> 2007-02-05 14:47 <a href="http://www.blogjava.net/lisuzhi008/articles/98002.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>