如何在web.xml和log4j.properties中配置log4j输出文件路径?

Thi*_*ker 7 debugging configuration web.xml log4j properties-file

我开发了一个Web应用程序,我可以在其中注册一名员工.

我的 web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">

  <display-name>Employee Registration</display-name>

  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>

  <servlet>
  <servlet-name>sapient</servlet-name>
  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
  <servlet-name>sapient</servlet-name>
  <url-pattern>*.htm</url-pattern>
  </servlet-mapping>

</web-app>
Run Code Online (Sandbox Code Playgroud)

现在,当我点击Register我的html页面中的一个按钮时.它转到一个控制器类,我已经编写了一个用于记录的代码,

@org.springframework.stereotype.Controller
public class RegController  {
    private static final Logger LOGGER = Logger
            .getLogger(RegController.class.getName());


@RequestMapping(value = "/register.htm", method = RequestMethod.GET)
public ModelAndView handleRequest(HttpServletRequest request,
        HttpServletResponse response) throws Exception {
    LOGGER.debug("ENTERING the contoller class");
    ModelAndView mav = new ModelAndView("register");
    LOGGER.debug("exiting the contoller class");
    return mav;

}
Run Code Online (Sandbox Code Playgroud)

}

我创建了一个名为的包,resource并在其中创建了一个log4j.properties文件

# Direct log messages to a log file
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=C:\\loging.log
log4j.appender.file.MaxFileSize=1MB
log4j.appender.file.MaxBackupIndex=1
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
Run Code Online (Sandbox Code Playgroud)

但我的日志不是在C:驱动器中创建的.

我需要在web.xml中配置一些东西吗?我已经包含了log4j.jar文件.

小智 9

你需要包括 -

    <context-param>
        <param-name>log4jConfigLocation</param-name>
        <param-value>/WEB-INF/resource/log4j.properties</param-value>
    </context-param>

     <listener>
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    </listener>
Run Code Online (Sandbox Code Playgroud)

在你的web.xml中.然后它会正常工作.


Adr*_*hum 2

你的问题与 Spring MVC 无关。这只是一个 Log4J 配置问题。(请编辑您的问题)

您是否正确设置了记录器?(例如允许调试级别,并将file附加程序设置为记录器)

在你的配置中有这样的东西(我只是凭记忆回忆语法,如果有什么问题请自行修复)

log4j.rootLogger.level=INFO, file
log4j.logger.your.package.RegController=DEBUG
Run Code Online (Sandbox Code Playgroud)

类似的事情。

另外,请确保类路径中没有其他 log4j.properties 或 log4j.xml。Log4J 可能会加载它们而不是您的,这导致了问题。