1. 加入log4j和slf4j的jar包

2. web.xml:

  1. <context-param>
  2. <!--log4j配置地址 -->
  3. <param-name>log4jConfigLocation</param-name>
  4. <!-- <param-value>/WEB-INF/classes/log4j.properties</param-value> -->
  5. <param-value>classpath:log4j.properties</param-value>
  6. </context-param>
  7. <context-param>
  8. <!-- log4j 配置扫描刷新间隔 可以不用 -->
  9. <param-name>log4jRefreshInterval</param-name>
  10. <param-value>10000</param-value>
  11. </context-param>
  12. <!-- spring里的log4j配置监听器 -->
  13. <listener>
  14. <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
  15. </listener>

3. src/log4j.properties:

  1. ### set log levels ###
  2. log4j.rootLogger = debug,stdout,D,E
  3. ### 输出到控制台 ###
  4. log4j.appender.stdout = org.apache.log4j.ConsoleAppender
  5. log4j.appender.stdout.Target = System.out
  6. log4j.appender.stdout.Threshold = INFO
  7. log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
  8. log4j.appender.stdout.layout.ConversionPattern =  %d{ABSOLUTE} %5p %c{1}:%L - %m%n
  9. log4j.appender.stdout.Encoding=UTF-8
  10. ### 输出到日志文件 ###
  11. log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
  12. log4j.appender.D.File = ${ssh}WEB-INF/logs/debug.log
  13. log4j.appender.D.file.MaxFileSize=500KB
  14. log4j.appender.D.Append = true
  15. ##输出DEBUG级别以上的日志
  16. log4j.appender.D.Threshold = DEBUG
  17. log4j.appender.D.layout = org.apache.log4j.PatternLayout
  18. log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
  19. log4j.appender.D.Encoding=UTF-8
  20. ### 保存异常信息到单独文件 ###
  21. log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
  22. ## 异常日志文件名
  23. log4j.appender.E.File = ${ssh}WEB-INF/logs/error.log
  24. log4j.appender.E.file.MaxFileSize=500KB
  25. log4j.appender.E.Append = true
  26. ## 只输出ERROR级别以上的日志!!!
  27. log4j.appender.E.Threshold = ERROR
  28. log4j.appender.E.layout = org.apache.log4j.PatternLayout
  29. log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
  30. log4j.appender.E.Encoding=UTF-8

配置info级输出到控制台,debug和error 都输出到对应文件中。

4. 使用log对象

    1. import org.slf4j.Logger;
    2. import org.slf4j.LoggerFactory;
    3. import com.stone.action.DefaultAction;
    4. public class LogUtil {
    5. //使用slf4j创建日志对象,好处时,以后更换为其它日志工具时,只要修改配置文件,不用修改代码
    6. private static Logger logger = LoggerFactory.getLogger(LogUtil.class);
    7. //使用log4j创建日志对象
    8. //  private org.apache.log4j.Logger logger = org.apache.log4j.Logger.getLogger(getClass());
    9. public static void error(String message) {
    10. logger.error(message);
    11. }
    12. public static void debug(String message) {
    13. logger.debug(message);
    14. }
    15. public static void info(String message) {
    16. logger.info(message);
    17. //      org.apache.log4j.Logger.getLogger(LogUtil.class).info(message);
    18. }
    19. }

JavaEE SSH框架整合(四) 日志处理Spring结合 log4j、slf4j [转]的更多相关文章

  1. ssh 框架整合试例 (spring+struts2+hibernate)

    1.首先用Eclipse创建一个web项目(Eclipse EE 版) new->Other-> 输入web 然后选择Dynamic Web Project->next-> 输 ...

  2. JavaEE SSH框架整合(三) struts2 异常、http错误状态码处理

    struts2的action可能出现訪问不到,或action报异常等情况,所以须要作一些处理,给用户一个友好的印象. 1. 异常处理  result声明在action中 <action name ...

  3. Spring+Hibernate+Struts(SSH)框架整合

    SSH框架整合 前言:有人说,现在还是流行主流框架,SSM都出来很久了,更不要说SSH.我不以为然.现在许多公司所用的老项目还是ssh,如果改成流行框架,需要成本.比如金融IT这一块,数据库dao层还 ...

  4. MVC+Spring.NET+NHibernate .NET SSH框架整合 C# 委托异步 和 async /await 两种实现的异步 如何消除点击按钮时周围出现的白线? Linq中 AsQueryable(), AsEnumerable()和ToList()的区别和用法

    MVC+Spring.NET+NHibernate .NET SSH框架整合   在JAVA中,SSH框架可谓是无人不晓,就和.NET中的MVC框架一样普及.作为一个初学者,可以感受到.NET出了MV ...

  5. SSH框架整合过程总结

    ---------------------siwuxie095                                 SSH 框架整合过程总结         (一)导入相关 jar 包(共 ...

  6. SSH框架整合

    SSH框架整合 一.原理图 action:(struts2) 1.获取表单的数据 2.表单的验证,例如非空验证,email验证等 3.调用service,并把数据传递给service Service: ...

  7. ssh框架整合之登录以及增删改查

    1.首先阐述一下我用得开发工具,myeclipse2017+oracle,所以我的基本配置步骤可能不一样,下面我用几张图来详解我的开发步骤. ---1先配置structs (Target 选择apac ...

  8. SSH 框架整合总结

    1. 搭建Struts2 环境 创建 struts2 的配置文件: struts.xml; 在 web.xml 中配置 struts2 的核心过滤器; // struts.xml <?xml v ...

  9. SSH框架整合的其它方式

    --------------------siwuxie095 SSH 框架整合的其它方式 1.主要是整合 Spring 框架和 Hibernate 框架时,可以不写 Hibernate 核心配置文件: ...

随机推荐

  1. 数据库中 关于不能用in 不能用exist 等关键字 查询不出现字段的问题

    这是之前在网上见到的一道题,后来心里略微想了想 觉得应该可能,所以就一闪而过了,之前去面试晨光的时候面试者问了我这道问题,当时也只是把自己的想法说了一下,可能因为当时面试的感觉不太好,面试官也没有追究 ...

  2. 夺命雷公狗-----React---3--标签的规则

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 让DIV水平和垂直居中的几种方法

    我们在设计页面的时候,经常要把DIV居中显示,而且是相对页面窗口水平和垂直方向居中显示,如让登录窗口居中显示.我们传统解决的办法是用纯CSS来让DIV居中.在本文中,我将给大家讲述如何用CSS和jQu ...

  4. ifconfig

    虚拟机启动后发现ifconfig命令下,没有打印ip .用ifconfig eth0 up命令开启下网卡. #ifconfig eth0 up .更改eth0配置: #vi/etc/sysconfig ...

  5. Python之通过IP地址库获取IP地理信息

    利用第三方的IP地址库,各个公司可以根据自己的业务情况打造自己的IP地址采集分析系统.例如游戏公司可以采集玩家地区信息,进行有针对性的运营策略,还可能帮助分析玩家网络故障分布等等. #!/usr/bi ...

  6. 连续最短路算法(Successive Shortest Path)(最小费用最大流)

    #include <cstdio> #include <cstring> #include <queue> #include <vector> #inc ...

  7. 有向图的强连通分量——Tarjan

    在同一个DFS树中分离不同的强连通分量SCC; 考虑一个强连通分量C,设第一个被发现的点是 x,希望在 x 访问完时立刻输出 C,这样就可以实现 在同一个DFS树中分离不同的强连通分量了. 问题就转换 ...

  8. js关于函数调用

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  9. JavaEE程序员必读图书大推荐

    下面是我根据多年的阅读和实践经验,给您推荐的一些图书: 第一部分: Java语言篇 1 <Java编程规范> 星级: 适合对象:初级,中级 介绍:作者James Gosling(Java之 ...

  10. Spring 定时任务1

    转载自 http://blog.csdn.net/prisonbreak_/article/details/49180307 Spring配置文件xmlns加入 xmlns:task="ht ...