log4j中配置日志文件相对路径方法

从前做项目使用到了log4j,今天做一个项目又想用这个,都配置好以后,想把日志写到本地文件中保存,从前是把本地文件写到了C:/log.txt中,正好有时间就上网查了下更好的方法:

方法一:用相对路径代替绝对路径

    主要是扩展了log4j的RollingFileAppender类,其他的FileAppender同样道理。扩展的方法,就是用一个子类去覆盖setFile方法,这个方法在log4j读取配置文件生成appender的时候调用

,传入的就是配 置文件中的路径,这样我就可以按照自己的想法在路径前面加上根路径了。这种方法可以在log4j.properties中用相对路径自由配置log4j.appender.A1.File属性来决定生成的日

志相对web应用根目录的位置。

方法二:使用服务器环境变量

    是利用服务器vm中已经存在的环境变量如${catalina.home}来设置相对于${catalina.home}的日志路径,日志只能放到服务器子目录里,而且如果是用的其它服务器,则要改对应的环境变

量。此方法平台移植不方便。

方法三:通过servlet初始化init()方法中加载file属性实现相对路径

    是扩展ActionServlet类,覆盖其init()方法,新方法中载入log4j.properties位置的参数,可以自由配置log4j的配置文件的名字和存放位置。也可自由配置log4j日志文件的相对于当前应

用的路径。

总结了上面的三个方法,可取的是方法三,但是还是繁琐,要写个servlet,写一大堆代码。

下面这个方法比较实用我觉得,大家可以试下:

log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=..//webapps//bjjjpcDemo//logs//log.txt

#log4j.appender.file.File=../webapps/bjjjpcDemo/logs/log.txt
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

我测试了一下,默认生成的日志文件是在服务器的bin目录下(我使用的是Tomcat),这样通过相对路径 ..//webapps//项目名称//日志目录//日志文件(或../webapps/项目名称/日志目录/日志文件),就能在你的项目中自动建立日志目录和日志文件。

如果作为网页格式保存,就可以作为网页来访问了,就更好了,如下:

log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=..//webapps//bjjjpcDemo//logs//police.html

#log4j.appender.file.File=../webapps/bjjjpcDemo/logs/police.html
log4j.appender.file.layout=org.apache.log4j.HTMLLayout
log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值