簡體   English   中英

如何為動態Web項目創建log4j.xml文件?

[英]How to create a log4j.xml file for the dynamic web project?

實際上,我正在嘗試為我的動態Web項目實現log4j.file。 這是我的web.xml

在這里,我僅給出了日志文件的web.xml代碼

web.xml中

<!-- Log File-->

<listener>
    <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
  </listener>
  <listener>
    <listener-class>com.ss.logFile.startupListener.StartupListener</listener-class>
  </listener>
  <context-param>
    <param-name>log4jConfigLocation</param-name>
    <param-value>/WEB-INF/classes/log4j.properties</param-value>
  </context-param>
</web-app>

log4j.properties

log4j.rootLogger=ERROR, stdout, rollingFile
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - <%m>%n
log4j.appender.rollingFile=org.apache.log4j.RollingFileAppender
log4j.appender.rollingFile.File=WEB-INF/logs/application.log
log4j.appender.rollingFile.MaxFileSize=512KB
log4j.appender.rollingFile.MaxBackupIndex=10
log4j.appender.rollingFile.layout=org.apache.log4j.PatternLayout
log4j.appender.rollingFile.layout.ConversionPattern=%d %p [%c] - %m%n
log4j.appender.rollingFile.Encoding=UTF-8

StartupListener

import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.log4j.Logger;
import org.apache.log4j.xml.DOMConfigurator;
@WebServlet("/StartupListener")
public class StartupListener extends HttpServlet implements ServletContextListener {
    private static final long serialVersionUID = 1L;

    public void init(ServletConfig config) throws ServletException {    
    }
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    }
    @Override
    public void contextDestroyed(ServletContextEvent arg0) {
    }
    @Override
    public void contextInitialized(ServletContextEvent sce) {
        java.util.logging.Logger logger = null;
        String log4jFile = sce.getServletContext().getInitParameter("log4jFileName");
        DOMConfigurator.configure(sce.getServletContext().getRealPath(log4jFile));
        logger = LogManager.getLogger(StartupListener.class.getName());
        logger.debug("Loaded: " + log4jFile);   
    }
}

先生,實際上我對log4j還是很陌生,所以我不怎么寫log4j.xml文件以及將文件放到哪里,請幫助我解決這個問題。

使用此鏈接http://www.mkyong.com/struts2/struts-2-log4j-integration-example/此鏈接將為您提供使用log4j的完整信息

根據您發布的配置。 您不使用xml,而是使用屬性文件。 正如Adam Dyga所說的,只要log4j.properties文件位於類路徑中,它將由應用程序自動拾取。 您無需顯式加載。 要設置日志文件的位置,

log4j.appender.rollingFile.file=D:/MyWEBLogs/MyWEB.log

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM