从前做项目使用到了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