Spring-Log4J로 로깅

이것은 Spring 애플리케이션 내에서 매우 사용하기 쉬운 Log4J 기능입니다. 다음 예제는 Log4J와 Spring 간의 간단한 통합을 설명하는 간단한 단계를 안내합니다.

우리는 당신이 이미 가지고 있다고 가정합니다 log4J컴퓨터에 설치됩니다. 없는 경우 다음에서 다운로드 할 수 있습니다.https://logging.apache.org/임의의 폴더에서 압축 파일을 추출하기 만하면됩니다. 우리는log4j-x.y.z.jar 우리 프로젝트에서.

다음으로, 작동하는 Eclipse IDE를 준비하고 다음 단계를 수행하여 Spring Web Framework를 사용하여 동적 양식 기반 웹 애플리케이션을 개발해 보겠습니다.

단계 기술
1 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더.
2 Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가하십시오 .
Add External JARs를 사용하여 프로젝트에 log4j 라이브러리 log4j-xyzjar추가 합니다.
4 com.tutorialspoint 패키지 아래에 Java 클래스 HelloWorldMainApp을 만듭니다 .
5 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더.
6 아래에 log4j 구성 파일 log4j.properties를 만듭니다 .src 폴더.
7 마지막 단계는 모든 Java 파일과 Bean 구성 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다.

내용은 다음과 같습니다. HelloWorld.java 파일

package com.tutorialspoint;

public class HelloWorld {
   private String message;
   
   public void setMessage(String message){
      this.message  = message;
   }
   public void getMessage() {
      System.out.println("Your Message : " + message);
   }
}

다음은 두 번째 파일의 내용입니다. MainApp.java

package com.tutorialspoint;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.apache.log4j.Logger;

public class MainApp {
   static Logger log = Logger.getLogger(MainApp.class.getName());
   
   public static void main(String[] args) {
      ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
      log.info("Going to create HelloWord Obj");
      HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
      obj.getMessage();
      
      log.info("Exiting the program");
   }
}

당신은 생성 할 수 있습니다 debugerror정보 메시지를 생성 한 것과 유사한 방식으로 메시지를 보냅니다. 이제 내용을 보자Beans.xml 파일

<?xml version = "1.0" encoding = "UTF-8"?>

<beans xmlns = "http://www.springframework.org/schema/beans"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

   <bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld">
      <property name = "message" value = "Hello World!"/>
   </bean>

</beans>

다음은 내용입니다 log4j.properties Log4J가 로그 메시지를 생성하는 데 필요한 표준 규칙을 정의합니다.

# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
# Set the name of the file
log4j.appender.FILE.File=C:\\log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, overwrite
log4j.appender.FILE.Append=false

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 Eclipse 콘솔에 다음 메시지가 인쇄됩니다.

Your Message : Hello World!

C : \\ 드라이브를 확인하면 로그 파일을 찾을 수 있습니다. log.out 다음과 같은 다양한 로그 메시지와 함께-

<!-- initialization log messages -->

Going to create HelloWord Obj
Returning cached instance of singleton bean 'helloWorld'
Exiting the program

Jakarta Commons Logging (JCL) API

또는 사용할 수 있습니다 Jakarta Commons Logging (JCL)Spring 애플리케이션에서 로그를 생성하는 API입니다. JCL은 다음에서 다운로드 할 수 있습니다.https://jakarta.apache.org/commons/logging/. 이 패키지에서 기술적으로 필요한 유일한 파일은 commons-logging-xyzjar 파일입니다.이 파일 은 위의 예제에서 log4j-xyzjar 를 넣은 것과 비슷한 방식으로 클래스 경로에 배치해야합니다 .

로깅 기능을 사용하려면 org.apache.commons.logging.Log 객체 가 필요하며 요구 사항에 따라 다음 메소드 중 하나를 호출 할 수 있습니다.

  • 치명적 (개체 메시지)
  • error (객체 메시지)
  • 경고 (개체 메시지)
  • info (객체 메시지)
  • debug (객체 메시지)
  • trace (오브젝트 메시지)

다음은 JCL API를 사용하는 MainApp.java의 대체입니다.

package com.tutorialspoint;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.apache.commons.logging. Log;
import org.apache.commons.logging. LogFactory;

public class MainApp {
   static Log log = LogFactory.getLog(MainApp.class.getName());

   public static void main(String[] args) {
      ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
      log.info("Going to create HelloWord Obj");
      HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
      obj.getMessage();

      log.info("Exiting the program");
   }
}

프로그램을 컴파일하고 실행하기 전에 프로젝트에 commons-logging-xyzjar 파일을 포함했는지 확인해야합니다.

이제 위의 예에서 나머지 구성 및 콘텐츠를 변경하지 않고 유지하면서 애플리케이션을 컴파일하고 실행하면 Log4J API를 사용하여 얻은 것과 유사한 결과를 얻을 수 있습니다.