如何在Http Client 4.1中禁用log4j日志记录以登录到FileAppender

时间:2012-10-17 13:51:48

标签: java log4j httpclient

这是我的HTTP客户端的log4j配置:

log4j.appender.HTTPCLIENT_APPDR=com.xxx.log.FileAppender
log4j.appender.HTTPCLIENT_APPDR.File=${user.dir}/log/access.log
log4j.appender.HTTPCLIENT_APPDR.layout=org.apache.log4j.PatternLayout
log4j.appender.HTTPCLIENT_APPDR_APPDR.layout.ConversionPattern=%d{dd MMM yyyy HH:mm:ss SSS}ms %-5p [%t] - %m%n
log4j.appender.HTTPCLIENT_APPDR.MaxFileSize=20000KB
log4j.appender.HTTPCLIENT_APPDR.MaxBackupIndex=30
log4j.logger.org.apache.http=DEBUG,HTTPCLIENT_APPDR

我希望它根据我所处的环境关闭来自CODE的httpclient日志记录(我知道如何从log4j.properties中禁用它)。

我尝试插入这些行:

+    System.setProperty("log4j.logger.org.apache.http", "ERROR"); 

+    Logger.getLogger("log4j.logger.org.apache.http").setLevel(Level.off)

在我的应用程序开始时但它不起作用。

  1. Can I access the log4j properties from the System class?
  2. When I look at the Logger.getLogger("log4j.logger.org.apache.http") the level is null? Should it not be DEBUG?

What worked finally,

Logger.getLogger("log4j.logger.org.apache.http")

我没有使用正确的密钥。

问候,

2 个答案:

答案 0 :(得分:5)

终于有效了 Logger.getLogger( “org.apache.http”)setLevel(org.apache.log4j.Level.OFF)。 我没有使用正确的密钥。

答案 1 :(得分:2)

如果您有log4j.properties文件,请添加此行

log4j.logger.org.apache.http=WARN

仅在Apache HttpClient 4中测试