关于Hibernate slf4j与log4j 日志不起作用的解决办法

本文介绍了当Hibernate整合Slf4j和Log4j时日志无法正常显示的原因,包括classpath下错误的slf4j-nop jar包未移除以及版本不匹配的问题,并提供了相应的解决办法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


不起作用的原因有如下几点

1:Classpath下没有把slf4j-nop的jar包移除,slf4j-nop 和 log4j都是slf下的实现。使用log4j是记得把slf4j-nop移除就行了。

2:所需要的包版本不对应,这点可能很多人都不注意到,用slf4j-api-1.5.11.zip,但你用的转换包却是slf4j-log4j12-1.5.8.jar,就会不起作用,本人也是没注意浪费了很多时间


我的Slf4j+Log4j的组合

  • slf4j-api-1.5.8.jar
  • slf4j-log4j12-1.5.8.jar
  • log4j-1.2.15.jar
  • log4j.properties

    如需要,可到我网盘下载slf4j转log4j所需的包 

    ------------------------------------------------------------

    附上 log4j.properties 配置文件信息,以下是我的配置

    ### direct log messages to stdout ###
    log4j.appender.stdout=org.apache.log4j.ConsoleAppender
    log4j.appender.stdout.Target=System.out
    log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
    log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
    
    ### direct messages to file hibernate.log ###
    #log4j.appender.file=org.apache.log4j.FileAppender
    #log4j.appender.file.File=hibernate.log
    #log4j.appender.file.layout=org.apache.log4j.PatternLayout
    #log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
    
    ### set log levels - for more verbose logging change 'info' to 'debug' ###
    
    log4j.rootLogger=warn, stdout
    
    #log4j.logger.org.hibernate=info
    #log4j.logger.org.hibernate=debug
    
    ### log HQL query parser activity
    #log4j.logger.org.hibernate.hql.ast.AST=debug
    
    ### log just the SQL
    #log4j.logger.org.hibernate.SQL=debug
    
    ### log JDBC bind parameters ###
    #log4j.logger.org.hibernate.type=info
    #log4j.logger.org.hibernate.type=debug
    
    ### log schema export/update ###
    log4j.logger.org.hibernate.tool.hbm2ddl=debug
    
    ### log HQL parse trees
    #log4j.logger.org.hibernate.hql=debug
    
    ### log cache activity ###
    #log4j.logger.org.hibernate.cache=debug
    
    ### log transaction activity
    #log4j.logger.org.hibernate.transaction=debug
    
    ### log JDBC resource acquisition
    #log4j.logger.org.hibernate.jdbc=debug
    
    ### enable the following line if you want to track down connection ###
    ### leakages when using DriverManagerConnectionProvider ###
    #log4j.logger.org.hibernate.connection.DriverManagerConnectionProvider=trace
    




  • slf4j-api-1.5.11.jar
  • slf4j-log4j12-1.5.11.jar
  • log4j-1.2.15.jar
  • log4j.properties(也可以是 log4j.xml,本例中用 log4j.propertes)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值