स्प्रिंग - लॉग 4 जे के साथ लॉगिंग

यह स्प्रिंग अनुप्रयोगों के अंदर एक बहुत ही आसान उपयोग लॉग 4 जे कार्यक्षमता है। निम्नलिखित उदाहरण आपको Log4J और स्प्रिंग के बीच सरल एकीकरण की व्याख्या करने के लिए सरल चरणों के माध्यम से ले जाएगा।

हम मानते हैं कि आपके पास पहले से ही है log4Jआपकी मशीन पर स्थापित है। अगर आपके पास नहीं है तो आप इससे डाउनलोड कर सकते हैंhttps://logging.apache.org/और बस किसी भी फ़ोल्डर में ज़िपित फ़ाइल निकालें। हम ही उपयोग करेंगेlog4j-x.y.z.jar हमारे प्रोजेक्ट में।

इसके बाद, हमारे पास कार्यशील ग्रहण आईडीई है और डायनेमिक फॉर्म-आधारित वेब एप्लिकेशन विकसित करने के लिए निम्नलिखित कदम उठाएं।

कदम विवरण
1 SpringExample नाम से एक प्रोजेक्ट बनाएँ और के तहत एक पैकेज com.tutorialspoint बनाएँsrc बनाया परियोजना में फ़ोल्डर।
2 स्प्रिंग हैलो वर्ल्ड उदाहरण अध्याय में बताए अनुसार बाहरी जार विकल्प का उपयोग करके आवश्यक स्प्रिंग लाइब्रेरी जोड़ें
3 Add बाह्य JAR का उपयोग करके अपने प्रोजेक्ट में log4j लाइब्रेरी log4j-xyzjar जोड़ें
4 Com.tutorialspoint पैकेज के तहत Java कक्षाएं HelloWorld और MainApp बनाएं ।
5 के तहत बीन्स कॉन्फ़िगरेशन फ़ाइल Beans.xml बनाएँsrc फ़ोल्डर।
6 के तहत log4J विन्यास फाइल log4j.properties बनाएँsrc फ़ोल्डर।
7 अंतिम चरण सभी जावा फ़ाइलों और बीन कॉन्फ़िगरेशन फ़ाइल की सामग्री बनाना और नीचे बताए अनुसार एप्लिकेशन चलाना है।

यहाँ की सामग्री है 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");
   }
}

आप उत्पन्न कर सकते हैं debug तथा errorसंदेश उसी तरह से जैसे हमने सूचना संदेश उत्पन्न किया है। अब हम सामग्री देखते हैं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

एक बार जब आप स्रोत और बीन विन्यास फाइल बनाने के साथ हो जाते हैं, तो हम एप्लिकेशन चलाते हैं। यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित संदेश को ग्रहण कंसोल में प्रिंट करेगा -

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

जकार्ता कॉमन्स लॉगिंग (JCL) एपीआई

वैकल्पिक रूप से आप उपयोग कर सकते हैं Jakarta Commons Logging (JCL)एपीआई अपने वसंत आवेदन में एक लॉग उत्पन्न करने के लिए। JCL से डाउनलोड किया जा सकता हैhttps://jakarta.apache.org/commons/logging/। इस पैकेज से तकनीकी रूप से हमें जो एकमात्र फ़ाइल चाहिए, वह कॉमन्स-लॉगिंग-xyzjar फ़ाइल है, जिसे आपके क्लासपाथ में उसी तरह से रखा जाना चाहिए, जैसा आपने उपरोक्त उदाहरण में log4j-xyzjar डाला था ।

लॉगिंग कार्यक्षमता का उपयोग करने के लिए आपको org.apache.commons.log.Log ऑब्जेक्ट की आवश्यकता होती है और फिर आप अपने अनुरोध के अनुसार निम्न विधियों में से एक को कॉल कर सकते हैं -

  • घातक (वस्तु संदेश)
  • त्रुटि (वस्तु संदेश)
  • चेतावनी (वस्तु संदेश)
  • जानकारी (वस्तु संदेश)
  • डीबग (ऑब्जेक्ट संदेश)
  • ट्रेस (वस्तु संदेश)

निम्नलिखित MainApp.java का प्रतिस्थापन है, जो JCL API का उपयोग करता है

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");
   }
}

आपको यह सुनिश्चित करना होगा कि आपने प्रोग्राम को संकलित करने और चलाने से पहले कॉमन्स-लॉगिंग-xyzjar फ़ाइल को अपनी परियोजना में शामिल किया है।

अब उपरोक्त विन्यास में शेष विन्यास और सामग्री को अपरिवर्तित रखते हुए, यदि आप अपने आवेदन को संकलित करते हैं और चलाते हैं, तो आपको वैसा ही परिणाम मिलेगा जैसा कि आपको Log4J API का उपयोग करके मिला है।