Dan*_*Man 12 java logging log4j
我目前正在开发一个Java项目,我们正在使用日志记录.创建日志时,无论日志记录级别如何(INFO,ERROR等),它始终以纯黑色文本打印.
如何覆盖这些输出的颜色,例如所有ERROR日志都是红色,而所有WARN日志都是橙色等.
谢谢
编辑:我设法下载ANSIColorLayout文件,我的log4j.properties现在引用它.但是我收到以下错误:
log4j:WARN No such property [all] in org.apache.log4j.ConsoleAppender.
log4j:WARN No such property [reset] in org.apache.log4j.ConsoleAppender.
log4j:WARN No such property [stacktrace] in org.apache.log4j.ConsoleAppender.
log4j:WARN No such property [info] in org.apache.log4j.ConsoleAppender.
log4j:WARN No such property [error] in org.apache.log4j.ConsoleAppender.
log4j:WARN No such property [defaultcolor] in org.apache.log4j.ConsoleAppender.
Run Code Online (Sandbox Code Playgroud)
我的log4j.properties文件如下所示:
log4j.rootLogger = DEBUG, CA, FA
log4j.appender.CA = org.apache.log4j.ConsoleAppender
log4j.appender.CA.layout = balle.logging.ANSIColorLayout
log4j.appender.CA.layout.ConversionPattern=%-5p [%d{MM-dd-yyyy HH:mm:ss}] %c - %m%n
log4j.appender.CA.all=\u001B[1;37m log4j.appender.A1.fatal=\u001B[1;31m
log4j.appender.CA.error=\u001B[0;31m log4j.appender.A1.warn=\u001B[1;33m
log4j.appender.CA.info=\u001B[0;37m log4j.appender.A1.debug=\u001B[0;36m
log4j.appender.CA.reset=\u001B[1;37m
log4j.appender.CA.stacktrace=\u001B[0;31m
log4j.appender.CA.defaultcolor=\u001B[1;37m
Run Code Online (Sandbox Code Playgroud)
我的猜测是我应该使用自己的自定义ConsoleAppender?有没有人有任何想法?
谢谢
您可以下载各种ANSIColorLayout.java实现之一.这些"颜色记录器"通过扩展PatternLayout类来工作.
然后你可以在你的log4j conf中做这样的事情:
log4j.appender.stdout.layout=com.acme.ANSIColorLayout
Run Code Online (Sandbox Code Playgroud)
这是一个准备使用的ANSIColorLayout.java的链接:
| 归档时间: |
|
| 查看次数: |
15907 次 |
| 最近记录: |