使用Log4j进行日志打印流程

当我们需要在项目中打印日志并输出到指定的日志文件中时,我们需要进行配置log4j进行日志的打印。

步骤如下:

1、引入约束

   如果是动态web工程需要引入如下两个jar包:

    commons-logging-版本号.jar

  log4j-版本号.jar

    如果是maven工程 需要在pom中引入如下两个约束:

<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>
<dependency>
    <groupId>commons-logging</groupId>
    <artifactId>commons-logging</artifactId>
    <version>1.1.1</version>
</dependency>
2、log4j.properties配置文件的加载

当在项目中引入了如上两个约束后,项目启动后,会在开发路径下:resources下,项目部署后classes路径下自动寻找配置文件log4j.properties

如果想要自定义log4j.properties配置文件位置,需要在web.xml中添加log4j的监听。

<!-- 配置log4j配置文件路径 -->  
    <context-param>  
        <param-name>log4jConfigLocation</param-name>  
        <param-value>classpath:log4j.properties</param-value>  
    </context-param>  
    <!-- 60s 检测日志配置 文件变化 -->  
    <context-param>  
        <param-name>log4jRefreshInterval</param-name>  
        <param-value>60000</param-value>  
    </context-param>  
  
    <!-- 配置Log4j监听器 -->  
    <listener>  
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>  
    </listener>  
3、log4j文件的编写

demo:

log4j.rootLogger=error,Console

log4j.logger.org.hibernate.type.descriptor.sql.BasicBinder=TRACE
#log4j.logger.org.hibernate.type.descriptor.sql.BasicExtractor=TRACE
log4j.logger.org.hibernate.tool.hbm2ddl=DEBUG
#log4j.logger.org.hibernate.SQL=DEBUG

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=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n

log4j.appender.OneFile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.OneFile.File=../logs/AI_COMM_MANAGER.log
log4j.appender.OneFile.DatePattern = '.'yyyy-MM-dd
log4j.appender.OneFile.Threshold=ALL
log4j.appender.OneFile.layout=org.apache.log4j.PatternLayout
log4j.appender.OneFile.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n

log4j.logger.MyScan=DEBUG,scan
log4j.additivity.MyScan=false
log4j.appender.scan=org.apache.log4j.DailyRollingFileAppender
log4j.appender.scan.File=../logs/scan.log
log4j.appender.scan.DatePattern = '.'yyyy-MM-dd
log4j.appender.scan.Threshold=ALL
log4j.appender.scan.layout=org.apache.log4j.PatternLayout
log4j.appender.scan.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n

log4j.logger.Count=DEBUG,count
log4j.additivity.Count=false
log4j.appender.count=org.apache.log4j.RollingFileAppender
log4j.appender.count.File=../logs/count.log
log4j.appender.FILE.MaxFileSize=10MB  
log4j.appender.FILE.Append = true 
log4j.appender.count.Threshold=ALL
log4j.appender.count.layout=org.apache.log4j.PatternLayout
log4j.appender.count.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n

rootLogger参数配置的后面两个表示输出位置

也可以通过log4j.logger.自定义log名字=日志等级,名字

在代码里面通过名字获取指定的log对象,打印到自定义的日志文件中

4、Log在java代码中的使用
private final static Log logger = LogFactory.getLog("Http");

注意导包一定是 apache.commons.logging下的包

备注:打印日志的工具类 还有logback等,很多,很杂,但是apache的log很经典,很好用

也可以参考 https://blog.youkuaiyun.com/qq_37733625/article/details/79046227


需求说明 (1使用UserDaoImp1类的方法查找用户,并用User类的getUserInfo()方法输出用户信息 (2使用一个不存在的用户名查找用户,使用try-catch对抛出的异常进行处理 实现思路及关键代码 (1)在测试类中调用UserDaoImp类的addUser(User user)方法,添加用户,然后用findUser(String uName)方法查找并输出用户信息 (2)在测试类中调用UserDaoImp1类的findUser(String uName)方法,使用不存在的用户名查找用户,并试图输出用户信息 (3)对抛出的异常使用try-catch进行异常处理。 实践二:使用try-catch-finally进行异常处理 需求说明 (1)对实践1的异常使用try-catch-finally进行异常处理 (2)在finally块输出是否抛出了异常 实现思路及关键代码 (1)在任务一中的代码上增加finally块 (2)为了判断在finally块输出是否抛出异常,可以设置一个变量,在catch块里修改这个变量 实践三:使用throw和throws 需求说明 修改UserDaoImpl类的updateUser(User user)方法,要求如果用户id被修改,则: (1)不执行更新 (2)抛出一个Exception异常 (3)异常消息是“用户id不能修改” 实现思路及关键代码 (1)修改UserDao类的updateUser(User user)方法,声明抛出异常 (2)修改UserDaoImpl类的updateUser(User user)方法,加入判断语句,并抛出异常 (3)在测试类中调用,并进行异常处理 实践四:使用log4j 需求说明 (1使用log4j输出日志信息 (2)查看输出日志信息
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值