springMVC集成log4j

log4j的使用非常简单,简单三步就ok。

Log4j所需的jar包:commons-logging.jar和log4j.jar。

Jar包下载地址:http://download.csdn.net/detail/qq_33556185/9568809

(一)写log4j.properties:

#设置日志等级及目的地

log4j.rootLogger=ERROR,Console,File

#输出到控制台

log4j.appender.Console=org.apache.log4j.ConsoleAppender

log4j.appender.Console.Target=System.out

#日志输出格式

log4j.appender.Console.layout = org.apache.log4j.PatternLayout

log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n

#输出到文件(tomcat\bin\logs\springMVC.log)

log4j.appender.File = org.apache.log4j.RollingFileAppender

log4j.appender.File.File = logs/springMVC.log

#日志文件最大值

log4j.appender.File.MaxFileSize = 1000MB

#日志输出门槛

log4j.appender.File.Threshold = WARN

log4j.appender.File.layout = org.apache.log4j.PatternLayout

log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n

#输出级别,共有5级:

#FATAL 致命错误

#ERROR 严重警告

#WARN 一般警告

#INFO 普通信息

#DEBUG 调试信息

#Appender 为日志输出目的地,Log4j提供的appender有以下几种

#org.apache.log4j.ConsoleAppender(控制台),

#org.apache.log4j.FileAppender(文件),

#org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),

#org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),

#org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

#Layout:日志输出格式,Log4j提供的layout有以下几种:

#org.apache.log4j.HTMLLayout(以HTML表格形式布局),

#org.apache.log4j.PatternLayout(可以灵活地指定布局模式),

#org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),

#org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

#打印参数: Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,如下:

#%m输出代码中指定的消息

#%p输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL

#%r输出自应用启动到输出该log信息耗费的毫秒数

#%c输出所属的类目,通常就是所在类的全名

#%t输出产生该日志事件的线程名

#%n输出一个回车换行符,Windows平台为“/r/n”,Unix平台为“/n”

#%d输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss ,SSS},

#%l输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。

(二)和spirng集成:

在web.xml里加载log4j的配置文件,并配置监听

     <context-param>  
         <param-name>webAppRootKey</param-name>  
         <param-value>springMVC</param-value>  
   </context-param> 
     <!-- 加载log4j配置文件 -->
      <context-param>
          <param-name>log4jConfigLocation</param-name>
          <param-value>/WEB-INF/classes/log4j.properties</param-value>
    </context-param>
    <!--log4jRefreshInterval为100000表示 开一条watchdog线程每10秒扫描一下配置文件的变化;   -->
      <context-param>
          <param-name>log4jRefreshInterval</param-name>
          <param-value>100000</param-value>
      </context-param>
     <!-- 1. 动态的改变记录级别和策略,不需要重启Web应用; 2. 把log文件定在 /WEB-INF/logs/ 而不需要写绝对路径。 -->
      <listener>
          <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
      </listener>

(三)使用log4j打印日志:

1)获得logger的副本(参数是类的class对象)

private static final Logger logger=Logger.getLogger(Test.class);

2)打印日志

logger.fatal("有一个致命错误:");

logger.error("有一个严重警告:");

logger.warn("有一个警告:");

logger.info("有一个普通信息:");

logger.debug("有一个调试信息:");

tips:

需要注意的一点是要是tomcat下部署了多个应用,同时都使用了org.springframework.web.util.Log4jConfigListener,

那需要设置webAppRootKey,否则因为多个同样的webAppRootKey的Log4jConfigListener的多个线程会冲突,而导致应用启动失败。

时间: 2024-07-29 11:12:23

springMVC集成log4j的相关文章

SSH集成log4j日志环境

第一步:在web.xml初始化log4j <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext.xml</param-value> </context-param> <context-param> <param-name>log4jConfigLocatio

Springmvc集成Shiro实现权限管理

Shiro是一个安全框架,他可以集成其他开发开发框架 如:Springmvc,实现用户身份认证.权限管理等等功能,shiro详细的介绍也就不讲了,这里给出一些关键的知识点吧: 知识点: shiro中默认的过滤器 过滤器名称 过滤器类 描述 anon org.apache.shiro.web.filter.authc.AnonymousFilter 匿名过滤器 authc org.apache.shiro.web.filter.authc.FormAuthenticationFilter 如果继续

spring+springMVC集成(annotation方式)

spring+springMVC集成(annotation方式) SpringMVC+Spring4.0+Hibernate 简单的整合 MyBatis3整合Spring3.SpringMVC3

springMVC系列之(三) spring+springMVC集成(annotation方式)

个人认为使用框架并不是很难,关键要理解其思想,这对于我们提高编程水平很有帮助.不过,如果用都不会,谈思想就变成纸上谈兵了!!!先技术,再思想.实践出真知. 1.基本概念 1.1.Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One J2EE Development and Design中阐述的部分理念和原型衍生而来.它是为了解决企业应用开发的复杂性而创建的.Spring使用

java工程集成log4J

log4j是Java开发平台中的日志管理工具,是Apache基金会的一个开源项目,它的作用可以简单的理解为在开发过程中替代system.out的功能. 1.在工程中集成log4j: (1)在官网http://logging.apache.org/log4j/2.x/download.html中下载jar包并添加到build path中 (2)修改配置文件log4j.properties,可以百度一下,这种资源很多,我的配置文件如下: log4j.rootLogger =DEBUG,console

SpringMVC集成Hessian

SpringMVC集成Hessian 首先强调这里是SpringMVC,不是Spring,这两者在集成Hessian的时候还是有差别的.Spring集成相对简单,网上随便搜一个就行. SpringMVC有点麻烦. 注:如果你还不了解Hessian,可以看Hessian简单示例 前提条件 假设你的SpringMVC环境已经配置了好了. 主要是在web.xml中有了如下的配置: <servlet> <!-- 名字随便,和你springmvc的配置xml一致即可 --> <serv

SpringMVC集成rabbitmq:优化秒杀下单环节

前言 上一篇在springboot中基于自动配置集成了rabbitmq.那么回到最初的话题中就是想在秒杀下单环节增加排队机制,从而达到限流的目的. 优化秒杀下单流程 之前是在控制器里拿到客户端请求后直接入库.减库存.如果碰到羊毛党其实这套机制是不行的.并发量高的时候,库存数量也会不准确.那么引入rabbitmq则在下单时让用户信息产生一条消息入队.然后消费者处理下单(是否重复下单.下单失败.库存不够).客户端接受到请求已入队列(response引入state处理交互)后发起ajax轮询请求,处理

springmvc集成shiro登录失败处理

一般的登录流程会有:用户名不存在,密码错误,验证码错误等.. 在集成shiro后,应用程序的外部访问权限以及访问控制交给了shiro来管理. shiro提供了两个主要功能:认证(Authentication)和授权(Authorization);认证的作用是证明自身可以访问,一般是用户名加密码,授权的作用是谁可以访问哪些资源,通过开发者自己的用户角色权限系统来控制. shiro的会话管理和缓存管理不在本文范围内. 下面通过登录失败的处理流程来介绍springmvc与shiro的集成. 项目依赖:

SpringMVC集成RSA加密算法

技术交流群: 233513714 本文介绍的是RSA加密算法+Spring Security在SpringMVC中的集成使用. Spring Security是什么? 引用: Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架.它提供了一组可以在Spring应用上下文中配置的Bean,充分利用了Spring IoC,DI(控制反转Inversion of Control ,DI:Dependency Injection 依赖注入)和