- 浏览: 2870110 次
- 性别:
- 来自: 武汉
文章分类
- 全部博客 (1173)
- 名言警句 (5)
- 心情随笔 (50)
- 数据库 (57)
- Java基础 (241)
- J2EE框架 (91)
- 数据结构 (12)
- 程序设计 (21)
- WEB技术 (128)
- 网络日志 (12)
- IT资讯 (247)
- linux (64)
- solaris (2)
- 其它 (143)
- WebService (4)
- 日语学习 (2)
- 机器人 (5)
- Android (5)
- cgywin (3)
- Game (1)
- DWR (1)
- spring (8)
- canvas (1)
- Guava (3)
- Modbus (5)
- 测试 (6)
- mongodb (9)
- Quartz (2)
- Cron (1)
- windows (2)
- 持续集成 (1)
- bootstrap (3)
- 结对编程 (1)
- nodejs (1)
- Netty (1)
- 安全 (3)
- webstorm (2)
- sparkline (1)
- Job (1)
- git (3)
- Maven (3)
- knockout (5)
- jquery (1)
- bower (1)
- docker (1)
- confluence (4)
- wiki (1)
- GoogleMap (1)
- jekyll (10)
- ruby (2)
- npm (3)
- browserify (1)
- gulp (3)
- openwrt (1)
- discuz (3)
- 输入法 (1)
- JPA (1)
- eclipse (2)
- IntelliJ (1)
- css (1)
- 虚拟机 (1)
- 操作系统 (1)
- azkaban (2)
- scrum (1)
最新评论
-
pangxiea_:
你好, 想请问一下 Linux下 这么使用rxtxcomm 在 ...
使用Java进行串口通信 -
abababudei:
请教一下,这个您是怎么解决的:/dev/ttyS2enteri ...
Java应用程序的MODBUS通讯 -
xuniverse:
hannibal005 写道楼主,我问下 request.se ...
用javascript与java进行RSA加密与解密 -
atxkm:
找了一下午,终于找到了
gulp 拷贝文件时如何移除文件目录结构 -
kalogen:
gtczr 写道非常感谢,经过我自己的修改,已经完美实现。发出 ...
用javascript与java进行RSA加密与解密
1。什么是日志:
程序运行时,往特定输出文件或数据库里输出程序信息,
如:出错信息,运行记录,调试记录,等等。
日志(LOG)一般分为以下几种类型。
FATAL:系统错误(大错误)(程序被错误中断)
系统出现大错误时输出(程序无法处理的大错误,如硬件错误)
ERROR:异常(程序被错误中断)
程序运行时出现的错误(程序员可以捕获处理)
WARN
:警告(程序不会中断)
程序不算出错,但以不推荐方式运行时输出。
INFO :
信息(程序不会中断)
程序中有意输出的信息,如程序运行信息,
如“程序开始”“程序结束”等。
DEBUG:
调试记录(程序不会中断)
调试程序时,跟踪程序运行的输出信息。
2.Log4J的使用。
Log4J是为了输出日志的Java程序包,是Apached的一个子项目。
可在http://logging.apache.org
下载并免费使用。
可以把LOG输出到,控制台,文件,或数据库。
这个网址里有很多Log4程序包,他们分别是,
log4c
-- ANSI C 版
log4E
-- Eiffel 版
log::Log4perl -- Perl
版
log4net
-- .NET 版
log4r
-- Ruby 版
log4j
-- Java版
3.Log4J的能输出LOG的优先级。
级别高 OFF 关闭所有LOG
FATAL
不可预想的无法继续运行程序的场合,一般是写进syslog(
系统日志),在应用程序中很难捕获。
ERROR 出现异常,应用程序停止运行等,需要紧急对应的程度的错误。
WARN 警告,以不建议的方式运行。
INFO 信息,实际运行中最基本程度的信息,如,启动服务器,
运行某某程序或方法,运行结束等。
DEBUG 调试时输出的信息,有可能产生非常大量的LOG文件。
如为解决问题而设置输出断点LOG等。DEBUG调试时输出的
信息,所以投入运行时一般关闭DEBUG级别的LOG。
tracever log4j的 1.2.12
新加入比DEBUG还小的断点。
级别低 ALL
打开所有LOG
4.Struts使用Log4J。
项目里的,[JavaSource]下做一个,log4j.xml或log4j.properties以后
Struts就可以使用Log4J了,log4j.xml,log4j.properties是Log4J的
设置文档。struts先读入log4j.xml,要是没有再读入log4j.properties。
我认为log4j.xml更容易理解,而且可以做到赛选各种级别LOG后输出
(log4j.properies无法赛选),所以只讲log4j.xml。
5.Log4j.xml设置方法。
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'> <!-- org.apache.log4j.ConsoleAppender (输出到控制台), org.apache.log4j.FileAppender (输出到文件), org.apache.log4j.DailyRollingFileAppender (每天输出产生一个日志文件), org.apache.log4j.RollingFileAppender (文件大小到达指定尺寸的时候产生一个新的文件), 可通过 log4j.appender.R.MaxFileSize=100KB 设置文件 大小,还可通过 log4j.appender.R.MaxBackupIndex=1 设置为保存一个备份文件。 org.apache.log4j.WriterAppender (将日志信息以流格式发送到任意指定的地方) --> <!-- 输出通道"STDOUT",输出所有信息到控制台 (也就是System.out.println()) --> <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender"> <!--org.apache.log4j.HTMLLayout (以 HTML 表格形式布局), org.apache.log4j.PatternLayout (可以灵活地指定Log内容布局模式), org.apache.log4j.SimpleLayout (包含日志信息的级别和信息字符串), org.apache.log4j.TTCCLayout (包含日志产生的时间、线程、类别等等信息) --> <!-- 输出自定义内容的LOG --> <layout class="org.apache.log4j.PatternLayout"> <!-- %m 输出代码中指定的消息 %p 输出优先级,即 DEBUG , INFO , WARN , ERROR , FATAL %r 输出自应用启动到输出该 log 信息耗费的毫秒数 %c 输出打了Log的类名,%c{1}从类名开始输出一个, 例如com.tongshida.Action,{1}时只输出Action, {2}输出 tongshida.Action %C 输出.Error()方法所在的类。 %M 输出生成LOG的类当中的方法名称 %t 输出产生该日志事件的线程名 %n 输出一个回车换行符, Windows 平台为 “rn”,Unix 平台为 “n” %d 输出日志时间点的日期或时间,默认格式为 ISO8601 ,也可以在 其后指定格式,比如: %d{yyyy MMM dd HH:mm:ss,SSS} ,输出类似: 2002 年 10 月 18 日 22 : 10 : 28 , 921 %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中 的行数。 %[数值]p 输出的%p字符串长度小于[数值]时,补空格,默认右对齐, 前加-号,左对齐,这里也可以是%m等别的 %.[数值]p输出的%p字符串长度大于[数值],后面切掉。 %[数值].[数值]p 就是综合上两行。 --> <!-- 输出时Log内容的具体定义 --> <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss,SSS}][%-20c{1}]★%-5p★%m%n"/> </layout> </appender> <!-- 输出通道"DEBUG",输出方式是:只输出DEBUG级别的LOG,并文件 大小到达指定大小时产生新的Log文件 --> <appender name="DEBUG" class="org.apache.log4j.RollingFileAppender"> <!-- 输出Log文件的路径和文件名 --> <param name="File" value="logs/debug/debug.log"/> <!-- TOMCAT等WEB服务器重新启动时,是否插入到原有的LOG文件里, true 插入false 新建 --> <param name="Append" value="true"/> <!-- 只输出定义的级别以上的LOG,因为在下面过滤LOG信息所以屏蔽 --> <!-- param name="Threshold" value="info"/ --> <!-- 因选择了RollingFileAppender了才有下面两个 MaxFileSize, MaxBackupIndex 选项 --> <!-- MaxFileSize是一个LOG文件的最大的文件大小,当LOG文件超过这个 值时,自动转成 *.log.1的LOG文件 --> <param name="MaxFileSize" value="500KB"/> <!-- MaxBackupIndex生成自动转成 *.log.1的LOG文件的个数,设置3时最多 生成3个LOG备份文件,它们是[*.log.1][*.log.2][*.log.3] --> <param name="MaxBackupIndex" value="2"/> <!-- 输出时Log内容的具体定义 --> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss,SSS}][%-20c{1}]★%-5p★%m%n"/> </layout> <!-- 过滤输出时Log内容,在这里,LevelMin,LevelMax都定义了DEBUG, 所以只输出DEBUG级别LOG的数据 --> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <!-- 指定输出LOG内容的最低等级 --> <param name="LevelMin" value="DEBUG"/> <!-- 指定输出LOG内容的最高等级 --> <param name="LevelMax" value="DEBUG"/> </filter> </appender> <!-- 输出通道"INFO",输出方式是:只输出INFO级别的LOG,并文件大小 到达指定大小时产生新的Log文件 --> <appender name="INFO" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="logs/info/info.log"/> <param name="Append" value="true"/> <param name="MaxFileSize" value="500KB"/> <param name="MaxBackupIndex" value="2"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss,SSS}][%-20c{1}]★%-5p★%m%n"/> </layout> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="LevelMin" value="INFO"/> <param name="LevelMax" value="INFO" /> </filter> </appender> <!-- 输出通道"WARN",输出方式是:只输出WARN级别的LOG,并文件 大小到达指定大小时产生新的Log文件 --> <appender name="WARN" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="logs/warn/warn.log"/> <param name="Append" value="true"/> <param name="MaxFileSize" value="500KB"/> <param name="MaxBackupIndex" value="2"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss,SSS}][%-20c{1}]★%-5p★%m%n"/> </layout> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="LevelMin" value="WARN"/> <param name="LevelMax" value="WARN"/> </filter> </appender> <!-- 输出通道"ERROR",输出方式是:只输出ERROR级别的LOG,并文件 大小到达指定大小时产生新的Log文件 --> <appender name="ERROR" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="logs/error/error.log"/> <param name="Append" value="true"/> <param name="MaxFileSize" value="500KB"/> <param name="MaxBackupIndex" value="2"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss,SSS}][%-20c{1}]★%-5p★%m%n"/> </layout> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="LevelMin" value="ERROR"/> <param name="LevelMax" value="ERROR"/> </filter> </appender> <!-- 输出通道"FATAL",输出方式是:只输出INFO级别的LOG,并文件大小 到达指定大小时产生新的Log文件 --> <appender name="FATAL" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="logs/fatal/fatal.log"/> <param name="Append" value="true"/> <param name="MaxFileSize" value="500KB"/> <param name="MaxBackupIndex" value="2"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss,SSS}][%-20c{1}]★%-5p★%m%n"/> </layout> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="LevelMin" value="FATAL"/> <param name="LevelMax" value="FATAL"/> </filter> </appender> <!-- 输出通道"ALL",输出方式是:输出所有级别的LOG,并文件大小到达 指定大小时产生新的Log文件 --> <appender name="ALL" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="logs/all/all.log"/> <param name="Append" value="true"/> <param name="MaxFileSize" value="500KB"/> <param name="MaxBackupIndex" value="2"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss,SSS}][%-20c{1}]★%-5p★%m%n"/> </layout> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="LevelMin" value="DEBUG"/> <param name="LevelMax" value="FATAL"/> </filter> </appender> <!-- 输出通道"EVERYDAY",输出方式是:输出所有级别的LOG,并每天一个 日志文件 --> <appender name="EVERYDAY" class="org.apache.log4j.DailyRollingFileAppender"> <param name="File" value="logs/ereryday/ereryday.log"/> <param name="Append" value="true"/> <!-- param name="Threshold" value="DEBUG"/ --> <!-- 以日为单位输出LOG文件,每日输出一个LOG文件--> <param name="DatePattern" value="'.'yyyy-MM-dd"/> <!-- 以时为单位输出LOG文件,每小时输出一个LOG文件 <param name="DatePattern" value="'.'yyyy-MM-dd-HH"/> --> <layout class="org.apache.log4j.PatternLayout"> <!-- The default pattern: Date Priority [Category] Message --> <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss,SSS}][%-20c{1}]★%-5p★%m%n"/> <!-- The full pattern: Date MS Priority [Category] (Thread:NDC) Message <param name="ConversionPattern" value="%d %-5r %-5p [%c] (%t:%x) %m%n"/> --> </layout> <!-- 过滤输出时Log内容,在这里,LevelMin是DEBUG,LevelMax都FATAL, 所以输出DEBUG级别到FATAL级别的LOG数据 --> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="LevelMin" value="DEBUG"/> <param name="LevelMax" value="FATAL"/> </filter> </appender> <!-- 输出通道"DATABASE",输出方式是:输出所有级别的LOG到数据库 --> <appender name="DATABASE" class="org.apache.log4j.jdbc.JDBCAppender"> <!--数据库的驱动,这里用的是MSSQL--> <param name="driver" value="com.microsoft.jdbc.sqlserver.SQLServerDriver"/> <!--这是Oracle用的驱动,在这里用MSSQL所以屏蔽掉了 <param name="driver" value="oracle.jdbc.driver.OracleDriver" /> --> <!--要连接的数据库--> <param name="URL" value="jdbc:microsoft:sqlserver://192.168.0.120: 1433;DatabaseName=test" /> <!--连接数据库的用户名--> <param name="user" value="sa" /> <!--连接数据库的密码--> <param name="password" value="sa" /> <!--向MSSQL数据库表LOG中插入数据的sql语句--> <param name="sql" value=" INSERT INTO LOG (LOGDATE,LOGLEVEL,LOGCLASS,LOGLOGGER,LOGMESSAGE) values ('%d{yyyy-MM-dd HH:mm:ss}','%.50p', '%.50c', '%.50l', '%.1000m')"/> <!-- Oracle 的 insert 语句 <param name="sql" value=" insert into logrecord (id,packageid,userid,syscodeid,info,logtime,loglevel) values(?,?,?,?,?,to_date('%d{yyyy-MM-dd HH:mm:ss}', 'yyyy-MM-dd HH24:mi:ss'),'%p')" /> --> <!-- 过滤输出时Log内容,在这里,LevelMin是ERROR,LevelMax都 FATAL,所以输出DEBUG级别到FATAL级别的LOG数据 --> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="LevelMin" value="ERROR"/> <param name="LevelMax" value="FATAL"/> </filter> </appender> <!-- 输出通道"HTML",输出方式是:输出所有级别的LOG到数据库 --> <appender name="HTML" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="logs/html/htmllog.html" /> <param name="Append" value="true" /> <!-- 只输出定义的级别以上的LOG,因为在下面过滤LOG信息所以屏蔽 --> <!-- param name="Threshold" value="info"/ --> <param name="MaxFileSize" value="50KB"/> <param name="MaxBackupIndex" value="2"/> <!-- 好像现在只有固定输出格式 --> <!-- 输出的HTML都缺少</table></body>等代码,log4j的Bug? 我建议是不要使用 --> <layout class="org.apache.log4j.HTMLLayout"> <param name="Title" value="TSD HP HTML LOG" /> </layout> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="LevelMin" value="DEBUG"/> <param name="LevelMax" value="FATAL"/> </filter> </appender> <!-- 设置域名限制,即com.tongshida域及以下的日志均输出到下面 对应的通道中, 虽然下面<roo>的<priority value="ERROR">设置 成ERROR,但com.tongshida下面的程序中的LOG要输出 level="DEBUG"的 DEBUG级别以上的LOG--> <!--给客户交货时要把它屏蔽--> <logger name="com.tongshida"> <!-- 设置com.tongshida以下函数输出LOG的级别 --> <level value="DEBUG"/> <!-- 好像是指定输出通道,因为下面root里指定了所以这里屏蔽掉了 <appender-ref ref="DEBUG"/> --> </logger> <root> <!-- 设置输出范围,在这里光输出ERROR以上的,ERROR级别, FATAL级别的LOG --> <priority value="ERROR"/> <!-- 上边设置的输出通道,使用的在这里定义 --> <appender-ref ref="STDOUT"/> <appender-ref ref="DEBUG"/> <appender-ref ref="INFO"/> <appender-ref ref="WARN"/> <appender-ref ref="ERROR"/> <appender-ref ref="FATAL"/> <appender-ref ref="ALL"/> <appender-ref ref="EVERYDAY"/> <appender-ref ref="DATABASE"/> <appender-ref ref="HTML"/> </root> </log4j:configuration>
6.Log4j在Java程序里的使用。
Logger log = Logger.getLogger(inputClass);
//输出到数据库时有"'"会出错所以把它换成全角
String outmessage =
message.replaceAll("'", "’");
log.debug(outmessage);log.error(outmessage);log.warn(outmessage);
如想要动态输出LOG(更改输出目录和文件名),也就是强制改变读到
内存中的[Log4j.xml]里的相应输出目录和文件名。鉴于篇幅没能写下。
7.MSSQL_log_table_Creater.sql
CREATE TABLE [LOG] (
ID INTEGER NOT NULL PRIMARY KEY,
LOGDATE DATETIME,
LOGTIME TIMESTAMP,
LOGTHREAD VARCHAR(50),
LOGLEVEL VARCHAR(50),
LOGCLASS VARCHAR(50),
LOGLOGGER VARCHAR(200),
LOGMESSAGE VARCHAR(2000)
)
发表评论
-
高级Java程序员值得拥有的10本书
2015-05-04 07:24 810Java是时下最流行的编程语言之一。市面上也出现了适合初学者 ... -
深入理解java异常处理机制
2015-01-30 09:30 13271. 引子 try…catch…fi ... -
java 运行时参数设置
2015-01-07 09:13 865JVM的运行时参数: -Xms为执行单元内存的1/4, ... -
每个Java开发者都应该知道的5个JDK工具
2014-12-29 12:37 1139JDK是Java语言的软件开 ... -
使用双重锁判定可以大幅降低锁的征用
2014-12-29 12:30 746class ObjInstance { //单例 pri ... -
MAVEN Scope使用说明
2014-11-24 09:40 757在Maven的依赖管理中,经常会用到依赖的scope设置。这 ... -
Spring4 quartz job xml configuration
2014-11-11 09:46 14371. 定义job details public ... -
Add items into list in one line using guava
2014-11-10 10:54 721//@formatter:off fina ... -
配置动态读取(变化)文件 in Spring
2014-11-10 08:51 13231. 从环境变量中读取路径: <bean id=&q ... -
JAVA实现AES加密与解密
2014-11-04 15:34 659package com.eifesun.monitor.up ... -
Netty4.x分析
2014-07-31 11:06 1461官网定义: netty是一个异步、事件驱动的网络应用框架,用 ... -
Ways to sort lists of objects in Java based on multiple fields
2014-07-21 17:19 7711. the first way: Sorting wit ... -
how to parse a String to BigDecimal
2014-07-21 10:08 917private BigDecimal parsePrice( ... -
order list using google guava
2014-07-21 09:08 884Predicate<String> filter ... -
Java 读文件操作
2014-07-08 14:09 8861. only use java core, no exte ... -
怎样使Java 中测试按一定顺序执行
2014-03-10 11:27 1318@FixMethodOrder(MethodSorters. ... -
如何实现在当类初始化时,自动调动某个方法
2014-02-14 14:44 964有两种思路, 1. 将这个类实现为thread类 (or ... -
持续集成JenkinsAPI常见用法
2014-02-10 13:54 43jenkins(持续集成开源工具)提供了丰富的api接口,基 ... -
Sonar 安装与使用
2014-01-13 10:49 1730Sonar 是一个用于代码质量管理的开放平台。通过插件机制, ... -
源代码管理分析工具 Source Navigator的安装与使用
2014-01-13 09:51 1893Source-Navigator是原来redhat开发的一个 ...
相关推荐
在"slf4j-log4j12-1.5.8"这个包中,包含了SLF4J的API接口和Log4j的具体实现,使得开发者能够方便地将日志记录集成到Struts2应用中。 Struts2的基础jar包通常包含以下组件: 1. `struts2-core`: 这是Struts2的核心...
这里特别提到了两个关键文件:`log4j-core-2.7.jar`和`log4j-api-2.7.jar`,它们是Log4j 2.7版本的核心实现和API接口,用于修复可能存在的与Struts2集成时的日志相关问题。此外,还提及了`log4j2.xml`,这是一个配置...
接着,将解压后的`log4j-1.x.x.jar`文件添加到你的项目类路径(LIB目录)中,确保项目能够识别并使用Log4j库。 Log4j的配置有静态和动态两种方式。静态配置通常是通过调用`BasicConfigurator.configure()`来完成,...
最后,log4j是日志记录库,它在`log4j-core-2.11.0.jar`中实现。在软件开发中,日志记录对于调试、性能分析和问题排查至关重要。Log4j提供了丰富的配置选项,允许开发者定制日志级别、输出格式和目的地,使得在项目...
Struts2是一个强大的MVC(Model-View-Controller)框架,它提供了丰富的功能来简化Java Web应用的开发,而Log4j则是一个广泛使用的日志记录库,为开发者提供了灵活的日志记录机制。 Struts2框架是Apache软件基金会...
Log4j与其他框架如Spring、Struts等有良好的集成,可以方便地在这些框架中使用日志功能。此外,通过添加插件,还可以将日志信息发送到syslog、SMTP、JMS等其他目的地。 总结来说,Log4j 1.2.17作为一个成熟的日志...
描述中提到,Struts2版本2.5.10.1依赖于Log4j2,这意味着开发者在使用该版本的Struts2时,需要引入两个关键的Log4j2库:log4j-api-2.7和log4j-core-2.7。log4j-api-2.7提供了API接口,供应用程序调用,而log4j-core-...
从Log4j升级到Log4j2,可以享受到更高效的日志处理、异步日志记录、动态配置以及支持JSON和XML等格式的日志输出。 在Struts2.3到Struts2.5的升级中,首先需要确保所有依赖的jar文件都与新版本兼容。这包括Struts2的...
总之,`slf4j-api-1.6.1.jar`和`slf4j-log4j12-1.6.1.jar`在Java开发中起到了桥梁的作用,将简单易用的SLF4J接口与强大的Log4j日志系统相结合,为SSH和MVC项目提供了一套高效且灵活的日志解决方案。通过正确配置和...
10. **与其他框架的集成**:许多Java框架,如Spring、Struts等,都内置了对Log4j的支持,开发者可以无缝地将日志记录整合到应用中。 了解并熟练掌握Log4j的使用,对于Java开发者来说是提高开发效率和维护质量的重要...
6. **log4j-1.2.9.jar**:Log4j的核心库,提供日志记录服务,包括配置日志级别、输出目的地(控制台、文件、数据库等)以及自定义日志格式。 7. **ognl-3.0.6.jar**:Object-Graph Navigation Language,Struts2中...
5. **log4j-1.2.14.jar**:Log4j是Apache组织提供的一款日志记录框架,广泛应用于各种Java应用中。通过配置,开发者可以选择不同的日志级别(如DEBUG、INFO、WARN等),控制输出的日志信息,便于调试和监控程序运行...
在本示例中,"纯struts2开发带log4j的用户登录demo"是教你如何利用Struts2框架来实现一个简单的用户登录功能,并结合log4j进行日志记录。Log4j是一个广泛使用的日志记录工具,它提供了灵活的日志配置,有助于调试、...
通过使用Log4j,开发者可以非常灵活地控制日志信息的输出目的地(如控制台、文件、GUI组件、网络套接字服务器、NT事件记录器、UNIX Syslog守护进程等)、每条日志信息的格式以及日志级别(例如DEBUG、INFO、WARN、...
在SSH(Struts、Spring、Hibernate)等Java Web框架中,配置Log4j以使用相对路径是非常常见的需求,这有助于在不同环境下保持日志文件的一致性。以下是关于Log4j相对路径配置的详细说明: 首先,在`Web.xml`文件中...
本篇文章将详细阐述如何在SSH环境中配置和使用Log4j,以及如何将日志输出到控制台和文件中。 首先,我们需要理解SSH框架中的每个组件与Log4j的关系。Spring作为应用的依赖注入容器,可以方便地整合其他库,包括Log4...
总之,"log4j2必需jar包"中的log4j-api-2.11.1.jar和log4j-core-2.11.1.jar是构建高效、灵活和安全的日志系统的基石。它们提供了强大的日志记录功能,可以满足从基本调试到复杂监控的多种需求。在Java项目中,正确...
在"apache-log4j-2.0-alpha2-bin"压缩包中,包含的XML配置文件是Log4j 2.0的主要配置方式,它允许用户详细定义日志记录的各个方面,包括日志级别、日志Appender、Layout和过滤器等。 综上所述,Log4j 2.0 Alpha2是...
通过对Log4j配置文件的理解和自定义日志类的编写,我们可以实现对Struts、iBatis等框架的日志输出控制,同时也能根据项目需求进行灵活的日志输出。这种扩展不仅可以提高系统的可维护性和可调试性,还能有效地帮助...