java log4j.xml配置与使用 (详解及实例)

备注:log4j -- logger和category的区别这:logger是category的子类,category现在已经不提倡使用。

1、 一般的log4j.xml的两种配置方式:

1、Logger 完成日志信息的处理
定义输出的层次和决定信息是否输出
DEBUG<INFO<WARN<ERROR

2、Appender 设置日志信息的去向
常用的:
org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppener(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
org.apache.log4j.WriterAppender(将日志讯息以串流格式发送到任意指定的地方)
org.apache.log4j.JdbcAppender(将日志讯息保存到数据库中)

3、Layout 设置日志信息的输出样式
layout有以下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局)
org.apache.log4j.SimpleLayout(包含日志讯息的级别和讯息字符串)
org.apache.log4j.TTCCLayout(包含日志产生的时间、执行绪、类别等讯息)
org.apache.log4j.PatterLayout(可以灵活地指定布局格式)

log4j.xml实例:
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
  3. <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

  4. <appender name="filelog_appender"  
  5.         class="org.apache.log4j.RollingFileAppender">  
  6.         <!-- 设置File参数:日志输出文件名 -->  
  7.         <param name="File" value="log/testlog4jxml_all.log" />  
  8.         <!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->  
  9.         <param name="Append" value="true" />  
  10.         <!-- 设置文件大小 -->  
  11.         <param name="MaxFileSize" value="1MB" />  
  12.         <!-- 设置文件备份 -->  
  13.         <param name="MaxBackupIndex" value="10000" />  
  14.         <!-- 设置输出文件项目和格式 -->  
  15.         <layout class="org.apache.log4j.PatternLayout">  
  16.             <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} %-5p (%c:%L)- %m%n" />  
  17.         </layout>  
  18.     </appender>  
    


  19. <appender name="A2" class="org.apache.log4j.ConsoleAppender">
  20.     <layout class="org.apache.log4j.PatternLayout">
  21.         <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss}][%C-%M]%m%n" />
  22.     </layout>
  23. </appender>

  24. <logger name="com.jjm.dao">
  25.     <level value="DEBUG" />
  26.     <appender-ref ref="A1" />
  27. </logger>

  28. <root>
  29.     <priority value="DEBUG" />
  30.     <appender-ref ref="A2" />
  31. </root>

  32. </log4j:configuration>

以上来自:http://www.blogjava.net/thisliy/archive/2009/06/01/279377.html

2、 log4j.xml向db、发邮件多种接入方式:

  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">  
  3.   
  4. <log4j:configuration>  
  5.   
  6.  <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">  
  7.   <layout class="org.apache.log4j.PatternLayout">  
  8.    <param name="ConversionPattern"  
  9.     value="%d - %c -%-4r [%t] %-5p %x - %m%n" />  
  10.   </layout>  
  11.     
  12.   <!--限制输出级别-->  
  13.   <filter class="org.apache.log4j.varia.LevelRangeFilter">  
  14.    <param name="LevelMax" value="ERROR"/>  
  15.    <param name="LevelMin" value="TRACE"/>  
  16.   </filter>  
  17.  </appender>  
  18.    
  19.  <appender name="FILE" class="org.apache.log4j.FileAppender">  
  20.   <param name="File" value="C:/log4j1.log"/>  
  21.   <layout class="org.apache.log4j.PatternLayout">  
  22.    <param name="ConversionPattern"  
  23.     value="%d - %c -%-4r [%t] %-5p %x - %m%n" />  
  24.   </layout>  
  25.  </appender>   
  26.    
  27.  <appender name="DATABASE" class="org.apache.log4j.jdbc.JDBCAppender">  
  28.   <param name="URL" value="jdbc:oracle:thin:@192.168.0.59:1521:oanet"/>  
  29.   <param name="driver" value="oracle.jdbc.driver.OracleDriver"/>  
  30.   <param name="user" value="hdczoa"/>  
  31.   <param name="password" value="system"/>      
  32.   <layout class="org.apache.log4j.PatternLayout">  
  33.    <param name="ConversionPattern"  
  34.     value="INSERT INTO hdczoa.LOG4J(stamp,thread, info_level,class,message) VALUES ('%d', '%t', '%p', '%c', %m)" />  
  35.   </layout>  
  36.  </appender>  
  37.    
  38.  <!-- 发邮件(只有ERROR时才会发送!) -->  
  39.  <appender name="MAIL"  
  40.   class="org.apache.log4j.net.SMTPAppender">  
  41.   <param name="threshold" value="debug" />  
  42.   <!-- 日志的错误级别  
  43.    <param name="threshold" value="fatal"/>  
  44.   -->  
  45.   <!-- 缓存文件大小,日志达到512K时发送Email -->  
  46.   <param name="BufferSize" value="512" /><!-- 单位K -->  
  47.   <param name="From" value="test@163.com" />  
  48.   <param name="SMTPHost" value="smtp.163.com" />  
  49.   <param name="Subject" value="juyee-log4jMessage" />  
  50.   <param name="To" value="test@163.com" />  
  51.   <param name="SMTPUsername" value="test" />  
  52.   <param name="SMTPPassword" value="test" />  
  53.   <layout class="org.apache.log4j.PatternLayout">  
  54.    <param name="ConversionPattern"  
  55.     value="%-d{yyyy-MM-dd HH:mm:ss.SSS} [%p]-[%c] %m%n" />  
  56.   </layout>  
  57.  </appender>  
  58.   
  59.  <appender name="ASYNC" class="org.apache.log4j.AsyncAppender">  
  60.   <param name="BufferSize" value="256" />  
  61.   <appender-ref ref="DATABASE" />  
  62.  </appender>  
  63.    
  64.  <!--通过<logger></logger>的定义可以将各个包中的类日志输出到不同的日志文件中-->  
  65.  <logger name="com.litt2.log4j" additivity="false">     
  66.         <level value="WARN" />     
  67.         <appender-ref ref="CONSOLE" />     
  68.     </logger>  
  69.   
  70.  <!--通过<category></category>的定义可以将各个包中的类日志输出到不同的日志文件中-->  
  71.  <category name="com.litt3">     
  72.     <level value="DEBUG" />   
  73.        <appender-ref ref="CONSOLE" />  
  74.        <appender-ref ref="MAIL" />  
  75.   </category>  
  76.    
  77.  <root>  
  78.   <priority value="debug" />  
  79.   <appender-ref ref="CONSOLE" />  
  80.   <appender-ref ref="FILE" />  
  81.  </root>  
  82.   
  83.   
  84. </log4j:configuration> 
3、 接入log4j.xml的web.xml的配置:

Web配置log4j,需求增加以下内容到WEB-INF/web.xml
  <context-param>
        <param-name>webAppRootKey</param-name>
        <param-value>smilecargo.root</param-value>
    </context-param>
    <context-param>
        <param-name>log4jConfigLocation</param-name>
        <param-value>classpath:log4j.xml</param-value>
    </context-param>
    <context-param>
        <param-name>log4jRefreshInterval</param-name>
        <param-value>60000</param-value>
    </context-param>
  <listener>
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    </listener>
${smilecargo.root}是web工程相对路径


4、 接入log4j.xml参数配置说明:
  1.     <!-- ========================== 自定义输出格式说明================================ -->  
  2.     <!-- %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL -->  
  3.     <!-- #%r 输出自应用启动到输出该log信息耗费的毫秒数  -->  
  4.     <!-- #%c 输出所属的类目,通常就是所在类的全名 -->  
  5.     <!-- #%t 输出产生该日志事件的线程名 -->  
  6.     <!-- #%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n” -->  
  7.     <!-- #%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921  -->  
  8.     <!-- #%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)  -->  
  9.     <!-- ========================================================================== --> 

以上来自:http://www.cnblogs.com/tqsummer/archive/2010/08/26/1809232.html


5、 备注:

<logger name="com.runway.bssp.activeXdemo" additivity="false"> 
         <priority value ="info"/>    
</logger> 
调试时,加类似上面这个logger节点,可以定义只打印具体类,及莫个包下的日志

整合下供自己以后参考使用

将配置好的log4j.xml 放到项目的classpath下即可。我的是放在src下

 


[xhtml] view plain copy
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">  
  3. <log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'>  
  4.   
  5.     <!-- ========================== 自定义输出格式说明================================ -->  
  6.       <!-- %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL -->  
  7.       <!-- %r 输出自应用启动到输出该log信息耗费的毫秒数  -->  
  8.       <!-- %c 输出所属的类目,通常就是所在类的全名 -->  
  9.       <!-- %t 输出产生该日志事件的线程名 -->  
  10.       <!-- %n 输出一个回车换行符,Windows平台为“/r/n”,Unix平台为“/n” -->  
  11.       <!-- %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921  -->  
  12.       <!-- %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)  -->  
  13.       <!-- ========================================================================== -->  
  14.   
  15.       <!-- ========================== 输出方式说明================================ -->  
  16.       <!-- Log4j提供的appender有以下几种:  -->  
  17.       <!-- org.apache.log4j.ConsoleAppender(控制台),  -->  
  18.       <!-- org.apache.log4j.FileAppender(文件),  -->  
  19.       <!-- org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件), -->  
  20.       <!-- org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),  -->  
  21.       <!-- org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)   -->  
  22.   <!-- ========================================================================== -->  
  23.   
  24.   
  25.   <!-- 输出到日志文件  -->  
  26.     <appender name="log4jTestDebug" class="org.apache.log4j.RollingFileAppender">  
  27.         <param name="File" value="D:/work/log/test_log4j_debug.log"/>  
  28.         <param name="Append" value="true"/>  
  29.         <param name="MaxFileSize" value="5KB"/>  
  30.         <param name="MaxBackupIndex" value="2"/>  
  31.         <layout class="org.apache.log4j.PatternLayout">  
  32.             <param name="ConversionPattern" value="%c %d{ISO8601}-- %p -- %m%n"/>  
  33.         </layout>  
  34.         <filter class="org.apache.log4j.varia.LevelRangeFilter">  
  35.             <param name="LevelMin" value="DEBUG"/>  
  36.             <param name="LevelMax" value="DEBUG"/>  
  37.         </filter>  
  38.     </appender>  
  39.   
  40.         <appender name="log4jTestLogInfo" class="org.apache.log4j.RollingFileAppender">  
  41.         <param name="File" value="D:/work/log/test_log4j_info.log"/>  
  42.         <param name="Append" value="true"/>  
  43.         <param name="MaxFileSize" value="5KB"/>  
  44.         <param name="MaxBackupIndex" value="2"/>  
  45.         <layout class="org.apache.log4j.PatternLayout">  
  46.             <param name="ConversionPattern" value="%c %d{ISO8601}-- %p -- %m%n"/>  
  47.         </layout>  
  48.         <filter class="org.apache.log4j.varia.LevelRangeFilter">  
  49.             <param name="LevelMin" value="INFO"/>  
  50.             <param name="LevelMax" value="INFO"/>  
  51.         </filter>  
  52.   
  53.     </appender>  
  54.   
  55.   
  56.        <!--通过<category></category>的定义可以将各个包中的类日志输出到不同的日志文件中-->  
  57.         <category name="com.gzy">  
  58.             <priority value="debug" />  
  59.             <appender-ref ref="log4jTestLogInfo" />  
  60.             <appender-ref ref="log4jTestDebug" />  
  61.         </category>  
  62.       
  63.     <root>  
  64.         <priority value="debug"/>  
  65.     </root>  
  66. </log4j:configuration>  

 

 

下面写个测试类进行测试

 

  1. package com.gzy;  
  2.   
  3. import org.apache.log4j.Logger;  
  4.   
  5. /** 
  6.  * Created by IntelliJ IDEA. 
  7.  * User: zunyong 
  8.  * Date: 2011-4-27 
  9.  * Time: 16:54:44 
  10.  * To change this template use File | Settings | File Templates. 
  11.  */  
  12. public class Test {  
  13.   
  14.     private static final Logger log = Logger.getLogger(Test.class);  
  15.   
  16.     public static void main(String[] args) {  
  17.         for(int i=0;i<10;i++){  
  18.                 log.info("Enter the main()....");  
  19.           log.debug("Enter the main()....");  
  20.           log.warn("Enter the main()....");  
  21.           log.info("Enter the main()....");  
  22.         System.out.println("this is a log4j test.");  
  23.         log.info("log end.");  
  24.         }  
  25.   
  26.     }  
  27.   


  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
全书一共被压缩为5个rar,这是第三个!!!! 其他的请看ID:ljtt123(本人分享) 本博客提供的所有教程的资源原稿均来自于互联网,仅供学习交流之用,切勿进行商业传播。同时,转载时不要移除本申明。如产生任何纠纷,均与本博客所有人、发表该文献之人无任何关系。谢谢合作 本书共分4部分,从xml、servlet、jsp和应用的角度向读者展示了java web开发各种技术的应用,循序渐进地引导读者快速掌握java web开发。.   本书内容全面,涵盖了从事java web开发所应掌握的所有知识。在知识的讲解上,本书采用理论与实践相结合的方式,从程序运行的内部机制进行分析讲解,并通过大量的实例和实验来验证并运用本书的知识。.. 本书语言生动、通俗易懂、讲解细致,大部分章节都提供了多个例子,而且很多例子都是目前web开发经常使用的功能,具有相当的实用价值。本书不仅可以作为java web开发的学习用书,还可以作为从事java web开发的程序员的参考用书和必备手册。此外,本书的配套光盘还免费提供了价值人民币330元的java教学视频,对java语言进行了全面讲解,帮助一些不会java语言的读者快速地从java基础知识的学习过渡到java web的学习与开发上. 第1部分 xml篇. 第1章 xml与dtd 2 1.1 xml的产生 2 1.2 w3c介绍 2 1.3 关于xml的几个问题 3 1.4 xml与html的比较 4 1.4.1 xml将数据与显示分开 5 1.4.2 xml对文档的格式要求更加严格 6 1.4.3 xml有且只能有一个根元素 6 1.5 xml的编辑工具 7 1.6 xml文档 8 1.6.1 xml声明 9 1.6.2 文档类型声明 10 1.6.3 元素 11 1.6.4 注释 15 1.6.5 处理指令 15 1.6.6 空白处理 16 1.6.7 行尾处理 16 1.6.8 语言标识 16 1.7 格式良好的xml 17 .1.8 dtd 18 1.8.1 在xml文档引入dtd 18 1.8.2 dtd的结构 21 1.9 有效的xml 35 1.10 xml处理器/解析器 35 1.11 小结 36 第2章 xml名称空间 38 2.1 声明名称空间 38 2.2 名称空间在元素和属性的运用 39 2.2.1 名称空间在元素的运用 39 2.2.2 默认名称空间 41 2.2.3 名称空间在属性的运用 42 2.3 名称空间和dtd 43 2.4 小结 45 第3章 对xml文档进行分析 46 3.1 dom、sax和jaxp 46 3.2 使用dom解析xml文档 47 3.2.1 dom结构模型 47 3.2.2 dom解析器工厂 50 3.2.3 jaxp的错误类和异常类 52 3.2.4 用dom解析xml文档实例 53 3.3 使用sax解析xml文档 65 3.3.1 sax的处理机制 66 3.3.2 配置sax解析器 69 3.3.3 sax解析器工厂 70 3.3.4 sax的异常类 71 3.3.5 errorhandler接口 73 3.3.6 使用sax解析xml文档实例 74 3.4 jdom 83 3.4.1 下载并配置jdom 83 3.4.2 jdom api介绍 84 3.5 dom4j 88 3.5.1 下载并配置dom4j 88 3.5.2 dom4j api介绍 88 3.5.3 第一个实例 92 3.5.4 第二个实例 94 3.6 解析名称空间 96 3.6.1 dom和名称空间 96 3.6.2 sax和名称空间 97 3.6.3 jdom和名称空间 98 3.6.4 dom4j和名称空间 98 3.7 小结 99 第4章 xsl转换 101 4.1 xslt概述 101 4.2 xalan处理器 105 4.3 模板规则 106 4.4 [xsl:apply-templates]元素 107 4.5 [xsl:value-of]元素 108 4.6 [xsl:for-each]元素 110 4.7 匹配节点的模式 111 4.8 mode属性 113 4.9 内置的模板规则 114 4.10 对空白的处理 115 4.11 xpath语言 116 4.11.1 xpath上下文 116 4.11.2 位置路径 117 4.11.3 表达式 121 4.11.4 核心函数库 123 4.12 创建结果树 126 4.12.1 创建元素和属性 127 4.12.2 创建文本 131 4.12.3 创建处理指令 133 4.12.4 创建注释 133 4.12.5 复制节点 134 4.12.6 输出格式化的数字 135 4.13 条件处理 144 4.13.1 [xsl:if] 144 4.13.2 [xsl:choose] 145 4.14 排序 146 4.15 变量和参数 150 4.15.1 变量 150 4.15.2 参数 152 4.16 命名模板 153 4.17 合并样式表 154 4.17.1 导入样式表 154 4.17.2 包含样式表 155 4.18 模板规则冲突的解决 156 4.19 [xsl:output]元素 157 4.19.1 指定输出文档的格式 158 4.19.2 输出xml声明 158 4.19.3 输出文档类型定义 159 4.19.4 输出cdata段 160 4.19.5 指定文档缩进 161 4.19.6 指定媒体类型 161 4.20 xslt的函数 162 4.21 数字格式化 162 4.22 查询和分组 164 4.23 处理多个输入文档 172 4.24 jaxp的xslt api 175 4.24.1 转换器工厂 175 4.24.2 transformer和templates 176 4.24.3 一个例子 178 4.25 小结 179 第2部分 servlet篇 第5章 servlet与tomcat 182 5.1 servlet与servlet容器 182 5.2 servlet容器的分类 183 5.3 servlet和其他技术的比较 183 5.4 tomcat介绍 183 5.5 tomcat的安装与配置 184 5.5.1 安装tomcat 185 5.5.2 运行tomcat 186 5.5.3 tomcat启动分析 189 5.5.4 tomcat的体系结构 191 5.6 tomcat的管理程序 193 5.6.1 admin web应用程序 193 5.6.2 manager web应用程序 194 5.7 小结 195 第6章 servlet技术 196 6.1 servlet api 196 6.1.1 servlet接口 196 6.1.2 servlet相关接口与实现类 197 6.2 几个实例 205 6.2.1 实例一:simplehello 205 6.2.2 实例二:welcomeyou 210 6.2.3 实例三:outputinfo 216 6.2.4 实例四:loginservlet 220 6.3 servlet异常 223 6.3.1 servletexception类 224 6.3.2 unavailableexception类 224 6.4 servlet生命周期 224 6.5 servlet上下文 226 6.5.1 servletcontext接口 226 6.5.2 页面访问量统计实例 228 6.6 请求转发 231 6.6.1 requestdispatcher接口 232 6.6.2 得到requestdispatcher对象 232 6.6.3 请求转发的实例 233 6.6.4 sendredirect()和forward()方法的区别 238 6.7 小结 239 第7章 web应用程序的部署 240 7.1 配置任意目录下的web应用程序 240 7.2 war文件 242 7.3 tomcatservlet的另一种运行方式 244 7.4 与servlet配置相关的元素 247 7.4.1 [servlet]元素及其子元素 247 7.4.2 [servlet-mapping]元素及其子元素 249 7.5 一个实例 250 7.6 小结 253 第8章 数据库访问 254 8.1 驱动程序的类型 254 8.1.1 jdbc-odbc桥 254 8.1.2 部分本地api java驱动程序 255 8.1.3 jdbc网络纯java驱动程序 255 8.1.4 本地协议的纯java驱动程序 256 8.2 安装数据库 256 8.3 jdbc api 260 8.3.1 加载并注册数据库驱动 261 8.3.2 建立到数据库的连接 263 8.3.3 访问数据库 264 8.3.4 事务处理 289 8.3.5 可滚动和可更新的结果集 296 8.4 jdbc数据源和连接池 299 8.5 mysql对文的处理 302 8.6 小结 302 第9章 会话跟踪 303 9.1 用于会话跟踪的技术 303 9.1.1 ssl会话 304 9.1.2 cookies 304 9.1.3 url重写 305 9.2 java servlet api的会话跟踪 306 9.2.1 httpsession接口 306 9.2.2 session的生命周期 307 9.2.3 cookie的应用 319 9.2.4 httpsessionbindinglistener接口 328 9.2.5 在线人数统计程序 329 9.3 小结 335 第10章 servlet的异常处理机制 337 10.1 声明式异常处理 338 10.1.1 http错误代码的处理 338 10.1.2 java异常的处理 341 10.2 程序式异常处理 343 10.2.1 在try-catch语句处理异常 343 10.2.2 使用requestdispatcher来处理异常 346 10.3 小结 349 第11章 开发线程安全的servlet 350 11.1 多线程的servlet模型 350 11.2 线程安全的servlet 351 11.2.1 变量的线程安全 351 11.2.2 属性的线程安全 360 11.3 singlethreadmodel接口 362 11.4 小结 363 11.5 思考题 363 第3部分 jsp篇 第12章 jsp技术 366 12.1 jsp简介 366 12.2 jsp的运行机制 366 12.3 jsp的语法 371 12.3.1 指令元素(directive elements) 371 12.3.2 脚本元素(scripting elements) 374 12.3.3 动作元素(action elements) 376 12.3.4 注释 383 12.4 jsp的隐含对象 383 12.4.1 pagecontext 384 12.4.2 out 385 12.4.3 page 385 12.4.4 exception 386 12.5 对象和范围 387 12.6 留言板程序 389 12.7 留言板管理程序 397 12.8 jsp文档 402 12.8.1 jsp文档的标识 404 12.8.2 jsp文档的元素语法 404 12.9 小结 407 第13章 jsp与javabean 409 13.1 javabean简介 409 13.1.1 属性的命名 409 13.1.2 属性的类型 411 13.2 在jsp使用javabean 412 13.2.1 [jsp:usebean] 412 13.2.2 [jsp:setproperty] 413 13.2.3 [jsp:getproperty] 414 13.2.4 示例 414 13.3 网上书店程序 418 13.4 小结 440 第14章 jsp开发的两种模型 441 14.1 模型1 441 14.2 模型2 445 14.3 小结 449 第15章 标签库(tag library) 450 15.1 标签库api 450 15.1.1 标签的形式 451 15.1.2 tag接口 451 15.1.3 iterationtag接口 453 15.1.4 bodytag接口 454 15.2 标签库描述符 455 15.2.1 [taglib]元素 456 15.2.2 [validator]元素 457 15.2.3 [listener]元素 457 15.2.4 [tag]元素 458 15.2.5 [tag-file]元素 460 15.2.6 [function]元素 461 15.3 传统标签的开发 462 15.3.1 实例一:[hello]标签 462 15.3.2 实例二:[max]标签 465 15.3.3 实例三:[greet]标签 467 15.3.4 实例四:[switch]标签 469 15.3.5 实例五:[iterate]标签 473 15.4 简单标签的开发 479 15.4.1 simpletag接口 479 15.4.2 实例一:[welcome]标签 480 15.4.3 实例二:[max_ex]标签 481 15.5 小结 483 第16章 表达式语言(el) 484 16.1 语法 484 16.1.1 “[ ]”和“.”操作符 484 16.1.2 算术操作符 484 16.1.3 关系操作符 485 16.1.4 逻辑操作符 485 16.1.5 empty操作符 485 16.1.6 条件操作符 485 16.1.7 圆括号 486 16.1.8 操作符的优先级 486 16.2 隐含对象 486 16.3 命名变量 487 16.4 保留的关键字 488 16.5 函数 488 16.6 小结 489 第17章 jsp标准标签库(jstl) 490 17.1 jstl简介 490 17.2 配置jstl 491 17.3 core标签库 491 17.3.1 一般用途的标签 492 17.3.2 条件标签 496 17.3.3 迭代标签 498 17.3.4 url相关的标签 501 17.4 i18n标签库 506 17.4.1 国际化标签 506 17.4.2 格式化标签 511 17.5 sql标签库 520 17.5.1 [sql:setdatasource] 520 17.5.2 [sql:query] 521 17.5.3 [sql:param] 524 17.5.4 [sql:dateparam] 525 17.5.5 [sql:update] 526 17.5.6 [sql:transaction] 527 17.6 xml标签库 529 17.6.1 核心操作 529 17.6.2 流程控制 532 17.6.3 转换操作 536 17.7 functions标签库 539 17.7.1 fn:contains 539 17.7.2 fn:containsignorecase 539 17.7.3 fn:startswith 540 17.7.4 fn:endswith 541 17.7.5 fn:indexof 541 17.7.6 fn:replace 542 17.7.7 fn:substring 543 17.7.8 fn:substringbefore 544 17.7.9 fn:substringafter 544 17.7.10 fn:split 545 17.7.11 fn:join 546 17.7.12 fn:tolowercase 547 17.7.13 fn:touppercase 547 17.7.14 fn:trim 548 17.7.15 fn:escapexml 548 17.7.16 fn:length 549 17.8 小结 549 第18章 标签文件(tag files) 551 18.1 标签文件的语法 551 18.2 一个简单的标签文件 551 18.3 标签文件的隐含对象 554 18.4 标签文件的指令 555 18.4.1 tag指令 555 18.4.2 attribute指令 556 18.4.3 variable指令 557 18.5 标签文件实例讲解 558 18.5.1 实例一:[welcome]标签 558 18.5.2 实例二:[tohtml]标签 559 18.6 [jsp:invoke]动作元素 561 18.7 [jsp:dobody]动作元素 562 18.8 小结 562 第4部分 应用篇 第19章 使用log4j进行日志操作 564 19.1 log4j介绍 564 19.1.1 logger组件 564 19.1.2 appender组件 566 19.1.3 layout组件 567 19.2 使用log4j 568 19.3 log4j使用实例 572 19.4 ndc和mdc 585 19.5 小结 587 第20章 filter在web开发的应用 588 20.1 过滤器概述 588 20.2 filter api 589 20.2.1 filter接口 589 20.2.2 filterconfig接口 590 20.2.3 filterchain接口 590 20.3 过滤器的部署 591 20.4 过滤器的开发 592 20.5 对用户进行统一验证的过滤器 594 20.6 对请求和响应数据进行替换的 20.6 过滤器 600 20.7 小结 609 第21章 文乱码问题与国际化 610 21.1 文乱码问题产生的由来 610 21.1.1 常用字符集 610 21.1.2 对乱码产生过程的分析 612 21.2 文乱码问题的解决方案 614 21.3 使用过滤器解决文问题 616 21.4 让tomcat支持文文件名 620 21.5 国际化与本地化 621 21.5.1 locale 621.. 21.5.2 资源包 623 21.5.3 编写国际化的web应用程序 625 21.6 小结 629 第22章 使用jbuilder2005开发web 第22章 应用程序 630 22.1 jbuilder2005简介 630 22.2 集成开发环境介绍 631 22.2.1 菜单栏 631 22.2.2 主工具栏 632 22.2.3 工程工具栏和工程窗口 632 22.2.4 结构窗口 633 22.2.5 文件标签和内容窗口 634 22.2.6 文件视图标签 634 22.2.7 消息窗口 637 22.3 jbuilder2005的基本配置 638 22.3.1 配置jdk 638 22.3.2 配置web服务器 640 22.4 文件的上传和下载 642 22.4.1 基于表单的文件上传 642 22.4.2 文件上传格式分析 643 22.4.3 commons-fileupload组件 644 22.4.4 文件上传实例 646 22.4.5 文件下载实例 656 22.5 给图片添加水印和文字 664 22.6 小结 667 第23章 开发安全的web应用程序 668 23.1 概述 668 23.2 理解验证机制 669 23.2.1 http basic authentication 669 23.2.2 http digest authentication 670 23.2.3 https client authentication 670 23.2.4 form based authentication 671 23.3 声明式安全 671 23.3.1 [security-constraint]元素 671 23.3.2 [login-config]元素 673 23.3.3 基本验证的实现 674 23.3.4 基于表单验证的实现 676 23.3.5 使用数据库保存用户名和密码 678 23.4 程序式安全 682 23.5 sql注入攻击的防范 685 23.6 小结 687 第24章 web应用程序开发实例 688 24.1 图像的缩放 688 24.2 如何动态生成验证码 692 24.3 如何避免表单的重复提交 696 24.3.1 在客户端避免表单的重复提交 697 24.3.2 在服务器端避免表单的重复 24.3.2 提交 700 24.4 小结 706 第25章 使用ant辅助web应用程序 第25章 开发 707 25.1 ant介绍 707 25.2 安装并配置ant 708 25.2.1 下载并安装ant 708 25.2.2 设置ant的运行环境 708 25.3 编写ant的构建文件 709 25.3.1 准备工作 709 25.3.2 工程([project]) 712 25.3.3 目标([target]) 713 25.3.4 任务 714 25.3.5 path-like structures 728 25.3.6 引用(references) 729 25.4 部署到tomcat 730 25.5 运行ant 732 25.6 小结 732 第26章 xml和xslt在web开发的 第26章 应用 733 26.1 功能概述 733 26.2 程序设计 733 26.2.1 软件架构 733 26.2.2 页面设计 735 26.2.3 数据库设计 747 26.3 程序实现 749 26.3.1 org.sunxin.guestbook 749 26.3.2 org.sunxin.guestbook.beans 750 26.3.3 org.sunxin.guestbook.util 758 26.3.4 org.sunxin.guestbook.parser 762 26.3.5 org.sunxin.guestbook.controller 765 26.3.6 org.sunxin.guestbook.view 787 26.3.7 page.xsl 791 26.3.8 web.xml 797 26.3.9 context.xml 798 26.4 小结 798 附录a 快速掌握html 799 附录b 解析http 820 附录c server.xml文件 833 附录d web.xml文件 840 索引 852...
当在 MapReduce 使用 log4j 记录日志时,你需要在项目添加 log4j 依赖项,并创建一个 log4j.properties 或 log4j.xml 文件来配置日志记录。以下是一个示例 log4j.xml 配置文件: ```xml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false"> <appender name="consoleAppender" class="org.apache.log4j.ConsoleAppender"> <param name="Target" value="System.out"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} [%p] %m%n"/> </layout> </appender> <appender name="fileAppender" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="/path/to/your/log/file.log" /> <param name="MaxFileSize" value="10MB" /> <param name="MaxBackupIndex" value="5" /> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} [%p] %m%n"/> </layout> </appender> <logger name="org.apache.hadoop.mapreduce"> <level value="INFO"/> <appender-ref ref="consoleAppender"/> <appender-ref ref="fileAppender"/> </logger> <root> <priority value="INFO"/> <appender-ref ref="consoleAppender"/> <appender-ref ref="fileAppender"/> </root> </log4j:configuration> ``` 在这个示例配置,我们定义了两个 Appender:consoleAppender 和 fileAppender,分别将日志输出到控制台和文件。我们还定义了一个 logger,它将记录来自 org.apache.hadoop.mapreduce 包的 INFO 级别日志,并将其发送到 consoleAppender 和 fileAppender。最后,我们定义了 root logger,它将记录所有未指定 logger 的日志,并将其发送到 consoleAppender 和 fileAppender。 你需要将此文件放置在 MapReduce 项目的 classpath ,并在运行 MapReduce 作业时指定 log4j 配置文件的位置。例如,你可以使用以下命令来运行作业: ``` hadoop jar myjob.jar com.example.MyJob -Dlog4j.configuration=file:/path/to/your/log4j.xml input output ``` 其,-Dlog4j.configuration 参数指定 log4j 配置文件的位置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值