स्प्रिंग बूट - त्वरित गाइड

स्प्रिंग बूट एक खुला स्रोत जावा-आधारित ढांचा है जिसका उपयोग माइक्रो सेवा बनाने के लिए किया जाता है। इसे Pivotal Team द्वारा विकसित किया गया है और इसका उपयोग स्टैंड-अलोन और प्रोडक्शन रेडी स्प्रिंग अनुप्रयोगों के निर्माण के लिए किया जाता है। यह अध्याय आपको स्प्रिंग बूट का परिचय देगा और आपको इसकी मूल अवधारणाओं से परिचित कराएगा।

माइक्रो सर्विस क्या है?

माइक्रो सेवा एक वास्तुकला है जो डेवलपर्स को स्वतंत्र रूप से सेवाओं को विकसित करने और तैनात करने की अनुमति देती है। चलने वाली प्रत्येक सेवा की अपनी प्रक्रिया होती है और यह व्यावसायिक अनुप्रयोगों का समर्थन करने के लिए हल्के मॉडल को प्राप्त करती है।

लाभ

सूक्ष्म सेवाएं अपने डेवलपर्स को निम्नलिखित लाभ प्रदान करती हैं -

  • आसान तैनाती
  • सरल मापनीयता
  • कंटेनर के साथ संगत
  • न्यूनतम विन्यास
  • उत्पादन का कम समय

स्प्रिंग बूट क्या है?

स्प्रिंग बूट जावा डेवलपर्स के लिए एक स्टैंड-अलोन और प्रोडक्शन-ग्रेड स्प्रिंग एप्लिकेशन विकसित करने के लिए एक अच्छा मंच प्रदान करता है जो आप कर सकते हैं just run। आप पूरे स्प्रिंग कॉन्फ़िगरेशन सेटअप की आवश्यकता के बिना न्यूनतम कॉन्फ़िगरेशन के साथ आरंभ कर सकते हैं।

लाभ

स्प्रिंग बूट अपने डेवलपर्स के लिए निम्नलिखित लाभ प्रदान करता है -

  • वसंत अनुप्रयोगों को समझने और विकसित करने में आसान
  • उत्पादकता बढ़ाता है
  • विकास के समय को कम करता है

लक्ष्य

स्प्रिंग बूट निम्नलिखित लक्ष्यों के साथ बनाया गया है -

  • वसंत में जटिल XML कॉन्फ़िगरेशन से बचने के लिए
  • एक आसान तरीके से उत्पादन तैयार स्प्रिंग अनुप्रयोगों को विकसित करने के लिए
  • विकास के समय को कम करने और स्वतंत्र रूप से एप्लिकेशन को चलाने के लिए
  • आवेदन के साथ आरंभ करने का एक आसान तरीका प्रदान करें

स्प्रिंग बूट क्यों?

आप यहां दिए गए फीचर्स और फायदों की वजह से स्प्रिंग बूट चुन सकते हैं -

  • यह जावा बीन्स, एक्सएमएल कॉन्फ़िगरेशन और डेटाबेस लेनदेन को कॉन्फ़िगर करने के लिए एक लचीला तरीका प्रदान करता है।

  • यह एक शक्तिशाली बैच प्रोसेसिंग प्रदान करता है और REST अंतिम बिंदुओं का प्रबंधन करता है।

  • स्प्रिंग बूट में, सब कुछ ऑटो कॉन्फ़िगर किया गया है; कोई मैनुअल कॉन्फ़िगरेशन की आवश्यकता नहीं है।

  • यह एनोटेशन आधारित स्प्रिंग एप्लिकेशन प्रदान करता है

  • आश्रित प्रबंधन

  • इसमें एंबेडेड सर्वलेट कंटेनर शामिल हैं

यह कैसे काम करता है?

स्प्रिंग बूट आपके द्वारा प्रोजेक्ट में जोड़े गए निर्भरता के आधार पर आपके एप्लिकेशन को स्वचालित रूप से कॉन्फ़िगर करता है @EnableAutoConfigurationएनोटेशन। उदाहरण के लिए, यदि MySQL डेटाबेस आपके classpath पर है, लेकिन आपने किसी डेटाबेस कनेक्शन को कॉन्फ़िगर नहीं किया है, तो स्प्रिंग बूट ऑटो-इन-मेमोरी डेटाबेस को कॉन्फ़िगर करता है।

स्प्रिंग बूट एप्लिकेशन का प्रवेश बिंदु वर्ग है @SpringBootApplication एनोटेशन और मुख्य विधि।

स्प्रिंग बूट स्वचालित रूप से परियोजना में शामिल सभी घटकों का उपयोग करके स्कैन करता है @ComponentScan एनोटेशन।

स्प्रिंग बूट शुरुआत

निर्भरता प्रबंधन को संभालना बड़ी परियोजनाओं के लिए एक मुश्किल काम है। स्प्रिंग बूट डेवलपर्स की सुविधा के लिए निर्भरता का एक सेट प्रदान करके इस समस्या का समाधान करता है।

उदाहरण के लिए, यदि आप डेटाबेस एक्सेस के लिए स्प्रिंग और जेपीए का उपयोग करना चाहते हैं, तो यह पर्याप्त है यदि आप शामिल हैं spring-boot-starter-data-jpa अपने प्रोजेक्ट में निर्भरता।

ध्यान दें कि सभी स्प्रिंग बूट शुरुआत एक ही नामकरण पैटर्न का पालन करते हैं spring-boot-starter- *, जहां * इंगित करता है कि यह एक प्रकार का एप्लिकेशन है।

उदाहरण

बेहतर समझ के लिए नीचे दिए गए स्प्रिंग बूट शुरुआत को देखें -

Spring Boot Starter Actuator dependencyका उपयोग आपके आवेदन की निगरानी और प्रबंधन के लिए किया जाता है। इसका कोड नीचे दिखाया गया है -

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

Spring Boot Starter Security dependencyवसंत सुरक्षा के लिए प्रयोग किया जाता है। इसका कोड नीचे दिखाया गया है -

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-security</artifactId>
</dependency>

Spring Boot Starter web dependencyरेस्ट एंडपॉइंट लिखने के लिए उपयोग किया जाता है। इसका कोड नीचे दिखाया गया है -

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

Spring Boot Starter Thyme Leaf dependencyवेब एप्लिकेशन बनाने के लिए उपयोग किया जाता है। इसका कोड नीचे दिखाया गया है -

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

Spring Boot Starter Test dependencyका उपयोग टेस्ट केस लिखने के लिए किया जाता है। इसका कोड नीचे दिखाया गया है -

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
</dependency>

ऑटो कॉन्फ़िगरेशन

स्प्रिंग बूट ऑटो कॉन्फ़िगरेशन प्रोजेक्ट में आपके द्वारा जोड़े गए JAR निर्भरता के आधार पर स्वचालित रूप से आपके स्प्रिंग एप्लिकेशन को कॉन्फ़िगर करता है। उदाहरण के लिए, यदि MySQL डेटाबेस आपके वर्ग पथ पर है, लेकिन आपने किसी डेटाबेस कनेक्शन को कॉन्फ़िगर नहीं किया है, तो स्प्रिंग बूट ऑटो इन-मेमोरी डेटाबेस को कॉन्फ़िगर करता है।

इस उद्देश्य के लिए, आपको जोड़ने की आवश्यकता है @EnableAutoConfiguration एनोटेशन या @SpringBootApplicationआपकी मुख्य श्रेणी फ़ाइल में एनोटेशन। फिर, आपका स्प्रिंग बूट एप्लिकेशन स्वचालित रूप से कॉन्फ़िगर हो जाएगा।

एक बेहतर समझ के लिए निम्नलिखित कोड देखें -

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;

@EnableAutoConfiguration
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

स्प्रिंग बूट अनुप्रयोग

स्प्रिंग बूट एप्लिकेशन का प्रवेश बिंदु वर्ग है @SpringBootApplicationएनोटेशन। स्प्रिंग बूट एप्लिकेशन को चलाने के लिए इस वर्ग की मुख्य विधि होनी चाहिए।@SpringBootApplication एनोटेशन में ऑटो कॉन्फ़िगरेशन, घटक स्कैन और स्प्रिंग बूट कॉन्फ़िगरेशन शामिल हैं।

अगर आपने जोड़ा @SpringBootApplication वर्ग के लिए एनोटेशन, आपको जोड़ने की आवश्यकता नहीं है @EnableAutoConfiguration, @ComponentScan तथा @SpringBootConfigurationएनोटेशन। @SpringBootApplication एनोटेशन में अन्य सभी एनोटेशन शामिल हैं।

एक बेहतर समझ के लिए निम्नलिखित कोड देखें -

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

घटक स्कैन

स्प्रिंग बूट एप्लिकेशन आवेदन शुरू होने पर सभी सेम और पैकेज घोषणाओं को स्कैन करता है। आपको जोड़ने की आवश्यकता है@ComponentScan आपकी परियोजना में जोड़े गए आपके घटकों को स्कैन करने के लिए आपकी कक्षा फ़ाइल के लिए एनोटेशन।

एक बेहतर समझ के लिए निम्नलिखित कोड देखें -

import org.springframework.boot.SpringApplication;
import org.springframework.context.annotation.ComponentScan;

@ComponentScan
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

यह अध्याय आपको मावेन और ग्रैडल का उपयोग करके स्प्रिंग बूट एप्लिकेशन बनाने का तरीका सिखाएगा।

आवश्यक शर्तें

स्प्रिंग बूट एप्लिकेशन बनाने के लिए आपके सिस्टम को निम्नलिखित न्यूनतम आवश्यकताएं होनी चाहिए -

  • जावा 7
  • मावेन ३.२
  • गाद 2.5

स्प्रिंग बूट सीएलआई

स्प्रिंग बूट सीएलआई एक कमांड लाइन उपकरण है और यह हमें ग्रूवी लिपियों को चलाने की अनुमति देता है। स्प्रिंग बूट कमांड लाइन इंटरफेस का उपयोग करके स्प्रिंग बूट एप्लिकेशन बनाने का यह सबसे आसान तरीका है। आप कमांड प्रॉम्प्ट में ही एप्लिकेशन बना, चला और टेस्ट कर सकते हैं।

यह खंड आपको स्प्रिंग बूट सीएलआई की मैन्युअल स्थापना में शामिल चरणों की व्याख्या करता है। आगे की मदद के लिए, आप निम्न लिंक का उपयोग कर सकते हैं:https://docs.spring.io/springboot/ docs/current-SNAPSHOT/reference/htmlsingle/#getting-started-installing-springboot

आप यहां पर स्प्रिंग सॉफ्टवेयर रिपॉजिटरी से स्प्रिंग सीएलआई वितरण भी डाउनलोड कर सकते हैं: https://docs.spring.io/spring-boot/docs/current-SNAPSHOT/reference/htmlsingle/#getting-started-manual-cli-installation

मैनुअल इंस्टॉलेशन के लिए, आपको निम्नलिखित दो फ़ोल्डरों का उपयोग करने की आवश्यकता है -

  • spring-boot-cli-2.0.0.BUILD-SNAPSHOT-bin.zip

  • spring-boot-cli-2.0.0.BUILD-SNAPSHOT-bin.tar.gz

डाउनलोड करने के बाद, संग्रह फ़ाइल को अनपैक करें और इंस्टॉल.टेक्स्ट फ़ाइल में दिए गए चरणों का पालन करें। ऐसा नहीं है कि इसे किसी भी पर्यावरण सेटअप की आवश्यकता नहीं है।

विंडोज में, स्प्रिंग बूट सीएलआई पर जाएं bin कमांड प्रॉम्प्ट में डायरेक्टरी और कमांड चलाएं spring –-versionयह सुनिश्चित करने के लिए कि वसंत सीएलआई सही ढंग से स्थापित है। कमांड निष्पादित करने के बाद, आप नीचे दिखाए गए अनुसार स्प्रिंग CLI संस्करण देख सकते हैं -

ग्रूवी के साथ हैलो वर्ल्ड चलाएं

एक साधारण ग्रूवी फाइल बनाएं जिसमें रेस्ट एंडपॉइंट स्क्रिप्ट हो और ग्रूवी फाइल को स्प्रिंग बूट सीएलआई के साथ चलाएं। इस उद्देश्य के लिए यहां दिखाए गए कोड को देखें -

@Controller
class Example {
   @RequestMapping("/")
   @ResponseBody
   public String hello() {
      "Hello Spring Boot"
   }
}

अब, नाम के साथ ग्रूवी फ़ाइल सहेजें hello.groovy। ध्यान दें कि इस उदाहरण में, हमने स्प्रिंग बूट सीएलआई के अंदर ग्रूवी फाइल को बचायाbinनिर्देशिका। अब कमांड का उपयोग करके एप्लिकेशन को चलाएंspring run hello.groovy जैसा कि नीचे दिए गए स्क्रीनशॉट में दिखाया गया है -

एक बार जब आप ग्रूवी फ़ाइल चलाते हैं, तो आवश्यक निर्भरताएं स्वचालित रूप से डाउनलोड हो जाएंगी और यह टॉमकैट 8080 पोर्ट में एप्लिकेशन शुरू कर देगी जैसा कि नीचे दिए गए स्क्रीनशॉट में दिखाया गया है -

एक बार टॉमकैट शुरू होने पर, वेब ब्राउज़र पर जाएं और URL को हिट करें http://localhost:8080/ और जैसा कि आप आउटपुट को देख सकते हैं।

यह अध्याय आपको समझाएगा कि स्प्रिंग बूट एप्लिकेशन पर बूटस्ट्रैपिंग कैसे करें।

स्प्रिंग इनिशिएटिव

स्प्रिंग बूटस्ट्रिप को बूटस्ट्रैप करने के तरीकों में से एक है स्प्रिंग इनिशियलाइज़र का उपयोग करना। ऐसा करने के लिए, आपको स्प्रिंग इनिशियल वेब पेज www.start.spring.io पर जाना होगा और अपने बिल्ड, स्प्रिंग बूट संस्करण और प्लेटफ़ॉर्म को चुनना होगा। इसके अलावा, आपको एप्लिकेशन चलाने के लिए एक समूह, कलाकारी और आवश्यक निर्भरताएं प्रदान करने की आवश्यकता है।

निम्नलिखित स्क्रीनशॉट का निरीक्षण करें जो एक उदाहरण दिखाता है जहां हमने जोड़ा है spring-boot-starter-web REST समापन बिंदु लिखने के लिए निर्भरता।

एक बार जब आप ग्रुप, आर्टवर्क, डिपेंडेंसी, बिल्ड प्रोजेक्ट, प्लेटफ़ॉर्म और वर्जन प्रदान करते हैं, तो क्लिक करें Generate Projectबटन। ज़िप फ़ाइल डाउनलोड होगी और फ़ाइलों को निकाला जाएगा।

यह खंड आपको मावेन और ग्रैडल दोनों का उपयोग करके उदाहरण बताता है।

Maven

प्रोजेक्ट डाउनलोड करने के बाद, फ़ाइल को अनज़िप करें। अब तुम्हाराpom.xml फ़ाइल के रूप में नीचे दिखाया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>

   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>
   
   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle

प्रोजेक्ट डाउनलोड करने के बाद, फ़ाइल को अनज़िप करें। अब तुम्हाराbuild.gradle फ़ाइल के रूप में नीचे दिखाया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

कक्षा पथ निर्भरताएँ

स्प्रिंग बूट कई नंबर प्रदान करता है Startersहमारे वर्ग पथ में जार जोड़ने के लिए। उदाहरण के लिए, रेस्ट एंडपॉइंट लिखने के लिए, हमें जोड़ना होगाspring-boot-starter-webहमारे वर्ग पथ में निर्भरता। बेहतर समझ के लिए नीचे दिए गए कोड देखें -

मावेन निर्भरता

<dependencies>
   <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
   </dependency>
</dependencies>

ग्रेड पर निर्भरता

dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
}

मुख्य विधि

मुख्य विधि स्प्रिंग बूट एप्लीकेशन क्लास लिखना चाहिए। इस वर्ग के साथ किया जाना चाहिए@SpringBootApplication। यह शुरू करने के लिए स्प्रिंग बूट एप्लिकेशन का प्रवेश बिंदु है। आप के तहत मुख्य वर्ग फ़ाइल पा सकते हैंsrc/java/main डिफ़ॉल्ट पैकेज के साथ निर्देशिका।

इस उदाहरण में, मुख्य वर्ग फ़ाइल में स्थित है src/java/main डिफ़ॉल्ट पैकेज के साथ निर्देशिका com.tutorialspoint.demo। बेहतर समझ के लिए यहां दिखाए गए कोड को देखें -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

एक आराम समापन बिंदु लिखें

स्प्रिंग बूट एप्लीकेशन मुख्य क्लास फ़ाइल में एक साधारण हैलो वर्ल्ड रेस्ट एंडपॉइंट लिखने के लिए, नीचे दिखाए गए चरणों का पालन करें -

  • सबसे पहले, जोड़ें @RestController वर्ग के शीर्ष पर एनोटेशन।

  • अब, एक अनुरोध URI विधि के साथ लिखें @RequestMapping एनोटेशन।

  • उसके बाद, अनुरोध URI विधि को वापस करना चाहिए Hello World स्ट्रिंग।

अब, आपकी मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फाइल नीचे दी गई कोड की तरह दिखाई देगी -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController

public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   @RequestMapping(value = "/")
   public String hello() {
      return "Hello World";
   }
}

एक निष्पादन जार बनाएँ

आइए हम दिखाए गए कमांड प्रॉम्प्ट में मावेन और ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन को चलाने के लिए एक निष्पादन योग्य JAR फ़ाइल बनाते हैं -

नीचे दिखाए गए अनुसार मावेन कमांड mvan क्लीन इंस्टॉल का उपयोग करें -

कमांड निष्पादित करने के बाद, आप देख सकते हैं BUILD SUCCESS नीचे दिखाए गए अनुसार कमांड प्रॉम्प्ट पर संदेश -

ग्रैडल कमांड का उपयोग करें gradle clean build जैसा कि नीचे दिखाया गया है -

कमांड निष्पादित करने के बाद, आप देख सकते हैं BUILD SUCCESSFUL नीचे दिखाए अनुसार कमांड प्रॉम्प्ट में संदेश -

जावा के साथ हैलो वर्ल्ड चलाएं

एक बार जब आप एक निष्पादन योग्य JAR फ़ाइल बना लेते हैं, तो आप इसे निम्न निर्देशिकाओं के अंतर्गत पा सकते हैं।

मावेन के लिए, आप लक्ष्य निर्देशिका के तहत JAR फ़ाइल पा सकते हैं जैसा कि नीचे दिखाया गया है -

ग्रेडेल के लिए, आप JAR फ़ाइल को इसके अंतर्गत पा सकते हैं build/libs नीचे दिखाए अनुसार निर्देशिका -

अब, कमांड का उपयोग करके JAR फ़ाइल चलाएँ java –jar <JARFILE>। निरीक्षण करें कि उपरोक्त उदाहरण में, JAR फ़ाइल का नाम हैdemo-0.0.1-SNAPSHOT.jar

एक बार जब आप जार फ़ाइल चलाते हैं, तो आप नीचे दिखाए अनुसार कंसोल विंडो में आउटपुट देख सकते हैं -

अब, कंसोल को देखें, पोर्ट 8080 (http) पर टॉमकैट शुरू हुआ। अब, वेब ब्राउज़र पर जाएं और URL को हिट करेंhttp://localhost:8080/ और आप नीचे दिखाए अनुसार आउटपुट देख सकते हैं -

स्प्रिंग बूट एप्लिकेशन का उपयोग करके, हम वेब सर्वर में तैनात करने के लिए एक युद्ध फ़ाइल बना सकते हैं। इस अध्याय में, आप सीखना चाहते हैं कि कैसे WAR फ़ाइल बनाएं और टॉमकैट वेब सर्वर में स्प्रिंग बूट एप्लिकेशन को तैनात करें।

स्प्रिंग बूट सर्वलेट इनिशिएटिव

तैनाती का पारंपरिक तरीका स्प्रिंग बूट एप्लीकेशन है @SpringBootApplication वर्ग का विस्तार SpringBootServletInitializerकक्षा। स्प्रिंग बूट सर्वलेट इनिशिएटिव क्लास फाइल आपको एप्लिकेशन को कॉन्फ़िगर करने की अनुमति देती है जब इसे सर्वलेट कंटेनर का उपयोग करके लॉन्च किया जाता है।

JAR फ़ाइल परिनियोजन के लिए स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल का कोड नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

हमें वर्ग का विस्तार करने की आवश्यकता है SpringBootServletInitializerWAR फ़ाइल परिनियोजन का समर्थन करने के लिए। स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल का कोड नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;

@SpringBootApplication
public class DemoApplication  extends SpringBootServletInitializer {
   @Override
   protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
      return application.sources(DemoApplication.class);
   }
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

मेन क्लास सेट करना

स्प्रिंग बूट में, हमें मुख्य वर्ग का उल्लेख करना होगा जो बिल्ड फ़ाइल में शुरू होना चाहिए। इस उद्देश्य के लिए, आप कोड के निम्नलिखित टुकड़ों का उपयोग कर सकते हैं -

मावेन के लिए, प्रारंभ वर्ग को इसमें जोड़ें pom.xml नीचे दिखाए गए गुण -

<start-class>com.tutorialspoint.demo.DemoApplication</start-class>

ग्रेडल के लिए, बिल्ड में मुख्य वर्ग का नाम जोड़ें। नीचे दिखाया गया है -

mainClassName="com.tutorialspoint.demo.DemoApplication"

पैकेजिंग जार को WAR में अपडेट करें

हमें कोड के निम्नलिखित टुकड़ों का उपयोग करके JAR में पैकेजिंग JAR को अपडेट करना होगा -

मावेन के लिए, WAR के रूप में पैकेजिंग जोड़ें pom.xml जैसा कि नीचे दिखाया गया है -

<packaging>war</packaging>

ग्रैडल के लिए, एप्लिकेशन प्लगइन और युद्ध प्लगइन जोड़ें build.gradle जैसा कि नीचे दिखाया गया है -

apply plugin: ‘war’
apply plugin: ‘application’

अब, हम "टॉमकैट से हैलो वर्ल्ड" स्ट्रिंग वापस करने के लिए एक साधारण रेस्ट एंडपॉइंट लिखते हैं। रेस्ट एंडपॉइंट लिखने के लिए, हमें अपनी बिल्ड फ़ाइल में स्प्रिंग बूट वेब स्टार्टर निर्भरता को जोड़ना होगा।

मावेन के लिए, नीचे दिए गए कोड का उपयोग करके pom.xml में स्प्रिंग बूट स्टार्टर निर्भरता जोड़ें -

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

ग्रैडल के लिए, स्प्रिंग बूट स्टार्टर निर्भरता जोड़ें build.gradle नीचे दिखाए गए अनुसार कोड का उपयोग करना -

dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
}

अब, नीचे दिए गए कोड का उपयोग करके स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल में एक साधारण रेस्ट एंडपॉइंट लिखें -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class DemoApplication  extends SpringBootServletInitializer {
   @Override
   protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
      return application.sources(DemoApplication.class);
   }
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   
   @RequestMapping(value = "/")
   public String hello() {
      return "Hello World from Tomcat";
   }
}

अपने अनुप्रयोग पैकेजिंग

अब, नीचे दिए गए अपने आवेदन को पैकेजिंग के लिए मावेन और ग्रैडल कमांड का उपयोग करके टॉमकैट सर्वर में तैनात करने के लिए एक डब्ल्यूएआर फ़ाइल बनाएं।

मावेन के लिए, कमांड का उपयोग करें mvn packageअपने आवेदन की पैकेजिंग के लिए। फिर, WAR फ़ाइल बनाई जाएगी और आप इसे लक्ष्य निर्देशिका में पा सकते हैं जैसा कि नीचे दिए गए स्क्रीनशॉट में दिखाया गया है -

ग्रैडल के लिए, कमांड का उपयोग करें gradle clean buildअपने आवेदन की पैकेजिंग के लिए। फिर, आपकी WAR फाइल बन जाएगी और आप इसे नीचे पा सकते हैंbuild/libsनिर्देशिका। बेहतर समझ के लिए यहां दिए गए स्क्रीनशॉट पर गौर करें -

टोमाट में तैनात करें

अब, Tomcat सर्वर चलाएं, और WAR फ़ाइल को इसके अंतर्गत तैनात करें webappsनिर्देशिका। बेहतर समझ के लिए यहां दिखाए गए स्क्रीनशॉट का अवलोकन करें -

सफल तैनाती के बाद, अपने वेब ब्राउज़र में URL को हिट करें http://localhost:8080/demo-0.0.1-SNAPSHOT/ और देखें कि आउटपुट नीचे दिए गए स्क्रीनशॉट में दिखाया गया है -

इस उद्देश्य के लिए पूरा कोड नीचे दिया गया है।

pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>war</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>
   
   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <start-class>com.tutorialspoint.demo.DemoApplication</start-class>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'
apply plugin: 'war'
apply plugin: 'application'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8
mainClassName = "com.tutorialspoint.demo.DemoApplication"

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल का कोड नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class DemoApplication  extends SpringBootServletInitializer {
   @Override
   protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
      return application.sources(DemoApplication.class);
   }
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   
   @RequestMapping(value = "/")
   public String hello() {
      return "Hello World from Tomcat";
   }
}

स्प्रिंग बूट में, एक बिल्ड सिस्टम चुनना एक महत्वपूर्ण कार्य है। हम मावेन या ग्रैडल की सलाह देते हैं क्योंकि वे निर्भरता प्रबंधन के लिए एक अच्छा समर्थन प्रदान करते हैं। वसंत अच्छी तरह से अन्य निर्माण प्रणालियों का समर्थन नहीं करता है।

निर्भरता प्रबंधन

स्प्रिंग बूट टीम अपनी हर रिलीज़ के लिए स्प्रिंग बूट संस्करण का समर्थन करने के लिए निर्भरता की एक सूची प्रदान करती है। आपको बिल्ड कॉन्फ़िगरेशन फ़ाइल में निर्भरता के लिए एक संस्करण प्रदान करने की आवश्यकता नहीं है। स्प्रिंग बूट स्वचालित रूप से रिलीज़ के आधार पर निर्भरता संस्करण को कॉन्फ़िगर करता है। याद रखें कि जब आप स्प्रिंग बूट संस्करण को अपग्रेड करते हैं, तो निर्भरताएं भी स्वचालित रूप से अपग्रेड हो जाएंगी।

Note- यदि आप निर्भरता के लिए संस्करण निर्दिष्ट करना चाहते हैं, तो आप इसे अपनी कॉन्फ़िगरेशन फ़ाइल में निर्दिष्ट कर सकते हैं। हालांकि, स्प्रिंग बूट टीम अत्यधिक अनुशंसा करती है कि निर्भरता के लिए संस्करण को निर्दिष्ट करने की आवश्यकता नहीं है।

मावेन निर्भरता

मावेन कॉन्फ़िगरेशन के लिए, हमें स्प्रिंग बूट स्टार्टर मूल निर्भरता को प्रबंधित करने के लिए स्प्रिंग बूट स्टार्टर मूल परियोजना को इनहेरिट करना चाहिए। इसके लिए, बस हम स्टार्टर माता-पिता को विरासत में दे सकते हैंpom.xml फ़ाइल के रूप में नीचे दिखाया गया है।

<parent>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-parent</artifactId>
   <version>1.5.8.RELEASE</version>
</parent>

हमें स्प्रिंग बूट पैरेंट स्टार्टर निर्भरता के लिए संस्करण संख्या निर्दिष्ट करनी चाहिए। फिर अन्य स्टार्टर निर्भरताओं के लिए, हमें स्प्रिंग बूट संस्करण संख्या निर्दिष्ट करने की आवश्यकता नहीं है। नीचे दिए गए कोड को ध्यान से देखें -

<dependencies>
   <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
   </dependency>
</dependencies>

ग्रेड की निर्भरता

हम सीधे वसंत बूट शुरुआत निर्भरता में आयात कर सकते हैं build.gradleफ़ाइल। हमें ग्रेड के लिए मावेन की तरह स्प्रिंग बूट स्टार्ट पैरेंट निर्भरता की आवश्यकता नहीं है। नीचे दिए गए कोड को ध्यान से देखें -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

इसी तरह, ग्रैडल में, हमें निर्भरता के लिए स्प्रिंग बूट संस्करण संख्या निर्दिष्ट करने की आवश्यकता नहीं है। स्प्रिंग बूट स्वचालित रूप से संस्करण के आधार पर निर्भरता को कॉन्फ़िगर करता है।

dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
}

स्प्रिंग बूट के पास काम करने के लिए कोई कोड लेआउट नहीं है। हालांकि, कुछ सर्वोत्तम अभ्यास हैं जो हमें मदद करेंगे। यह अध्याय उनके बारे में विस्तार से बात करता है।

डिफ़ॉल्ट पैकेज

एक वर्ग जिसके पास कोई पैकेज घोषणा नहीं है, को एक माना जाता है default package। ध्यान दें कि आम तौर पर एक डिफ़ॉल्ट पैकेज घोषणा की सिफारिश नहीं की जाती है। जब आप डिफ़ॉल्ट पैकेज का उपयोग करते हैं तो स्प्रिंग बूट ऑटो कॉन्फ़िगरेशन या घटक स्कैन की खराबी जैसे मुद्दों का कारण होगा।

Note- पैकेज की घोषणा के लिए जावा के अनुशंसित नामकरण का उलट डोमेन नाम है। उदाहरण के लिए -com.tutorialspoint.myproject

विशिष्ट लेआउट

स्प्रिंग बूट एप्लिकेशन का विशिष्ट लेआउट नीचे दी गई छवि में दिखाया गया है -

Application.java फ़ाइल को @SpringBootApplication के साथ मुख्य विधि घोषित करनी चाहिए। बेहतर समझ के लिए नीचे दिए गए कोड को देखें -

package com.tutorialspoint.myproject;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Application {
   public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}

स्प्रिंग बूट में, हम अपनी फलियों और उनकी निर्भरता इंजेक्शन को परिभाषित करने के लिए स्प्रिंग फ्रेमवर्क का उपयोग कर सकते हैं। @ComponentScan एनोटेशन का उपयोग सेम को खोजने के लिए किया जाता है और इसके साथ इंजेक्शन लगाया जाता है @Autowired एनोटेशन।

यदि आपने स्प्रिंग बूट ठेठ लेआउट का अनुसरण किया है, तो इसके लिए कोई तर्क निर्दिष्ट करने की आवश्यकता नहीं है @ComponentScanएनोटेशन। सभी घटक वर्ग की फाइलें स्वचालित रूप से स्प्रिंग बीन्स के साथ पंजीकृत होती हैं।

निम्नलिखित उदाहरण रेस्ट टेम्प्लेट ऑब्जेक्ट को ऑटो वायरिंग और उसी के लिए बीन बनाने के बारे में एक विचार प्रदान करता है -

@Bean
public RestTemplate getRestTemplate() {
   return new RestTemplate();
}

निम्न कोड मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल में ऑटो वायर्ड रेस्ट टेम्प्लेट ऑब्जेक्ट और बीन क्रिएशन ऑब्जेक्ट के लिए कोड दिखाता है -

package com.tutorialspoint.demo;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@SpringBootApplication
public class DemoApplication {
@Autowired
   RestTemplate restTemplate;
   
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   @Bean
   public RestTemplate getRestTemplate() {
      return new RestTemplate();   
   }
}

एप्लिकेशन रनर और कमांड लाइन रनर इंटरफेस आपको स्प्रिंग बूट एप्लिकेशन शुरू होने के बाद कोड को निष्पादित करने देता है। आप आवेदन शुरू होने के तुरंत बाद किसी भी कार्य को करने के लिए इन इंटरफेस का उपयोग कर सकते हैं। यह अध्याय उनके बारे में विस्तार से बात करता है।

आवेदन धावक

एप्लिकेशन रनर एक इंटरफ़ेस है जिसका उपयोग स्प्रिंग बूट एप्लिकेशन शुरू होने के बाद कोड को निष्पादित करने के लिए किया जाता है। नीचे दिए गए उदाहरण से पता चलता है कि मुख्य वर्ग फ़ाइल पर एप्लिकेशन रनर इंटरफ़ेस को कैसे लागू किया जाए।

package com.tutorialspoint.demo;

import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication implements ApplicationRunner {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   @Override
   public void run(ApplicationArguments arg0) throws Exception {
      System.out.println("Hello World from Application Runner");
   }
}

अब, यदि आप नीचे दिए गए कंसोल विंडो को देखते हैं Hello World from Application Runner, Println स्टेटमेंट को टॉस्क शुरू होने के बाद निष्पादित किया जाता है। निम्नलिखित स्क्रीनशॉट प्रासंगिक है?

कमांड लाइन धावक

कमांड लाइन रनर एक इंटरफ़ेस है। स्प्रिंग बूट एप्लिकेशन शुरू होने के बाद कोड को निष्पादित करने के लिए इसका उपयोग किया जाता है। नीचे दिए गए उदाहरण से पता चलता है कि कमांड लाइन रनर इंटरफ़ेस को मुख्य वर्ग फ़ाइल पर कैसे लागू किया जाए।

package com.tutorialspoint.demo;

import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication implements CommandLineRunner {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   @Override
   public void run(String... arg0) throws Exception {
      System.out.println("Hello world from Command Line Runner");
   }
}

टॉमकैट शुरू होने के बाद "कमांड लाइन रनर से हैलो दुनिया" प्रिंटल स्टेटमेंट के नीचे कंसोल विंडो को देखें।

अनुप्रयोग गुण विभिन्न वातावरणों में काम करने के लिए हमारा समर्थन करते हैं। इस अध्याय में, आप स्प्रिंग बूट एप्लिकेशन के गुणों को कॉन्फ़िगर और निर्दिष्ट करने का तरीका जानने जा रहे हैं।

कमांड लाइन गुण

स्प्रिंग बूट एप्लिकेशन कमांड लाइन के गुणों को स्प्रिंग बूट पर्यावरण के गुणों में परिवर्तित करता है। कमांड लाइन गुण अन्य संपत्ति स्रोतों पर पूर्वता लेते हैं। डिफ़ॉल्ट रूप से, स्प्रिंग बूट टॉमकट शुरू करने के लिए 8080 पोर्ट नंबर का उपयोग करता है। आइए जानें कमांड लाइन के गुणों का उपयोग करके पोर्ट नंबर को कैसे बदलें।

Step 1 - एक निष्पादन योग्य जार फ़ाइल बनाने के बाद, कमांड का उपयोग करके इसे चलाएं java –jar <JARFILE>

Step 2 - कमांड लाइन के गुणों का उपयोग करके स्प्रिंग बूट एप्लिकेशन के लिए पोर्ट नंबर बदलने के लिए नीचे दिए गए स्क्रीनशॉट में दिए गए कमांड का उपयोग करें।

Note - आप सीमांकक का उपयोग करके एक से अधिक अनुप्रयोग गुण प्रदान कर सकते हैं -।

गुण फ़ाइल

एक अलग वातावरण में एप्लिकेशन को चलाने के लिए एकल फ़ाइल में गुणों की संख्या 'एन' रखने के लिए गुण फ़ाइलों का उपयोग किया जाता है। स्प्रिंग बूट में, गुणों को रखा जाता हैapplication.properties क्लासपाथ के नीचे फाइल।

Application.properties फ़ाइल में स्थित है src/main/resourcesनिर्देशिका। नमूना के लिए कोडapplication.properties फ़ाइल नीचे दी गई है -

server.port = 9090
spring.application.name = demoservice

ध्यान दें कि स्प्रिंग बूट एप्लिकेशन के ऊपर दिखाए गए कोड में पोर्ट 9090 पर शुरू होता है।

YAML फ़ाइल

स्प्रिंग बूट एप्लीकेशन को चलाने के लिए YAML आधारित गुण विन्यास का समर्थन करता है। के बजायapplication.properties, हम प्रयोग कर सकते हैं application.ymlफ़ाइल। इस YAML फ़ाइल को भी क्लासपाथ के अंदर रखा जाना चाहिए। नमूनाapplication.yml फ़ाइल नीचे दी गई है -

spring:
   application:
      name: demoservice
   server:
port: 9090

बाहरी गुण

गुणों को वर्गपथ के अंतर्गत रखने के बजाय, हम गुणों को अलग-अलग स्थान या पथ पर रख सकते हैं। JAR फ़ाइल चलाते समय, हम गुण फ़ाइल पथ निर्दिष्ट कर सकते हैं। JAR चलाते समय प्रॉपर्टीज़ फ़ाइल के स्थान को निर्दिष्ट करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

-Dspring.config.location = C:\application.properties

@Value एनोटेशन का उपयोग

जावा कोड में पर्यावरण या एप्लिकेशन प्रॉपर्टी वैल्यू को पढ़ने के लिए @ वेल्यू एनोटेशन का उपयोग किया जाता है। संपत्ति का मूल्य पढ़ने का सिंटैक्स नीचे दिखाया गया है -

@Value("${property_key_name}")

निम्नलिखित उदाहरण देखें जो सिंटैक्स को पढ़ने के लिए दिखाता है spring.application.name जावा वेरिएबल में @ वेल्यू एनोटेशन का उपयोग करके संपत्ति का मूल्य।

@Value("${spring.application.name}")

बेहतर समझ के लिए नीचे दिए गए कोड को देखें -

import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class DemoApplication {
   @Value("${spring.application.name}")
   private String name;
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   @RequestMapping(value = "/")
   public String name() {
      return name;
   }
}

Note - यदि आवेदन चलाते समय संपत्ति नहीं मिली है, तो स्प्रिंग बूट अवैध तर्क अपवाद को फेंक देता है Could not resolve placeholder 'spring.application.name' in value "${spring.application.name}"

प्लेसहोल्डर समस्या को हल करने के लिए, हम नीचे दिए गए थ्रोट सिंटैक्स का उपयोग करके संपत्ति के लिए डिफ़ॉल्ट मान सेट कर सकते हैं -

@Value("${property_key_name:default_value}")

@Value("${spring.application.name:demoservice}")

स्प्रिंग बूट सक्रिय प्रोफ़ाइल

स्प्रिंग सक्रिय प्रोफ़ाइल के आधार पर स्प्रिंग बूट विभिन्न गुणों का समर्थन करता है। उदाहरण के लिए, हम स्प्रिंग बूट एप्लिकेशन को चलाने के लिए विकास और उत्पादन के लिए दो अलग-अलग फाइलें रख सकते हैं।

आवेदन में वसंत सक्रिय प्रोफ़ाइल

आइए समझते हैं कि आवेदन में स्प्रिंग सक्रिय प्रोफ़ाइल कैसे होना चाहिए। डिफ़ॉल्ट रूप से, आवेदन। गुण का उपयोग स्प्रिंग बूट एप्लिकेशन को चलाने के लिए किया जाएगा। यदि आप प्रोफ़ाइल आधारित गुणों का उपयोग करना चाहते हैं, तो हम नीचे दिखाए गए अनुसार प्रत्येक प्रोफ़ाइल के लिए अलग गुण फ़ाइल रख सकते हैं -

application.properties

server.port = 8080
spring.application.name = demoservice

application-dev.properties

server.port = 9090
spring.application.name = demoservice

application-prod.properties

server.port = 4431
spring.application.name = demoservice

JAR फ़ाइल चलाते समय, हमें प्रत्येक गुण फ़ाइल के आधार पर स्प्रिंग सक्रिय प्रोफ़ाइल को निर्दिष्ट करने की आवश्यकता होती है। डिफ़ॉल्ट रूप से, स्प्रिंग बूट एप्लिकेशन Application.properties फ़ाइल का उपयोग करता है। वसंत सक्रिय प्रोफ़ाइल को सेट करने का आदेश नीचे दिखाया गया है -

आप नीचे दिखाए गए अनुसार कंसोल लॉग पर सक्रिय प्रोफ़ाइल नाम देख सकते हैं -

2017-11-26 08:13:16.322  INFO 14028 --- [           
   main] com.tutorialspoint.demo.DemoApplication  :
   The following profiles are active: dev

अब, नीचे दिखाए गए अनुसार पोर्ट 9090 (http) पर टॉमकैट शुरू हो गया है -

2017-11-26 08:13:20.185  INFO 14028 --- [           
   main] s.b.c.e.t.TomcatEmbeddedServletContainer : 
   Tomcat started on port(s): 9090 (http)

आप नीचे दिखाए अनुसार उत्पादन सक्रिय प्रोफ़ाइल सेट कर सकते हैं -

आप नीचे दिखाए गए अनुसार कंसोल लॉग पर सक्रिय प्रोफ़ाइल नाम देख सकते हैं -

2017-11-26 08:13:16.322  INFO 14028 --- [           
   main] com.tutorialspoint.demo.DemoApplication  :
   The following profiles are active: prod

अब, टॉमकट ने पोर्ट 4431 (http) पर शुरू किया जैसा कि नीचे दिखाया गया है -

2017-11-26 08:13:20.185  INFO 14028 --- [          
   main] s.b.c.e.t.TomcatEmbeddedServletContainer :
   Tomcat started on port(s): 4431 (http)

आवेदन के लिए स्प्रिंग सक्रिय प्रोफ़ाइल

चलिए समझते हैं कि आवेदन के लिए स्प्रिंग सक्रिय प्रोफ़ाइल कैसे रखें। हम सिंगल में स्प्रिंग सक्रिय प्रोफाइल गुण रख सकते हैंapplication.ymlफ़ाइल। Application.properties जैसी अलग फ़ाइल का उपयोग करने की आवश्यकता नहीं है।

Application.yml फ़ाइल में स्प्रिंग सक्रिय प्रोफाइल रखने के लिए निम्न उदाहरण कोड है। ध्यान दें कि delimiter (---) का उपयोग प्रत्येक प्रोफाइल को अलग करने के लिए किया जाता है।

spring:
   application:
      name: demoservice
server:
   port: 8080

---
spring:
   profiles: dev
   application:
      name: demoservice
server:
   port: 9090

---
spring: 
   profiles: prod
   application:
      name: demoservice
server: 
   port: 4431

विकास को निर्धारित करने के लिए सक्रिय प्रोफ़ाइल नीचे दी गई है -

आप नीचे दिखाए गए अनुसार कंसोल लॉग पर सक्रिय प्रोफ़ाइल नाम देख सकते हैं -

2017-11-26 08:41:37.202  INFO 14104 --- [           
   main] com.tutorialspoint.demo.DemoApplication  : 
   The following profiles are active: dev

अब, टॉमकट ने पोर्ट 9090 पर शुरू किया (http) जैसा कि नीचे दिखाया गया है -

2017-11-26 08:41:46.650  INFO 14104 --- [           
   main] s.b.c.e.t.TomcatEmbeddedServletContainer : 
   Tomcat started on port(s): 9090 (http)

उत्पादन सक्रिय प्रोफ़ाइल सेट करने का आदेश नीचे दिया गया है -

आप नीचे दिखाए गए अनुसार कंसोल लॉग पर सक्रिय प्रोफ़ाइल नाम देख सकते हैं -

2017-11-26 08:43:10.743  INFO 13400 --- [    
   main] com.tutorialspoint.demo.DemoApplication  : 
   The following profiles are active: prod

यह नीचे दिखाए गए अनुसार पोर्ट 4431 (http) पर टॉमकैट शुरू करेगा:

2017-11-26 08:43:14.473  INFO 13400 --- [     
   main] s.b.c.e.t.TomcatEmbeddedServletContainer : 
   Tomcat started on port(s): 4431 (http)

स्प्रिंग बूट सभी आंतरिक लॉगिंग के लिए अपाचे कॉमन्स लॉगिंग का उपयोग करता है। स्प्रिंग बूट का डिफ़ॉल्ट कॉन्फ़िगरेशन जावा यूटिल लॉगिंग, लॉग 4 जे 2 और लॉगबैक के उपयोग के लिए सहायता प्रदान करता है। इनका उपयोग करके, हम कंसोल लॉगिंग के साथ-साथ फाइल लॉगिंग को कॉन्फ़िगर कर सकते हैं।

यदि आप स्प्रिंग बूट स्टार्टर्स का उपयोग कर रहे हैं, तो लॉगबैक लॉगिंग के लिए एक अच्छा समर्थन प्रदान करेगा। इसके अलावा, लॉगबैक कॉमन लॉगिंग, यूटिल लॉगिंग, लॉग 4 जे और एसएलएफ 4 जे के लिए अच्छे समर्थन का उपयोग भी प्रदान करता है।

लॉग प्रारूप

डिफ़ॉल्ट स्प्रिंग बूट लॉग प्रारूप नीचे दिए गए स्क्रीनशॉट में दिखाया गया है।

जो आपको निम्नलिखित जानकारी देता है -

  • Date तथा Time जो लॉग की तारीख और समय देता है

  • Log level जानकारी, त्रुटि या चेतावनी दिखाता है

  • Process ID

  • --- जो एक विभाजक है

  • Thread name वर्ग कोष्ठक के भीतर संलग्न है []

  • Logger Name वह स्रोत वर्ग नाम दिखाता है

  • लॉग संदेश

कंसोल लॉग आउटपुट

डिफ़ॉल्ट लॉग संदेश कंसोल विंडो पर प्रिंट होगा। डिफ़ॉल्ट रूप से, "INFO", "ERROR" और "WARN" लॉग संदेश लॉग फ़ाइल में प्रिंट होंगे।

यदि आपको डिबग स्तर लॉग को सक्षम करना है, तो नीचे दिखाए गए आदेश का उपयोग करके अपना एप्लिकेशन शुरू करने पर डीबग ध्वज जोड़ें -

java –jar demo.jar --debug

आप अपने डिबग मोड को अपने एप्लिकेशन में भी जोड़ सकते हैं।

debug = true

फ़ाइल लॉग आउटपुट

डिफ़ॉल्ट रूप से, सभी लॉग कंसोल विंडो पर प्रिंट होंगे और फाइलों में नहीं। यदि आप किसी फ़ाइल में लॉग प्रिंट करना चाहते हैं, तो आपको संपत्ति सेट करने की आवश्यकता हैlogging.file या logging.path Application.properties फ़ाइल में।

आप नीचे दिखाए गए गुण का उपयोग करके लॉग फ़ाइल पथ निर्दिष्ट कर सकते हैं। ध्यान दें कि लॉग फ़ाइल का नाम spring.log है।

logging.path = /var/tmp/

नीचे दी गई संपत्ति का उपयोग करके आप स्वयं लॉग फ़ाइल नाम निर्दिष्ट कर सकते हैं -

logging.file = /var/tmp/mylog.log

Note - 10 एमबी साइज तक पहुंचने के बाद फाइलें अपने आप रोटेट हो जाएंगी।

लॉग स्तर

स्प्रिंग बूट सभी लकड़हारा स्तरों का समर्थन करता है जैसे "TRACE", "DEBUG", "INFO", "WARN", "ERROR", "FATAL", "OFF"। आप रूट लॉगर को अनुप्रयोग में परिभाषित कर सकते हैं। निम्न फ़ाइल में दिखाया गया है -

logging.level.root = WARN

Note- लॉगबैक "FATAL" स्तर लॉग का समर्थन नहीं करता है। यह "त्रुटि" स्तर लॉग करने के लिए मैप किया गया है।

लॉगबैक कॉन्फ़िगर करें

Logback स्प्रिंग बूट लॉग कॉन्फ़िगरेशन को संभालने के लिए XML आधारित कॉन्फ़िगरेशन का समर्थन करता है। लॉगिंग कॉन्फ़िगरेशन विवरण कॉन्फ़िगर किए गए हैंlogback.xmlफ़ाइल। लॉगबैक। Xml फ़ाइल को क्लासपाथ के नीचे रखा जाना चाहिए।

आप नीचे दिए गए कोड का उपयोग करके Logback.xml फ़ाइल में ROOT लॉग को कॉन्फ़िगर कर सकते हैं -

<?xml version = "1.0" encoding = "UTF-8"?>
<configuration>
   <root level = "INFO">
   </root>
</configuration>

आप नीचे दिए गए Logback.xml फ़ाइल में कंसोल ऐपेंडर को कॉन्फ़िगर कर सकते हैं।

<?xml version = "1.0" encoding = "UTF-8"?>
<configuration>
   <appender name = "STDOUT" class = "ch.qos.logback.core.ConsoleAppender"></appender>
   <root level = "INFO">
      <appender-ref ref = "STDOUT"/> 
   </root>
</configuration>

आप नीचे दिए गए कोड का उपयोग करके Logback.xml फ़ाइल में फ़ाइल परिशिष्ट को कॉन्फ़िगर कर सकते हैं। ध्यान दें कि आपको लॉग फ़ाइल पथ को निर्दिष्ट करने की आवश्यकता है फ़ाइल परिशिष्ट पर अंदरूनी सूत्र।

<?xml version = "1.0" encoding = "UTF-8"?>
<configuration>
   <appender name = "FILE" class = "ch.qos.logback.core.FileAppender">
      <File>/var/tmp/mylog.log</File>
   </appender>   
   <root level = "INFO">
      <appender-ref ref = "FILE"/>
   </root>
</configuration>

आप लॉग पैटर्न को परिभाषित कर सकते हैं logback.xmlनीचे दिए गए कोड का उपयोग करके फ़ाइल। आप नीचे दिए गए कोड का उपयोग करके कंसोल या फ़ाइल लॉग ऐपेंडर के अंदर समर्थित लॉग पैटर्न के सेट को भी परिभाषित कर सकते हैं -

<pattern>[%d{yyyy-MM-dd'T'HH:mm:ss.sss'Z'}] [%C] [%t] [%L] [%-5p] %m%n</pattern>

पूर्ण logback.xml फ़ाइल के लिए कोड नीचे दिया गया है। आपको इसे कक्षा पथ में रखना होगा।

<?xml version = "1.0" encoding = "UTF-8"?>
<configuration>
   <appender name = "STDOUT" class = "ch.qos.logback.core.ConsoleAppender">
      <encoder>
         <pattern>[%d{yyyy-MM-dd'T'HH:mm:ss.sss'Z'}] [%C] [%t] [%L] [%-5p] %m%n</pattern>
      </encoder>
   </appender>
   
   <appender name = "FILE" class = "ch.qos.logback.core.FileAppender">
      <File>/var/tmp/mylog.log</File>
      <encoder>
         <pattern>[%d{yyyy-MM-dd'T'HH:mm:ss.sss'Z'}] [%C] [%t] [%L] [%-5p] %m%n</pattern>
      </encoder>
   </appender>
   
   <root level = "INFO">
      <appender-ref ref = "FILE"/>
      <appender-ref ref = "STDOUT"/> 
   </root>
</configuration>

नीचे दिया गया कोड स्प्रिंग बूट मुख्य वर्ग फ़ाइल में slf4j लकड़हारा जोड़ने का तरीका दिखाता है।

package com.tutorialspoint.demo;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   private static final Logger logger = LoggerFactory.getLogger(DemoApplication.class);
   
   public static void main(String[] args) {
      logger.info("this is a info message");
      logger.warn("this is a warn message");
      logger.error("this is a error message");
      SpringApplication.run(DemoApplication.class, args);
   }
}

कंसोल विंडो में आप जो आउटपुट देख सकते हैं वह यहां दिखाया गया है -

लॉग फ़ाइल में आप जो आउटपुट देख सकते हैं वह यहाँ दिखाया गया है -

स्प्रिंग बूट एंटरप्राइज़ अनुप्रयोगों के लिए Restful Web Services के निर्माण के लिए एक बहुत अच्छा समर्थन प्रदान करता है। यह अध्याय स्प्रिंग बूट का उपयोग करके रेस्टफुल वेब सेवाओं के निर्माण के बारे में विस्तार से बताएगा।

Note - Restful Web Services के निर्माण के लिए, हमें निर्माण विन्यास फाइल में स्प्रिंग बूट स्टार्टर वेब निर्भरता जोड़ने की आवश्यकता है।

यदि आप एक मावेन उपयोगकर्ता हैं, तो अपने में नीचे निर्भरता जोड़ने के लिए निम्न कोड का उपयोग करें pom.xml फ़ाइल -

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>    
</dependency>

यदि आप एक ग्रेडल उपयोगकर्ता हैं, तो अपने नीचे निर्भरता जोड़ने के लिए निम्न कोड का उपयोग करें build.gradle फ़ाइल।

compile('org.springframework.boot:spring-boot-starter-web')

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए कोड Maven build – pom.xml नीचे दिया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>
   
   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> 
   </parent>
   
   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>
   
   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>
   
   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए कोड Gradle Build – build.gradle नीचे दिया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

इससे पहले कि आप एक RESTful वेब सेवा बनाने के लिए आगे बढ़ें, यह सुझाव दिया जाता है कि आपको निम्नलिखित एनोटेशन का ज्ञान है -

बाकी नियंत्रक

Restful वेब सेवाओं को परिभाषित करने के लिए @RestController एनोटेशन का उपयोग किया जाता है। यह JSON, XML और कस्टम प्रतिक्रिया देता है। इसका सिंटैक्स नीचे दिखाया गया है -

@RestController
public class ProductServiceController { 
}

मानचित्रण का अनुरोध करें

REST समापन बिंदु तक पहुँचने के लिए अनुरोध URI को परिभाषित करने के लिए @RequestMapping एनोटेशन का उपयोग किया जाता है। हम ऑब्जेक्ट का उपभोग और उत्पादन करने के लिए अनुरोध विधि को परिभाषित कर सकते हैं। डिफ़ॉल्ट अनुरोध विधि GET है।

@RequestMapping(value = "/products")
public ResponseEntity<Object> getProducts() { }

शरीर का अनुरोध करें

@RequestBody एनोटेशन का उपयोग अनुरोध बॉडी कंटेंट प्रकार को परिभाषित करने के लिए किया जाता है।

public ResponseEntity<Object> createProduct(@RequestBody Product product) {
}

पथ चर

@PathVariable एनोटेशन का उपयोग कस्टम या गतिशील अनुरोध URI को परिभाषित करने के लिए किया जाता है। अनुरोध URI में पथ चर को घुंघराले ब्रेस के रूप में परिभाषित किया गया है {} जैसा कि नीचे दिखाया गया है -

public ResponseEntity<Object> updateProduct(@PathVariable("id") String id) {
}

अनुरोध पैरामीटर

अनुरोध URL से अनुरोध पैरामीटर पढ़ने के लिए @RequestParam एनोटेशन का उपयोग किया जाता है। डिफ़ॉल्ट रूप से, यह एक आवश्यक पैरामीटर है। हम यहां दिखाए गए अनुरोध मानदंड के लिए डिफ़ॉल्ट मान भी सेट कर सकते हैं -

public ResponseEntity<Object> getProduct(
   @RequestParam(value = "name", required = false, defaultValue = "honey") String name) {
}

एपीआई प्राप्त करें

डिफ़ॉल्ट HTTP अनुरोध विधि GET है। इस विधि को किसी भी अनुरोध निकाय की आवश्यकता नहीं है। आप कस्टम या डायनामिक URL को परिभाषित करने के लिए अनुरोध पैरामीटर और पथ चर भेज सकते हैं।

HTTP GET अनुरोध विधि को परिभाषित करने के लिए नमूना कोड नीचे दिखाया गया है। इस उदाहरण में, हमने HashMap का उपयोग उत्पाद को संग्रहीत करने के लिए किया। ध्यान दें कि हमने संग्रहित किए जाने वाले उत्पाद के रूप में एक POJO वर्ग का उपयोग किया था।

यहाँ, अनुरोध URI है /productsऔर यह HashMap भंडार से उत्पादों की सूची वापस कर देगा। नियंत्रक वर्ग फ़ाइल नीचे दी गई है जिसमें GET विधि REST समापन बिंदु है।

package com.tutorialspoint.demo.controller;

import java.util.HashMap;
import java.util.Map;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.tutorialspoint.demo.model.Product;

@RestController
public class ProductServiceController {
   private static Map<String, Product> productRepo = new HashMap<>();
   static {
      Product honey = new Product();
      honey.setId("1");
      honey.setName("Honey");
      productRepo.put(honey.getId(), honey);
      
      Product almond = new Product();
      almond.setId("2");
      almond.setName("Almond");
      productRepo.put(almond.getId(), almond);
   }
   @RequestMapping(value = "/products")
   public ResponseEntity<Object> getProduct() {
      return new ResponseEntity<>(productRepo.values(), HttpStatus.OK);
   }
}

पोस्ट एपीआई

HTTP POST अनुरोध का उपयोग संसाधन बनाने के लिए किया जाता है। इस विधि में अनुरोध निकाय है। हम कस्टम या डायनामिक URL को परिभाषित करने के लिए अनुरोध पैरामीटर और पथ चर भेज सकते हैं।

निम्न उदाहरण HTTP POST अनुरोध विधि को परिभाषित करने के लिए नमूना कोड दिखाता है। इस उदाहरण में, हमने उत्पाद को संग्रहीत करने के लिए HashMap का उपयोग किया, जहां उत्पाद एक POJO वर्ग है।

यहाँ, अनुरोध URI है /products, और यह HashMap रिपॉजिटरी में उत्पाद को संग्रहीत करने के बाद स्ट्रिंग को वापस कर देगा।

package com.tutorialspoint.demo.controller;

import java.util.HashMap;
import java.util.Map;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import com.tutorialspoint.demo.model.Product;

@RestController
public class ProductServiceController {
   private static Map<String, Product> productRepo = new HashMap<>();
   
   @RequestMapping(value = "/products", method = RequestMethod.POST)
   public ResponseEntity<Object> createProduct(@RequestBody Product product) {
      productRepo.put(product.getId(), product);
      return new ResponseEntity<>("Product is created successfully", HttpStatus.CREATED);
   }
}

PUT एपीआई

HTTP PUT अनुरोध का उपयोग मौजूदा संसाधन को अपडेट करने के लिए किया जाता है। इस विधि में एक अनुरोध निकाय है। हम कस्टम या डायनामिक URL को परिभाषित करने के लिए अनुरोध पैरामीटर और पथ चर भेज सकते हैं।

नीचे दिया गया उदाहरण दिखाता है कि HTTP PUT अनुरोध विधि को कैसे परिभाषित किया जाए। इस उदाहरण में, हमने मौजूदा उत्पाद को अपडेट करने के लिए HashMap का उपयोग किया, जहां उत्पाद POJO वर्ग है।

यहाँ अनुरोध URI है /products/{id}जो एक हैशपॉप रिपॉजिटरी में उत्पाद के बाद स्ट्रिंग को वापस कर देगा। ध्यान दें कि हमने पथ चर का उपयोग किया है{id} जो उत्पादों की आईडी को परिभाषित करता है जिसे अद्यतन करने की आवश्यकता होती है।

package com.tutorialspoint.demo.controller;

import java.util.HashMap;
import java.util.Map;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.tutorialspoint.demo.model.Product;

@RestController
public class ProductServiceController {
   private static Map<String, Product> productRepo = new HashMap<>();
   
   @RequestMapping(value = "/products/{id}", method = RequestMethod.PUT)
   public ResponseEntity<Object> updateProduct(@PathVariable("id") String id, @RequestBody Product product) { 
      productRepo.remove(id);
      product.setId(id);
      productRepo.put(id, product);
      return new ResponseEntity<>("Product is updated successsfully", HttpStatus.OK);
   }   
}

DELETE API

मौजूदा संसाधन को हटाने के लिए HTTP डिलीट अनुरोध का उपयोग किया जाता है। इस विधि में कोई अनुरोध निकाय शामिल नहीं है। हम कस्टम या डायनामिक URL को परिभाषित करने के लिए अनुरोध पैरामीटर और पथ चर भेज सकते हैं।

नीचे दिया गया उदाहरण दिखाता है कि HTTP DELETE अनुरोध विधि को कैसे परिभाषित किया जाए। इस उदाहरण में, हमने मौजूदा उत्पाद को हटाने के लिए HashMap का उपयोग किया, जो एक POJO वर्ग है।

URI का अनुरोध है /products/{id}और यह HashMap रिपॉजिटरी से उत्पाद को हटाने के बाद स्ट्रिंग को वापस कर देगा। हमने पथ चर का उपयोग किया{id} जो उन उत्पादों की आईडी को परिभाषित करता है जिन्हें हटाने की आवश्यकता होती है।

package com.tutorialspoint.demo.controller;

import java.util.HashMap;
import java.util.Map;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import com.tutorialspoint.demo.model.Product;

@RestController
public class ProductServiceController {
   private static Map<String, Product> productRepo = new HashMap<>();
   
   @RequestMapping(value = "/products/{id}", method = RequestMethod.DELETE)
   public ResponseEntity<Object> delete(@PathVariable("id") String id) { 
      productRepo.remove(id);
      return new ResponseEntity<>("Product is deleted successsfully", HttpStatus.OK);
   }
}

यह खंड आपको स्रोत कोड का पूरा सेट देता है। निम्नलिखित कोड उनके संबंधित कार्यात्मकताओं के लिए देखें -

The Spring Boot main application class – DemoApplication.java

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

The POJO class – Product.java

package com.tutorialspoint.demo.model;

public class Product {
   private String id;
   private String name;

   public String getId() {
      return id;
   }
   public void setId(String id) {
      this.id = id;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name;
   }
}

The Rest Controller class – ProductServiceController.java

package com.tutorialspoint.demo.controller;

import java.util.HashMap;
import java.util.Map;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import com.tutorialspoint.demo.model.Product;

@RestController
public class ProductServiceController {
   private static Map<String, Product> productRepo = new HashMap<>();
   static {
      Product honey = new Product();
      honey.setId("1");
      honey.setName("Honey");
      productRepo.put(honey.getId(), honey);
      
      Product almond = new Product();
      almond.setId("2");
      almond.setName("Almond");
      productRepo.put(almond.getId(), almond);
   }
   
   @RequestMapping(value = "/products/{id}", method = RequestMethod.DELETE)
   public ResponseEntity<Object> delete(@PathVariable("id") String id) { 
      productRepo.remove(id);
      return new ResponseEntity<>("Product is deleted successsfully", HttpStatus.OK);
   }
   
   @RequestMapping(value = "/products/{id}", method = RequestMethod.PUT)
   public ResponseEntity<Object> updateProduct(@PathVariable("id") String id, @RequestBody Product product) { 
      productRepo.remove(id);
      product.setId(id);
      productRepo.put(id, product);
      return new ResponseEntity<>("Product is updated successsfully", HttpStatus.OK);
   }
   
   @RequestMapping(value = "/products", method = RequestMethod.POST)
   public ResponseEntity<Object> createProduct(@RequestBody Product product) {
      productRepo.put(product.getId(), product);
      return new ResponseEntity<>("Product is created successfully", HttpStatus.CREATED);
   }
   
   @RequestMapping(value = "/products")
   public ResponseEntity<Object> getProduct() {
      return new ResponseEntity<>(productRepo.values(), HttpStatus.OK);
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिए गए मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, नीचे दिखाए गए कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, नीचे दिखाए गए कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

आप नीचे दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चला सकते हैं -

java –jar <JARFILE>

यह नीचे दिखाए गए अनुसार टॉमकैट पोर्ट 8080 पर आवेदन शुरू करेगा -

अब POSTMAN एप्लिकेशन में नीचे दिखाए गए URL को हिट करें और आउटपुट देखें।

GET API URL है: http://localhost:8080/products

POST API URL है: http://localhost:8080/products

PUT API URL है: http://localhost:8080/products/3

DELETE API URL है: http://localhost:8080/products/3

एपीआई में अपवाद और त्रुटियों को संभालना और क्लाइंट को उचित प्रतिक्रिया भेजना उद्यम अनुप्रयोगों के लिए अच्छा है। इस अध्याय में, हम सीखेंगे कि स्प्रिंग बूट में अपवादों को कैसे संभालना है।

अपवाद से निपटने के लिए आगे बढ़ने से पहले, आइए निम्नलिखित एनोटेशन पर एक समझ हासिल करें।

नियंत्रक सलाह

@ControllerAdvice एक एनोटेशन है, विश्व स्तर पर अपवादों को संभालने के लिए।

अपवाद हैंडलर

@ExceptionHandler एक एनोटेशन है जिसका उपयोग विशिष्ट अपवादों को संभालने और क्लाइंट को कस्टम प्रतिक्रियाएं भेजने के लिए किया जाता है।

विश्व स्तर पर अपवादों को संभालने के लिए आप @ControllerAdvice क्लास बनाने के लिए निम्न कोड का उपयोग कर सकते हैं -

package com.tutorialspoint.demo.exception;

import org.springframework.web.bind.annotation.ControllerAdvice;

@ControllerAdvice
   public class ProductExceptionController {
}

एक वर्ग परिभाषित करें जो RuntimeException वर्ग का विस्तार करता है।

package com.tutorialspoint.demo.exception;

public class ProductNotfoundException extends RuntimeException {
   private static final long serialVersionUID = 1L;
}

आप अपवादों को दिखाने के लिए @ExceptionHandler विधि को परिभाषित कर सकते हैं। इस विधि का उपयोग नियंत्रक सलाह वर्ग फ़ाइल लिखने के लिए किया जाना चाहिए।

@ExceptionHandler(value = ProductNotfoundException.class)

public ResponseEntity<Object> exception(ProductNotfoundException exception) {
}

अब, एपीआई से अपवाद को फेंकने के लिए नीचे दिए गए कोड का उपयोग करें।

@RequestMapping(value = "/products/{id}", method = RequestMethod.PUT)
public ResponseEntity<Object> updateProduct() { 
   throw new ProductNotfoundException();
}

अपवाद को संभालने का पूरा कोड नीचे दिया गया है। इस उदाहरण में, हमने उत्पाद को अपडेट करने के लिए PUT API का उपयोग किया। यहां, उत्पाद को अपडेट करते समय, यदि उत्पाद नहीं मिला है, तो "उत्पाद नहीं मिला" के रूप में प्रतिक्रिया त्रुटि संदेश लौटाएं। ध्यान दें किProductNotFoundException अपवाद वर्ग को विस्तार करना चाहिए RuntimeException

package com.tutorialspoint.demo.exception;
public class ProductNotfoundException extends RuntimeException {
   private static final long serialVersionUID = 1L;
}

विश्व स्तर पर अपवाद को संभालने के लिए नियंत्रक सलाह वर्ग नीचे दिया गया है। हम इस श्रेणी फ़ाइल में किसी भी अपवाद हैंडलर विधियों को परिभाषित कर सकते हैं।

package com.tutorialspoint.demo.exception;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;

@ControllerAdvice
public class ProductExceptionController {
   @ExceptionHandler(value = ProductNotfoundException.class)
   public ResponseEntity<Object> exception(ProductNotfoundException exception) {
      return new ResponseEntity<>("Product not found", HttpStatus.NOT_FOUND);
   }
}

उत्पाद को अद्यतन करने के लिए उत्पाद सेवा एपीआई नियंत्रक फ़ाइल नीचे दी गई है। यदि उत्पाद नहीं मिला है, तो यह फेंकता हैProductNotFoundException कक्षा।

package com.tutorialspoint.demo.controller;

import java.util.HashMap;
import java.util.Map;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import com.tutorialspoint.demo.exception.ProductNotfoundException;
import com.tutorialspoint.demo.model.Product;

@RestController
public class ProductServiceController {
   private static Map<String, Product> productRepo = new HashMap<>();
   static {
      Product honey = new Product();
      honey.setId("1");
      honey.setName("Honey");
      productRepo.put(honey.getId(), honey);
      
      Product almond = new Product();
      almond.setId("2");
      almond.setName("Almond");
      productRepo.put(almond.getId(), almond);
   }
   
   @RequestMapping(value = "/products/{id}", method = RequestMethod.PUT)
   public ResponseEntity<Object> updateProduct(@PathVariable("id") String id, @RequestBody Product product) { 
      if(!productRepo.containsKey(id))throw new ProductNotfoundException();
      productRepo.remove(id);
      product.setId(id);
      productRepo.put(id, product);
      return new ResponseEntity<>("Product is updated successfully", HttpStatus.OK);
   }
}

मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल का कोड नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

के लिए कोड POJO class उत्पाद के लिए नीचे दिया गया है -

package com.tutorialspoint.demo.model;
public class Product {
   private String id;
   private String name;

   public String getId() {
      return id;
   }
   public void setId(String id) {
      this.id = id;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name;
   }
}

के लिए कोड Maven build – pom.xml नीचे दिखाया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> 
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

के लिए कोड Gradle Build – build.gradle नीचे दिया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

आप JAR फ़ाइल को निम्न कमांड का उपयोग करके चला सकते हैं -

java –jar <JARFILE>

यह नीचे दिखाए गए अनुसार टॉमकैट पोर्ट 8080 पर आवेदन शुरू करेगा -

अब POSTMAN एप्लिकेशन में नीचे दिए गए URL को हिट करें और आप नीचे दिखाए अनुसार आउटपुट देख सकते हैं -

अद्यतन URL: http: // localhost: 8080 / उत्पाद / 3

आप निम्न परिस्थितियों में ऑपरेशन करने के लिए स्प्रिंग बूट में इंटरसेप्टर का उपयोग कर सकते हैं -

  • नियंत्रक को अनुरोध भेजने से पहले

  • ग्राहक को प्रतिक्रिया भेजने से पहले

उदाहरण के लिए, आप नियंत्रक को अनुरोध भेजने से पहले अनुरोध हेडर जोड़ने के लिए इंटरसेप्टर का उपयोग कर सकते हैं और क्लाइंट को प्रतिक्रिया भेजने से पहले प्रतिक्रिया हेडर जोड़ सकते हैं।

इंटरसेप्टर के साथ काम करने के लिए, आपको बनाने की आवश्यकता है @Component वर्ग जो इसका समर्थन करता है और इसे लागू करना चाहिए HandlerInterceptor इंटरफेस।

निम्नलिखित तीन तरीके हैं जिनके बारे में आपको इंटरसेप्टर पर काम करते समय पता होना चाहिए -

  • preHandle()विधि - इसका उपयोग नियंत्रक को अनुरोध भेजने से पहले संचालन करने के लिए किया जाता है। क्लाइंट को प्रतिक्रिया देने के लिए इस विधि को सही लौटना चाहिए।

  • postHandle() विधि - इसका उपयोग क्लाइंट को प्रतिक्रिया भेजने से पहले ऑपरेशन करने के लिए किया जाता है।

  • afterCompletion() विधि - यह अनुरोध और प्रतिक्रिया को पूरा करने के बाद संचालन करने के लिए उपयोग किया जाता है।

एक बेहतर समझ के लिए निम्नलिखित कोड देखें -

@Component
public class ProductServiceInterceptor implements HandlerInterceptor {
   @Override
   public boolean preHandle(
      HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
      
      return true;
   }
   @Override
   public void postHandle(
      HttpServletRequest request, HttpServletResponse response, Object handler, 
      ModelAndView modelAndView) throws Exception {}
   
   @Override
   public void afterCompletion(HttpServletRequest request, HttpServletResponse response, 
      Object handler, Exception exception) throws Exception {}
}

आपको इस इंटरसेप्टर को पंजीकृत करना होगा InterceptorRegistry का उपयोग करके WebMvcConfigurerAdapter जैसा कि नीचे दिखाया गया है -

@Component
public class ProductServiceInterceptorAppConfig extends WebMvcConfigurerAdapter {
   @Autowired
   ProductServiceInterceptor productServiceInterceptor;

   @Override
   public void addInterceptors(InterceptorRegistry registry) {
      registry.addInterceptor(productServiceInterceptor);
   }
}

नीचे दिए गए उदाहरण में, हम GET उत्पादों API को हिट करने जा रहे हैं, जो निम्न के रूप में आउटपुट देता है -

इंटरसेप्टर वर्ग ProductServiceInterceptor.java के लिए कोड नीचे दिया गया है -

package com.tutorialspoint.demo.interceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

@Component
public class ProductServiceInterceptor implements HandlerInterceptor {
   @Override
   public boolean preHandle
      (HttpServletRequest request, HttpServletResponse response, Object handler) 
      throws Exception {
      
      System.out.println("Pre Handle method is Calling");
      return true;
   }
   @Override
   public void postHandle(HttpServletRequest request, HttpServletResponse response, 
      Object handler, ModelAndView modelAndView) throws Exception {
      
      System.out.println("Post Handle method is Calling");
   }
   @Override
   public void afterCompletion
      (HttpServletRequest request, HttpServletResponse response, Object 
      handler, Exception exception) throws Exception {
      
      System.out.println("Request and Response is completed");
   }
}

इंटरसेप्टर को इंटरसेप्टर रजिस्ट्री में पंजीकृत करने के लिए एप्लिकेशन कॉन्फ़िगरेशन क्लास फ़ाइल के लिए कोड - ProductServiceInterceptorAppConfig.java नीचे दिया गया है -

package com.tutorialspoint.demo.interceptor;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

@Component
public class ProductServiceInterceptorAppConfig extends WebMvcConfigurerAdapter {
   @Autowired
   ProductServiceInterceptor productServiceInterceptor;

   @Override
   public void addInterceptors(InterceptorRegistry registry) {
      registry.addInterceptor(productServiceInterceptor);
   }
}

कंट्रोलर क्लास फ़ाइल ProductServiceController.java का कोड नीचे दिया गया है -

package com.tutorialspoint.demo.controller;

import java.util.HashMap;
import java.util.Map;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.tutorialspoint.demo.exception.ProductNotfoundException;
import com.tutorialspoint.demo.model.Product;

@RestController
public class ProductServiceController {
   private static Map<String, Product> productRepo = new HashMap<>();   
   static {      
      Product honey = new Product();
      honey.setId("1");
      honey.setName("Honey");
      productRepo.put(honey.getId(), honey);      
      Product almond = new Product();
      almond.setId("2");
      almond.setName("Almond");
      productRepo.put(almond.getId(), almond);      
   }
   @RequestMapping(value = "/products")
   public ResponseEntity<Object> getProduct() {
      return new ResponseEntity<>(productRepo.values(), HttpStatus.OK);
   }
}

Product.java के लिए POJO वर्ग के लिए कोड नीचे दिया गया है -

package com.tutorialspoint.demo.model;

public class Product {
   private String id;
   private String name;

   public String getId() {
      return id;
   }
   public void setId(String id) {
      this.id = id;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name;
   }
}

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल के लिए कोड DemoApplication.java नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);   
   }
}

मावेन बिल्ड के लिए कोड - pom.xml यहाँ दिखाया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" xmlns:xsi = "
   http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> 
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

ग्रेड बिल्ड के लिए कोड build.gradle यहाँ दिखाया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'
group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

मावेन के लिए, नीचे दिखाए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, नीचे दिखाए अनुसार कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

आप JAR फ़ाइल को निम्न कमांड का उपयोग करके चला सकते हैं -

java –jar <JARFILE>

अब, नीचे दिखाए गए अनुसार टॉमकैट पोर्ट 8080 पर आवेदन शुरू हो गया है -

अब POSTMAN एप्लिकेशन में नीचे दिए गए URL को हिट करें और आप नीचे दिखाए अनुसार आउटपुट देख सकते हैं -

एपीआई प्राप्त करें: http://localhost:8080/products

कंसोल विंडो में, आप इंटरसेप्टर में जोड़े गए System.out.println स्टेटमेंट देख सकते हैं जैसा कि नीचे दिए गए स्क्रीनशॉट में दिखाया गया है -

एक फ़िल्टर एक ऐसी वस्तु है जिसका उपयोग HTTP अनुरोध और आपके आवेदन की प्रतिक्रियाओं को बाधित करने के लिए किया जाता है। फ़िल्टर का उपयोग करके, हम दो उदाहरणों में दो ऑपरेशन कर सकते हैं -

  • नियंत्रक को अनुरोध भेजने से पहले
  • ग्राहक को प्रतिक्रिया भेजने से पहले।

निम्न कोड @Component एनोटेशन के साथ एक सर्वलेट फ़िल्टर कार्यान्वयन वर्ग के लिए नमूना कोड दिखाता है।

@Component
public class SimpleFilter implements Filter {
   @Override
   public void destroy() {}

   @Override
   public void doFilter
      (ServletRequest request, ServletResponse response, FilterChain filterchain) 
      throws IOException, ServletException {}

   @Override
   public void init(FilterConfig filterconfig) throws ServletException {}
}

निम्नलिखित उदाहरण नियंत्रक को अनुरोध भेजने से पहले दूरस्थ होस्ट और दूरस्थ पते को ServletRequest ऑब्जेक्ट से पढ़ने के लिए कोड दिखाता है।

DoFilter () पद्धति में, हमने दूरस्थ मेजबान और दूरस्थ पते को प्रिंट करने के लिए System.out.println स्टेटमेंट को जोड़ा है।

package com.tutorialspoint.demo;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;

import org.springframework.stereotype.Component;

@Component
public class SimpleFilter implements Filter {
   @Override
   public void destroy() {}

   @Override
   public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterchain) 
      throws IOException, ServletException {
      
      System.out.println("Remote Host:"+request.getRemoteHost());
      System.out.println("Remote Address:"+request.getRemoteAddr());
      filterchain.doFilter(request, response);
   }

   @Override
   public void init(FilterConfig filterconfig) throws ServletException {}
}

स्प्रिंग बूट मुख्य एप्लिकेशन क्लास फ़ाइल में, हमने सरल रीस्ट एंडपॉइंट जोड़ा है जो "हैलो वर्ल्ड" स्ट्रिंग लौटाता है।

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   @RequestMapping(value = "/")
   public String hello() {
      return "Hello World";
   }
}

मावेन बिल्ड के लिए कोड - pom.xml नीचे दिया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" xmlns:xsi = "
   http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> 
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

ग्रेडल बिल्ड - बिल्ड.ग्रेड के लिए कोड नीचे दिया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिखाए गए मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, नीचे दिखाए अनुसार कमांड का उपयोग करें -

mvn clean install

BUILD SUCCESS के बाद, आप JAR फ़ाइल को लक्ष्य निर्देशिका के अंतर्गत पा सकते हैं।

ग्रेडल के लिए, नीचे दिखाए अनुसार कमांड का उपयोग करें -

gradle clean build

BUILD SUCCESSFUL के बाद, आप JAR फाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, JAR फ़ाइल को निम्न कमांड का उपयोग करके चलाएं

java –jar <JARFILE>

आप देख सकते हैं कि आवेदन टॉमकैट पोर्ट 8080 पर शुरू हो गया है।

अब URL को हिट करें http://localhost:8080/और आउटपुट देखें हैलो वर्ल्ड। इसे नीचे दिखाया गया है -

फिर, आप नीचे दिखाए अनुसार कंसोल होस्ट पर रिमोट होस्ट और रिमोट एड्रेस देख सकते हैं -

स्प्रिंग बूट आपको एक ही एप्लीकेशन को एक अलग पोर्ट नंबर पर एक से अधिक बार चलाने की सुविधा देता है। इस अध्याय में, आप इसके बारे में विस्तार से जानेंगे। ध्यान दें कि डिफ़ॉल्ट पोर्ट संख्या 8080।

कस्टम बंदरगाह

में application.properties फ़ाइल, हम प्रॉपर्टी सर्वर.पोर्ट के लिए कस्टम पोर्ट नंबर सेट कर सकते हैं

server.port = 9090

में application.yml फ़ाइल, आप निम्नानुसार पा सकते हैं -

server: 
   port: 9090

रैंडम पोर्ट

में application.properties फ़ाइल, हम संपत्ति server.port के लिए यादृच्छिक पोर्ट नंबर सेट कर सकते हैं

server.port = 0

में application.yml फ़ाइल, आप निम्नानुसार पा सकते हैं -

server: 
   port: 0

Note - अगर server.port स्प्रिंग बूट एप्लिकेशन शुरू करते समय नंबर 0 है, टॉमकैट यादृच्छिक पोर्ट नंबर का उपयोग करता है।

रेस्ट टेम्प्लेट का उपयोग उन एप्लिकेशन को बनाने के लिए किया जाता है जो रेस्टफुल वेब सर्विसेज का उपभोग करते हैं। आप उपयोग कर सकते हैंexchange()सभी HTTP विधियों के लिए वेब सेवाओं का उपभोग करने की विधि। नीचे दिए गए कोड से पता चलता है कि रेस्ट टेम्प्लेट को ऑटो टेस्टिंग करने के लिए रेस्ट टेम्प्लेट के लिए बीन कैसे बनाएं

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   @Bean
   public RestTemplate getRestTemplate() {
      return new RestTemplate();
   }
}

प्राप्त

Consuming the GET API by using RestTemplate - exchange() method

इस URL को मान लें http://localhost:8080/products निम्नलिखित JSON लौटाता है और हम निम्नलिखित कोड का उपयोग करके रेस्ट टेम्प्लेट का उपयोग करके इस एपीआई प्रतिक्रिया का उपभोग करने जा रहे हैं -

[
   {
      "id": "1",
      "name": "Honey"
   },
   {
      "id": "2",
      "name": "Almond"
   }
]

एपीआई का उपभोग करने के लिए आपको दिए गए बिंदुओं का पालन करना होगा -

  • रेस्ट टेम्प्लेट ऑब्जेक्ट को स्वत: प्राप्त किया।
  • अनुरोध हेडर सेट करने के लिए HttpHeaders का उपयोग करें।
  • अनुरोध ऑब्जेक्ट को लपेटने के लिए HttpEntity का उपयोग करें।
  • URL, HttpMethod, और Exchange () विधि के लिए रिटर्न प्रकार प्रदान करें।
@RestController
public class ConsumeWebService {
   @Autowired
   RestTemplate restTemplate;

   @RequestMapping(value = "/template/products")
   public String getProductList() {
      HttpHeaders headers = new HttpHeaders();
      headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
      HttpEntity <String> entity = new HttpEntity<String>(headers);
      
      return restTemplate.exchange("
         http://localhost:8080/products", HttpMethod.GET, entity, String.class).getBody();
   }
}

पद

Consuming POST API by using RestTemplate - exchange() method

इस URL को मान लें http://localhost:8080/products नीचे दर्शाई गई प्रतिक्रिया देता है, हम रेस्ट टेम्प्लेट का उपयोग करके इस एपीआई प्रतिक्रिया का उपभोग करने जा रहे हैं।

नीचे दिया गया कोड अनुरोध निकाय है -

{
   "id":"3",
   "name":"Ginger"
}

नीचे दिया गया कोड रिस्पांस बॉडी है -

Product is created successfully

एपीआई का उपभोग करने के लिए आपको नीचे दिए गए बिंदुओं का पालन करना होगा -

  • रेस्ट टेम्प्लेट ऑब्जेक्ट को स्वत: प्राप्त किया।

  • अनुरोध हेडर सेट करने के लिए HttpHeaders का उपयोग करें।

  • अनुरोध ऑब्जेक्ट को लपेटने के लिए HttpEntity का उपयोग करें। यहां, हम अनुरोध ऑब्जेक्ट को भेजने के लिए उत्पाद ऑब्जेक्ट को लपेटते हैं।

  • URL, HttpMethod, और वापसी प्रकार विनिमय () विधि के लिए प्रदान करें।

@RestController
public class ConsumeWebService {
   @Autowired
   RestTemplate restTemplate;

   @RequestMapping(value = "/template/products", method = RequestMethod.POST)
   public String createProducts(@RequestBody Product product) {
      HttpHeaders headers = new HttpHeaders();
      headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
      HttpEntity<Product> entity = new HttpEntity<Product>(product,headers);
      
      return restTemplate.exchange(
         "http://localhost:8080/products", HttpMethod.POST, entity, String.class).getBody();
   }
}

डाल

Consuming PUT API by using RestTemplate - exchange() method

इस URL को मान लें http://localhost:8080/products/3 नीचे की प्रतिक्रिया देता है और हम रेस्ट टेम्प्लेट का उपयोग करके इस एपीआई प्रतिक्रिया का उपभोग करने जा रहे हैं।

नीचे दिया गया कोड अनुरोध निकाय है -

{
   "name":"Indian Ginger"
}

नीचे दिया गया कोड रिस्पांस बॉडी है -

Product is updated successfully

एपीआई का उपभोग करने के लिए आपको नीचे दिए गए बिंदुओं का पालन करना होगा -

  • रेस्ट टेम्प्लेट ऑब्जेक्ट को स्वत: प्राप्त किया।

  • अनुरोध हेडर सेट करने के लिए HttpHeaders का उपयोग करें।

  • अनुरोध ऑब्जेक्ट को लपेटने के लिए HttpEntity का उपयोग करें। यहां, हम अनुरोध ऑब्जेक्ट को भेजने के लिए उत्पाद ऑब्जेक्ट को लपेटते हैं।

  • URL, HttpMethod, और वापसी प्रकार विनिमय () विधि के लिए प्रदान करें।

@RestController
public class ConsumeWebService {
   @Autowired
   RestTemplate restTemplate;

   @RequestMapping(value = "/template/products/{id}", method = RequestMethod.PUT)
   public String updateProduct(@PathVariable("id") String id, @RequestBody Product product) {
      HttpHeaders headers = new HttpHeaders();
      headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
      HttpEntity<Product> entity = new HttpEntity<Product>(product,headers);
      
      return restTemplate.exchange(
         "http://localhost:8080/products/"+id, HttpMethod.PUT, entity, String.class).getBody();
   }
}

हटाएँ

Consuming DELETE API by using RestTemplate - exchange() method

इस URL को मान लें http://localhost:8080/products/3 नीचे दी गई प्रतिक्रिया देता है और हम रेस्ट टेम्प्लेट का उपयोग करके इस एपीआई प्रतिक्रिया का उपभोग करने जा रहे हैं।

नीचे दर्शाई गई कोड की यह लाइन रिस्पॉन्स बॉडी है -

Product is deleted successfully

एपीआई का उपभोग करने के लिए आपको नीचे दिखाए गए बिंदुओं का पालन करना होगा -

  • रेस्ट टेम्प्लेट ऑब्जेक्ट को स्वत: प्राप्त किया।

  • अनुरोध हेडर सेट करने के लिए HttpHeaders का उपयोग करें।

  • अनुरोध ऑब्जेक्ट को लपेटने के लिए HttpEntity का उपयोग करें।

  • URL, HttpMethod, और वापसी प्रकार विनिमय () विधि के लिए प्रदान करें।

@RestController
public class ConsumeWebService {
   @Autowired
   RestTemplate restTemplate;

   @RequestMapping(value = "/template/products/{id}", method = RequestMethod.DELETE)
   public String deleteProduct(@PathVariable("id") String id) {
      HttpHeaders headers = new HttpHeaders();
      headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
      HttpEntity<Product> entity = new HttpEntity<Product>(headers);
      
      return restTemplate.exchange(
         "http://localhost:8080/products/"+id, HttpMethod.DELETE, entity, String.class).getBody();
   }
}

पूरा रेस्ट टेम्प्लेट कंट्रोलर क्लास फाइल नीचे दिया गया है -

package com.tutorialspoint.demo.controller;

import java.util.Arrays;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpEntity;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpMethod;
import org.springframework.http.MediaType;

import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

import com.tutorialspoint.demo.model.Product;

@RestController
public class ConsumeWebService {
   @Autowired
   RestTemplate restTemplate;

   @RequestMapping(value = "/template/products")
   public String getProductList() {
      HttpHeaders headers = new HttpHeaders();
      headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
      HttpEntity<String> entity = new HttpEntity<String>(headers);
      
      return restTemplate.exchange(
         "http://localhost:8080/products", HttpMethod.GET, entity, String.class).getBody();
   }
   @RequestMapping(value = "/template/products", method = RequestMethod.POST)
   public String createProducts(@RequestBody Product product) {
      HttpHeaders headers = new HttpHeaders();
      headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
      HttpEntity<Product> entity = new HttpEntity<Product>(product,headers);
      
      return restTemplate.exchange(
         "http://localhost:8080/products", HttpMethod.POST, entity, String.class).getBody();
   }
   @RequestMapping(value = "/template/products/{id}", method = RequestMethod.PUT)
   public String updateProduct(@PathVariable("id") String id, @RequestBody Product product) {
      HttpHeaders headers = new HttpHeaders();
      headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
      HttpEntity<Product> entity = new HttpEntity<Product>(product,headers);
      
      return restTemplate.exchange(
         "http://localhost:8080/products/"+id, HttpMethod.PUT, entity, String.class).getBody();
   }
   @RequestMapping(value = "/template/products/{id}", method = RequestMethod.DELETE)
   public String deleteProduct(@PathVariable("id") String id) {
      HttpHeaders headers = new HttpHeaders();
      headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
      HttpEntity<Product> entity = new HttpEntity<Product>(headers);
      
      return restTemplate.exchange(
         "http://localhost:8080/products/"+id, HttpMethod.DELETE, entity, String.class).getBody();
   }
}

स्प्रिंग बूट एप्लीकेशन क्लास के लिए कोड - DemoApplication.java नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

मावेन बिल्ड - pom.xml का कोड नीचे दिया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> 
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

ग्रेडल बिल्ड - बिल्ड.ग्रेड के लिए कोड नीचे दिया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्नलिखित Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप नीचे दिए गए कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप नीचे दिखाए गए कमांड का उपयोग कर सकते हैं -

gradle clean build

"BUILD SUCCESSFUL" के बाद, आप JAR फाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, JAR फ़ाइल को निम्न कमांड का उपयोग करके चलाएं -

java –jar <JARFILE>

अब, Tomcat पोर्ट 8080 पर आवेदन शुरू हो गया है।

अब POSTMAN एप्लिकेशन में नीचे दिए गए URL को हिट करें और आप आउटपुट देख सकते हैं।

बाकी टेम्पलेट द्वारा उत्पाद प्राप्त करें - http://localhost:8080/template/products

उत्पाद पोस्ट बनाएं - http://localhost:8080/template/products

उत्पाद का अद्यतन करें - http://localhost:8080/template/products/3

उत्पाद हटाएं - http://localhost:8080/template/products/3

इस अध्याय में, आप सीखेंगे कि वेब सेवा का उपयोग करके फ़ाइल को कैसे अपलोड करें और डाउनलोड करें।

फाइल अपलोड

फ़ाइल अपलोड करने के लिए, आप उपयोग कर सकते हैं MultipartFileअनुरोध पैरामीटर के रूप में और इस API को मल्टी-पार्ट फॉर्म डेटा मान का उपभोग करना चाहिए। नीचे दिए गए कोड को ध्यान से देखें -

@RequestMapping(value = "/upload", method = RequestMethod.POST, consumes = MediaType.MULTIPART_FORM_DATA_VALUE)

public String fileUpload(@RequestParam("file") MultipartFile file) {
   return null;
}

उसी के लिए पूरा कोड नीचे दिया गया है -

package com.tutorialspoint.demo.controller;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

@RestController
public class FileUploadController {
   @RequestMapping(value = "/upload", method = RequestMethod.POST, 
      consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
   
   public String fileUpload(@RequestParam("file") MultipartFile file) throws IOException {
      File convertFile = new File("/var/tmp/"+file.getOriginalFilename());
      convertFile.createNewFile();
      FileOutputStream fout = new FileOutputStream(convertFile);
      fout.write(file.getBytes());
      fout.close();
      return "File is upload successfully";
   }
}

फाइल डाउनलोड

फ़ाइल डाउनलोड के लिए, आपको फ़ाइल डाउनलोड करने के लिए InputStreamResource का उपयोग करना चाहिए। हमें HttpHeader को सेट करने की आवश्यकता हैContent-Disposition प्रतिक्रिया में और आवेदन की प्रतिक्रिया मीडिया प्रकार निर्दिष्ट करने की आवश्यकता है।

Note - निम्नलिखित उदाहरण में, फ़ाइल उस निर्दिष्ट पथ पर उपलब्ध होनी चाहिए जहां अनुप्रयोग चल रहा है।

@RequestMapping(value = "/download", method = RequestMethod.GET) 
public ResponseEntity<Object> downloadFile() throws IOException  {
   String filename = "/var/tmp/mysql.png";
   File file = new File(filename);
   InputStreamResource resource = new InputStreamResource(new FileInputStream(file));
   HttpHeaders headers = new HttpHeaders();
      
   headers.add("Content-Disposition", String.format("attachment; filename=\"%s\"", file.getName()));
   headers.add("Cache-Control", "no-cache, no-store, must-revalidate");
   headers.add("Pragma", "no-cache");
   headers.add("Expires", "0");
      
   ResponseEntity<Object> 
   responseEntity = ResponseEntity.ok().headers(headers).contentLength(file.length()).contentType(
      MediaType.parseMediaType("application/txt")).body(resource);
      
   return responseEntity;
}

उसी के लिए पूरा कोड नीचे दिया गया है -

package com.tutorialspoint.demo.controller;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;

import org.springframework.core.io.InputStreamResource;
import org.springframework.http.HttpHeaders;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class FileDownloadController {
   @RequestMapping(value = "/download", method = RequestMethod.GET) 
   public ResponseEntity<Object> downloadFile() throws IOException  {
      String filename = "/var/tmp/mysql.png";
      File file = new File(filename);
      InputStreamResource resource = new InputStreamResource(new FileInputStream(file));
      HttpHeaders headers = new HttpHeaders();
      
      headers.add("Content-Disposition", String.format("attachment; filename=\"%s\"", file.getName()));
      headers.add("Cache-Control", "no-cache, no-store, must-revalidate");
      headers.add("Pragma", "no-cache");
      headers.add("Expires", "0");
      
      ResponseEntity<Object> 
      responseEntity = ResponseEntity.ok().headers(headers).contentLength(
         file.length()).contentType(MediaType.parseMediaType("application/txt")).body(resource);
      
      return responseEntity;
   }
}

मुख्य स्प्रिंग बूट आवेदन नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

मावेन बिल्ड - pom.xml का कोड नीचे दिया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> 
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

ग्रेडल बिल्ड - बिल्ड.ग्रेड के लिए कोड नीचे दिया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

अब आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिए गए Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, नीचे दी गई कमांड का उपयोग करें -

mvn clean install

"बिल्ड सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप नीचे दिखाए गए कमांड का उपयोग करेंगे -

sgradle clean build

"BUILD SUCCESSFUL" के बाद, आप JAR फाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, JAR फ़ाइल को निम्न कमांड का उपयोग करके चलाएं -

java –jar <JARFILE>

यह नीचे दिखाए गए अनुसार टॉमकैट पोर्ट 8080 पर आवेदन शुरू करेगा -

अब POSTMAN एप्लिकेशन में नीचे दिए गए URL को हिट करें और आप नीचे दिखाए अनुसार आउटपुट देख सकते हैं -

फ़ाइल अपलोड - http://localhost:8080/upload

फ़ाइल डाउनलोड - http://localhost:8080/upload

सेवा घटक वर्ग फ़ाइल है, जिसमें @ सेवा एनोटेशन शामिल है। इन क्लास फाइलों का उपयोग @ लॉस्टकंट्रोलर क्लास फाइल से अलग, एक अलग लेयर में बिजनेस लॉजिक लिखने के लिए किया जाता है। सेवा घटक वर्ग फ़ाइल बनाने का तर्क यहाँ दिखाया गया है -

public interface ProductService {
}

@Service एनोटेशन के साथ इंटरफ़ेस लागू करने वाला वर्ग निम्नानुसार है -

@Service
public class ProductServiceImpl implements ProductService {
}

इस ट्यूटोरियल में देखें कि हम क्या उपयोग कर रहे हैं Product Service API(s)उत्पादों को स्टोर करने, पुनः प्राप्त करने, अद्यतन करने और हटाने के लिए। हमने @RestController क्लास फाइल में ही बिजनेस लॉजिक लिखा है। अब, हम कंट्रोलर से सर्विस कंपोनेंट तक बिजनेस लॉजिक कोड को स्थानांतरित करने जा रहे हैं।

आप एक इंटरफ़ेस बना सकते हैं जिसमें नीचे दिए गए कोड का उपयोग करके जोड़, संपादन, प्राप्त करने और हटाने की विधियाँ शामिल हैं -

package com.tutorialspoint.demo.service;

import java.util.Collection;
import com.tutorialspoint.demo.model.Product;

public interface ProductService {
   public abstract void createProduct(Product product);
   public abstract void updateProduct(String id, Product product);
   public abstract void deleteProduct(String id);
   public abstract Collection<Product> getProducts();
}

निम्नलिखित कोड आपको एक वर्ग बनाने देगा जो ProductService इंटरफ़ेस को @Service एनोटेशन के साथ लागू करता है और उत्पाद को स्टोर करने, पुनर्प्राप्त करने, हटाने और अपडेट करने के लिए व्यावसायिक तर्क को लिखता है।

package com.tutorialspoint.demo.service;

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import org.springframework.stereotype.Service;
import com.tutorialspoint.demo.model.Product;

@Service
public class ProductServiceImpl implements ProductService {
   private static Map<String, Product> productRepo = new HashMap<>();
   static {
      Product honey = new Product();
      honey.setId("1");
      honey.setName("Honey");
      productRepo.put(honey.getId(), honey);

      Product almond = new Product();
      almond.setId("2");
      almond.setName("Almond");
      productRepo.put(almond.getId(), almond);
   }
   @Override
   public void createProduct(Product product) {
      productRepo.put(product.getId(), product);
   }
   @Override
   public void updateProduct(String id, Product product) {
      productRepo.remove(id);
      product.setId(id);
      productRepo.put(id, product);
   }
   @Override
   public void deleteProduct(String id) {
      productRepo.remove(id);

   }
   @Override
   public Collection<Product> getProducts() {
      return productRepo.values();
   }
}

यहाँ कोड रेस्ट कंट्रोलर क्लास फाइल दिखाता है, यहाँ हमने @ ProductService इंटरफ़ेस को बंद कर दिया है और विधियों को बुलाया है।

package com.tutorialspoint.demo.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import com.tutorialspoint.demo.model.Product;
import com.tutorialspoint.demo.service.ProductService;

@RestController
public class ProductServiceController {
   @Autowired
   ProductService productService;

   @RequestMapping(value = "/products")
   public ResponseEntity<Object> getProduct() {
      return new ResponseEntity<>(productService.getProducts(), HttpStatus.OK);
   }
   @RequestMapping(value = "/products/{id}", method = RequestMethod.PUT)
   public ResponseEntity<Object> 
      updateProduct(@PathVariable("id") String id, @RequestBody Product product) {
      
      productService.updateProduct(id, product);
      return new ResponseEntity<>("Product is updated successsfully", HttpStatus.OK);
   }
   @RequestMapping(value = "/products/{id}", method = RequestMethod.DELETE)
   public ResponseEntity<Object> delete(@PathVariable("id") String id) {
      productService.deleteProduct(id);
      return new ResponseEntity<>("Product is deleted successsfully", HttpStatus.OK);
   }
   @RequestMapping(value = "/products", method = RequestMethod.POST)
   public ResponseEntity<Object> createProduct(@RequestBody Product product) {
      productService.createProduct(product);
      return new ResponseEntity<>("Product is created successfully", HttpStatus.CREATED);
   }
}

POJO वर्ग के लिए कोड - Product.java यहां दिखाया गया है -

package com.tutorialspoint.demo.model;

public class Product {
   private String id;
   private String name;

   public String getId() {
      return id;
   }
   public void setId(String id) {
      this.id = id;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name;
   }
}

एक मुख्य स्प्रिंग बूट आवेदन नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

मावेन बिल्ड - pom.xml का कोड नीचे दिखाया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath/> 
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>

</project>

ग्रेड बिल्ड - बिल्ड.ग्रेड के लिए कोड नीचे दिखाया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिए गए मावेन या ग्रेडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, नीचे दिखाए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप नीचे दिखाए अनुसार कमांड का उपयोग कर सकते हैं -

gradle clean build

"BUILD SUCCESSFUL" के बाद, आप JAR फाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

नीचे दी गई कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, आवेदन टॉमकट बंदरगाह 8080 पर शुरू हो गया है जैसा कि नीचे दी गई छवि में दिखाया गया है -

अब POSTMAN एप्लिकेशन में नीचे दिए गए URL को हिट करें और आप नीचे दिखाए अनुसार आउटपुट देख सकते हैं -

GET API URL है - http://localhost:8080/products

POST API URL है - http://localhost:8080/products

PUT API URL है - http://localhost:8080/products/3

DELETE API URL है - http://localhost:8080/products/3

Thymeleaf एक जावा-आधारित लाइब्रेरी है जिसका उपयोग वेब एप्लिकेशन बनाने के लिए किया जाता है। यह वेब अनुप्रयोगों में XHTML / HTML5 की सेवा के लिए एक अच्छा समर्थन प्रदान करता है। इस अध्याय में, आप Thymeleaf के बारे में विस्तार से जानेंगे।

थाइमेल्फ टेम्प्लेट्स

Thymeleaf आपकी फ़ाइलों को अच्छी तरह से बनाई गई XML फ़ाइलों में परिवर्तित करता है। इसमें 6 प्रकार के टेम्प्लेट दिए गए हैं जो नीचे दिए गए हैं -

  • XML
  • मान्य XML
  • XHTML
  • मान्य XHTML
  • HTML5
  • विरासत एचटीएमएल 5

लीगेसी एचटीएमएल 5 को छोड़कर सभी टेम्प्लेट अच्छी तरह से बनाई गई वैध एक्सएमएल फाइलों की बात कर रहे हैं। लीगेसी एचटीएमएल 5 हमें वेब पेज में एचटीएमएल 5 टैग्स को बंद किए गए टैग्स को रेंडर करने की अनुमति देता है।

वेब एप्लीकेशन

स्प्रिंग बूट में वेब एप्लिकेशन बनाने के लिए आप थाइमेल्फ टेम्पलेट का उपयोग कर सकते हैं। आपको Thymeleaf का उपयोग करके स्प्रिंग बूट में वेब एप्लिकेशन बनाने के लिए नीचे दिए गए चरणों का पालन करना होगा।

अनुरोध URI को HTML फ़ाइल में पुनर्निर्देशित करने के लिए @Controller क्लास फ़ाइल बनाने के लिए निम्न कोड का उपयोग करें -

package com.tutorialspoint.demo.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class WebController {
   @RequestMapping(value = "/index")
   public String index() {
      return "index";
   }
}

उपरोक्त उदाहरण में, अनुरोध URI है /index, और कंट्रोल को index.html फ़ाइल में रीडायरेक्ट किया जाता है। ध्यान दें कि index.html फ़ाइल को टेम्प्लेट डायरेक्टरी के नीचे रखा जाना चाहिए और सभी JS और CSS फाइलों को क्लासपाथ में स्टैटिक डायरेक्टरी के तहत रखा जाना चाहिए। दिखाए गए उदाहरण में, हमने पाठ का रंग बदलने के लिए CSS फ़ाइल का उपयोग किया।

आप निम्न कोड का उपयोग कर सकते हैं और एक सीएसएस फ़ाइल को अलग फ़ोल्डर में बना सकते हैं css और फ़ाइल को style.css नाम दें -

h4 {
   color: red;
}

Index.html फ़ाइल का कोड नीचे दिया गया है -

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "ISO-8859-1" />
      <link href = "css/styles.css" rel = "stylesheet"/>
      <title>Spring Boot Application</title>
   </head>
   <body>
      <h4>Welcome to Thymeleaf Spring Boot web application</h4>
   </body>
</html>

प्रोजेक्ट एक्सप्लोरर नीचे दिए गए स्क्रीनशॉट में दिखाया गया है -

अब, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर थाइमेल्फ निर्भरता जोड़ने की आवश्यकता है।

मावेन उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता बिल्ड.ग्रेड फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

compile group: 'org.springframework.boot', name: 'spring-boot-starter-thymeleaf'

मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल का कोड नीचे दिया गया है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

मावेन के लिए कोड - pom.xml नीचे दिया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath />
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-thymeleaf</artifactId>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

ग्रेड के लिए कोड - build.gradle नीचे दिया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   compile group: 'org.springframework.boot', name: 'spring-boot-starter-thymeleaf'
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्नलिखित मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, नीचे दिखाए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, नीचे दिखाए अनुसार कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

यहां दिए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, नीचे दिखाए गए अनुसार टॉमकैट पोर्ट 8080 पर आवेदन शुरू हो गया है -

अब अपने वेब ब्राउजर में URL को हिट करें और आप आउटपुट को देख सकते हैं -

http://localhost:8080/index

यह अध्याय jQuery AJAX का उपयोग करके एक RESTful वेब सेवाओं के उपभोग के बारे में विस्तार से चर्चा करेगा।

एक साधारण स्प्रिंग बूट वेब एप्लिकेशन बनाएं और एक कंट्रोलर क्लास फ़ाइलों को लिखें, जो REST वेब सेवाओं का उपभोग करने के लिए HTML फ़ाइल में रीडायरेक्ट की जाती हैं।

हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर थाइमेलफ और वेब निर्भरता जोड़ने की आवश्यकता है।

मावेन उपयोगकर्ताओं के लिए, अपनी pom.xml फ़ाइल में निम्न निर्भरताएँ जोड़ें।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

ग्रेडल उपयोगकर्ताओं के लिए, अपनी build.gradle फ़ाइल में निम्न निर्भरताएँ जोड़ें -

compile group: ‘org.springframework.boot’, name: ‘spring-boot-starter-thymeleaf’
compile(‘org.springframework.boot:spring-boot-starter-web’)

@Controller वर्ग फ़ाइल के लिए कोड नीचे दिया गया है -

@Controller
public class ViewController {
}

आप नीचे दिखाए गए अनुसार HTML फ़ाइल में रीडायरेक्ट करने के लिए अनुरोध URI विधियों को परिभाषित कर सकते हैं -

@RequestMapping(“/view-products”)
public String viewProducts() {
   return “view-products”;
}
@RequestMapping(“/add-products”)
public String addProducts() {
   return “add-products”;
}

यह एपीआई http://localhost:9090/products नीचे दिखाए गए जवाब में नीचे JSON वापस करना चाहिए -

[
   {
      "id": "1",
      "name": "Honey"
   },
   {
      "id": "2",
      "name": "Almond"
   }
]

अब, classpath में टेम्प्लेट डायरेक्टरी के तहत एक view-products.html फ़ाइल बनाएँ।

HTML फ़ाइल में, हमने jQuery लाइब्रेरी को जोड़ा और पेज लोड पर Restful वेब सेवा का उपभोग करने के लिए कोड लिखा।

<script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>

<script>
$(document).ready(function(){
   $.getJSON("http://localhost:9090/products", function(result){ $.each(result, function(key,value) {
         $("#productsJson").append(value.id+" "+value.name+" ");
      }); 
   });
});
</script>

POST विधि और यह URL http://localhost:9090/products नीचे अनुरोध बॉडी और प्रतिक्रिया बॉडी शामिल होनी चाहिए।

अनुरोध निकाय का कोड नीचे दिया गया है -

{
   "id":"3",
   "name":"Ginger"
}

प्रतिक्रिया शरीर के लिए कोड नीचे दिया गया है -

Product is created successfully

अब, classpath में टेम्प्लेट डायरेक्टरी के तहत ऐड-प्रोडक्ट्स.html फाइल बनाएँ।

HTML फ़ाइल में, हमने jQuery लाइब्रेरी को जोड़ा और उस कोड को लिखा, जो बटन क्लिक करने पर Restful वेब सेवा को फ़ॉर्म सबमिट करता है।

<script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script>
   $(document).ready(function() {
      $("button").click(function() { var productmodel = { id : "3", name : "Ginger" }; var requestJSON = JSON.stringify(productmodel); $.ajax({
            type : "POST",
            url : "http://localhost:9090/products",
            headers : {
               "Content-Type" : "application/json"
            },
            data : requestJSON,
            success : function(data) {
               alert(data);
            },
            error : function(data) {
            }
         });
      });
   });
</script>

पूरा कोड नीचे दिया गया है।

मावेन - pom.xml फ़ाइल

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath />
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-thymeleaf</artifactId>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

ग्रेड के लिए कोड - build.gradle नीचे दिया गया है -

buildscript {
   ext {
      springBootVersion = ‘1.5.8.RELEASE’
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: ‘java’
apply plugin: ‘eclipse’
apply plugin: ‘org.springframework.boot’

group = ‘com.tutorialspoint’
version = ‘0.0.1-SNAPSHOT’
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}

dependencies {
   compile(‘org.springframework.boot:spring-boot-starter-web’)
   compile group: ‘org.springframework.boot’, name: ‘spring-boot-starter-thymeleaf’
   testCompile(‘org.springframework.boot:spring-boot-starter-test’)
}

नीचे दी गई कंट्रोलर क्लास फाइल - ViewController.java नीचे दी गई है -

package com.tutorialspoint.demo.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class ViewController {
   @RequestMapping(“/view-products”)
   public String viewProducts() {
      return “view-products”;
   }
   @RequestMapping(“/add-products”)
   public String addProducts() {
      return “add-products”;   
   }   
}

View-products.html फ़ाइल नीचे दी गई है -

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "ISO-8859-1"/>
      <title>View Products</title>
      <script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
      
      <script>
         $(document).ready(function(){
            $.getJSON("http://localhost:9090/products", function(result){ $.each(result, function(key,value) {
                  $("#productsJson").append(value.id+" "+value.name+" ");
               }); 
            });
         });
      </script>
   </head>
   
   <body>
      <div id = "productsJson"> </div>
   </body>
</html>

Add-products.html फ़ाइल नीचे दी गई है -

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "ISO-8859-1" />
      <title>Add Products</title>
      <script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
      
      <script>
         $(document).ready(function() {
            $("button").click(function() { var productmodel = { id : "3", name : "Ginger" }; var requestJSON = JSON.stringify(productmodel); $.ajax({
                  type : "POST",
                  url : "http://localhost:9090/products",
                  headers : {
                     "Content-Type" : "application/json"
                  },
                  data : requestJSON,
                  success : function(data) {
                     alert(data);
                  },
                  error : function(data) {
                  }
               });
            });
         });
      </script>
   </head>
   
   <body>
      <button>Click here to submit the form</button>
   </body>
</html>

मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल नीचे दी गई है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

अब, आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

मावेन के लिए, नीचे दिए गए आदेश का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, नीचे दिए गए आदेश का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

निम्न आदेश का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, Tomcat पोर्ट 8080 पर आवेदन शुरू हो गया है।

अब अपने वेब ब्राउजर में URL को हिट करें और आप आउटपुट को देख सकते हैं -

http: // localhost: 8080 / दृश्य उत्पादों

http: // localhost: 8080 / एड-उत्पादों

अब, बटन पर क्लिक करें Click here to submit the form और आप परिणाम को देख सकते हैं -

अब, व्यू प्रोडक्ट्स URL को हिट करें और निर्मित उत्पाद देखें।

http://localhost:8080/view-products

कोणीय जेएस

कोणीय जेएस का उपयोग करके एपीआई का उपभोग करने के लिए, आप नीचे दिए गए उदाहरणों का उपयोग कर सकते हैं -

GET API का उपभोग करने के लिए कोणीय JS नियंत्रक बनाने के लिए निम्नलिखित कोड का उपयोग करें - http://localhost:9090/products -

angular.module('demo', [])
.controller('Hello', function($scope, $http) {
   $http.get('http://localhost:9090/products'). then(function(response) { $scope.products = response.data;
   });
});

POST API का उपभोग करने के लिए कोणीय JS नियंत्रक बनाने के लिए निम्नलिखित कोड का उपयोग करें - http://localhost:9090/products -

angular.module('demo', [])
.controller('Hello', function($scope, $http) {
   $http.post('http://localhost:9090/products',data).
   then(function(response) {
      console.log("Product created successfully");
   });
});

Note - पोस्ट विधि डेटा एक उत्पाद बनाने के लिए JSON प्रारूप में अनुरोध निकाय का प्रतिनिधित्व करता है।

क्रॉस-ऑरिजनल रिसोर्स शेयरिंग (CORS) एक सुरक्षा अवधारणा है जो वेब ब्राउज़र में कार्यान्वित संसाधनों को प्रतिबंधित करने की अनुमति देती है। यह जावास्क्रिप्ट कोड को विभिन्न मूल के खिलाफ अनुरोधों का उत्पादन या उपभोग करने से रोकता है।

उदाहरण के लिए, आपका वेब एप्लिकेशन 8080 पोर्ट पर चल रहा है और जावास्क्रिप्ट का उपयोग करके आप 9090 पोर्ट से Restful वेब सेवाओं का उपभोग करने का प्रयास कर रहे हैं। ऐसी स्थितियों के तहत, आप अपने वेब ब्राउज़र पर क्रॉस-ओरिजिनल रिसोर्स शेयरिंग सुरक्षा समस्या का सामना करेंगे।

इस समस्या से निपटने के लिए दो आवश्यकताओं की आवश्यकता है -

  • रेस्टफुल वेब सेवाओं को क्रॉस-ऑरिजिन रिसोर्स शेयरिंग का समर्थन करना चाहिए।

  • रेस्टफुल वेब सेवा एप्लिकेशन को 8080 पोर्ट से एपीआई (एस) तक पहुंचने की अनुमति देनी चाहिए।

इस अध्याय में, हम एक विस्तृत वेब सेवा अनुप्रयोग के लिए क्रॉस-ऑरिजनल अनुरोध को सक्षम करने के बारे में विस्तार से जानने जा रहे हैं।

नियंत्रक विधि में CORS सक्षम करें

हमें मूल वेब सेवा का उपयोग करके मूल सेट करने की आवश्यकता है @CrossOriginनियंत्रक विधि के लिए एनोटेशन। यह @CrossOrigin एनोटेशन विशिष्ट REST API का समर्थन करता है, न कि संपूर्ण एप्लिकेशन के लिए।

@RequestMapping(value = "/products")
@CrossOrigin(origins = "http://localhost:8080")

public ResponseEntity<Object> getProduct() {
   return null;
}

ग्लोबल कॉर्स कॉन्फ़िगरेशन

हमें अपने स्प्रिंग बूट एप्लिकेशन को विश्व स्तर पर कॉर्स कॉन्फ़िगरेशन समर्थन सेट करने के लिए दिखाए गए @Bean कॉन्फ़िगरेशन को परिभाषित करने की आवश्यकता है।

@Bean
public WebMvcConfigurer corsConfigurer() {
   return new WebMvcConfigurerAdapter() {
      @Override
      public void addCorsMappings(CorsRegistry registry) {
         registry.addMapping("/products").allowedOrigins("http://localhost:9000");
      }    
   };
}

मुख्य स्प्रिंग बूट एप्लिकेशन में विश्व स्तर पर कॉर्स कॉन्फ़िगरेशन को सेट करने के लिए कोड नीचे दिया गया है।

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
   @Bean
   public WebMvcConfigurer corsConfigurer() {
      return new WebMvcConfigurerAdapter() {
         @Override
         public void addCorsMappings(CorsRegistry registry) {
            registry.addMapping("/products").allowedOrigins("http://localhost:8080");
         }
      };
   }
}

अब, आप एक स्प्रिंग बूट वेब एप्लिकेशन बना सकते हैं जो 8080 पोर्ट पर चलता है और आपका Restful वेब सेवा एप्लिकेशन जो 9090 पोर्ट पर चल सकता है। रेस्टफुल वेब सेवा के बारे में कार्यान्वयन के बारे में अधिक जानकारी के लिए, आप शीर्षक वाले अध्याय का उल्लेख कर सकते हैंConsuming RESTful Web Services इस ट्यूटोरियल का।

अंतर्राष्ट्रीयकरण एक ऐसी प्रक्रिया है जो आपके एप्लिकेशन को स्रोत कोड पर इंजीनियरिंग परिवर्तनों के बिना विभिन्न भाषाओं और क्षेत्रों के अनुकूल बनाती है। किसी भी शब्द में, अंतर्राष्ट्रीयकरण स्थानीयकरण की एक तत्परता है।

इस अध्याय में, हम विस्तार से जानने वाले हैं कि स्प्रिंग बूट में अंतर्राष्ट्रीयकरण को कैसे लागू किया जाए।

निर्भरता

स्प्रिंग बूट में वेब एप्लिकेशन विकसित करने के लिए हमें स्प्रिंग बूट स्टार्टर वेब और स्प्रिंग बूट स्टार्टर थाइमेल्फ निर्भरता की आवश्यकता होती है।

Maven

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

Gradle

compile('org.springframework.boot:spring-boot-starter-web')
compile group: 'org.springframework.boot', name: 'spring-boot-starter-thymeleaf'

LocaleResolver

हमें आपके एप्लिकेशन का डिफ़ॉल्ट स्थान निर्धारित करना होगा। हमें अपने स्प्रिंग बूट एप्लिकेशन में LocaleResolver सेम को जोड़ने की आवश्यकता है।

@Bean
public LocaleResolver localeResolver() {
   SessionLocaleResolver sessionLocaleResolver = new SessionLocaleResolver();
   sessionLocaleResolver.setDefaultLocale(Locale.US);
   return sessionLocaleResolver;
}

LocaleChangeInterceptor

LocaleChangeInterceptor एक अनुरोध में जोड़े गए भाषा पैरामीटर के मूल्य के आधार पर नए लोकेल को बदलने के लिए उपयोग किया जाता है।

@Bean
public LocaleChangeInterceptor localeChangeInterceptor() {
   LocaleChangeInterceptor localeChangeInterceptor = new LocaleChangeInterceptor();
   localeChangeInterceptor.setParamName("language");
   return localeChangeInterceptor;
}

इस प्रभाव को लेने के लिए, हमें एप्लिकेशन के रजिस्ट्री इंटरसेप्टर में LocaleChangeInterceptor को जोड़ना होगा। कॉन्फ़िगरेशन वर्ग WebMvcConfigurerAdapter वर्ग का विस्तार करना चाहिए और addInterceptors () विधि को ओवरराइड करना चाहिए।

@Override
public void addInterceptors(InterceptorRegistry registry) {
   registry.addInterceptor(localeChangeInterceptor());
}

संदेश स्रोत

डिफ़ॉल्ट रूप से स्प्रिंग बूट एप्लिकेशन संदेश स्रोतों से लेता है src/main/resourcesवर्गपथ के अंतर्गत फ़ोल्डर। डिफ़ॉल्ट लोकेल संदेश फ़ाइल नाम होना चाहिएmessage.properties और प्रत्येक स्थान के लिए फ़ाइलों के रूप में नाम होना चाहिए messages_XX.properties। "XX" स्थानीय कोड का प्रतिनिधित्व करता है।

सभी संदेश गुणों को मुख्य जोड़ी मूल्यों के रूप में उपयोग किया जाना चाहिए। यदि कोई गुण स्थान पर नहीं पाए जाते हैं, तो अनुप्रयोग संदेश से डिफ़ॉल्ट गुण का उपयोग करता है। फ़ाइल फ़ाइल।

डिफ़ॉल्ट संदेश.प्रयोगों के रूप में दिखाया जाएगा -

welcome.text=Hi Welcome to Everyone

फ्रेंच भाषा के मैसेज_फ्रेंड.प्रौपर्टीज दिखाए जाएंगे -

welcome.text=Salut Bienvenue à tous

Note - संदेश स्रोत फ़ाइल को "UTF-8" फ़ाइल प्रारूप के रूप में सहेजा जाना चाहिए।

HTML फ़ाइल

HTML फ़ाइल में, सिंटैक्स का उपयोग करें #{key} गुण फ़ाइल से संदेशों को प्रदर्शित करने के लिए।

<h1 th:text = "#{welcome.text}"></h1>

पूरा कोड नीचे दिया गया है

मावेन - pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.8.RELEASE</version>
      <relativePath />
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-thymeleaf</artifactId>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
</project>

ग्रेडल - build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   compile group: 'org.springframework.boot', name: 'spring-boot-starter-thymeleaf'
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल नीचे दी गई है -

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

नियंत्रक वर्ग फ़ाइल नीचे दी गई है -

package com.tutorialspoint.demo.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class ViewController {
   @RequestMapping("/locale")
   public String locale() {
      return "locale";
   }
}

अंतर्राष्ट्रीयकरण का समर्थन करने के लिए विन्यास वर्ग

package com.tutorialspoint.demo;

import java.util.Locale;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.LocaleResolver;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import org.springframework.web.servlet.i18n.LocaleChangeInterceptor;
import org.springframework.web.servlet.i18n.SessionLocaleResolver;

@Configuration
public class Internationalization extends WebMvcConfigurerAdapter {
   @Bean
   public LocaleResolver localeResolver() {
      SessionLocaleResolver sessionLocaleResolver = new SessionLocaleResolver();
      sessionLocaleResolver.setDefaultLocale(Locale.US);
      return sessionLocaleResolver;
   }
   @Bean
   public LocaleChangeInterceptor localeChangeInterceptor() {
      LocaleChangeInterceptor localeChangeInterceptor = new LocaleChangeInterceptor();
      localeChangeInterceptor.setParamName("language");
      return localeChangeInterceptor;
   }
   @Override
   public void addInterceptors(InterceptorRegistry registry) {
      registry.addInterceptor(localeChangeInterceptor());
   }
}

संदेश स्रोत - messages.properties के रूप में दिखाया गया है -

welcome.text = Hi Welcome to Everyone

संदेश स्रोत - message_fr.properties के रूप में दिखाया गया है -

welcome.text = Salut Bienvenue à tous

HTML फ़ाइल locale.html को क्लासपाथ पर टेम्प्लेट डायरेक्टरी के तहत दिखाया जाना चाहिए -

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "ISO-8859-1"/>
      <title>Internationalization</title>
   </head>
   <body>
      <h1 th:text = "#{welcome.text}"></h1>
   </body>
</html>

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्नलिखित मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, निम्न कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, निम्नलिखित कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब दिखाए अनुसार कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

आप पाएंगे कि आवेदन टॉमकैट पोर्ट 8080 पर शुरू हो गया है।

अब URL को हिट करें http://localhost:8080/locale अपने वेब ब्राउज़र में और आप निम्न आउटपुट देख सकते हैं -

URL http://localhost:8080/locale?language=fr आपको दिखाए गए अनुसार आउटपुट देगा -

शेड्यूलिंग विशिष्ट समय अवधि के लिए कार्यों को निष्पादित करने की एक प्रक्रिया है। स्प्रिंग एप्लीकेशन पर एक शेड्यूलर लिखने के लिए स्प्रिंग बूट एक अच्छा समर्थन प्रदान करता है।

जावा क्रोन एक्सप्रेशन

Java Cron के भावों का उपयोग CronTrigger के उदाहरणों को कॉन्फ़िगर करने के लिए किया जाता है, जो org.quartz.Trigger का एक उपवर्ग है। जावा क्रोन अभिव्यक्ति के बारे में अधिक जानकारी के लिए आप इस लिंक का उल्लेख कर सकते हैं -

https://docs.oracle.com/cd/E12058_01/doc/doc.1014/e12030/cron_expressions.htm

@EnableScheduled एनोटेशन का उपयोग आपके एप्लिकेशन के लिए शेड्यूलर को सक्षम करने के लिए किया जाता है। इस एनोटेशन को मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल में जोड़ा जाना चाहिए।

@SpringBootApplication
@EnableScheduling

public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

शेड्यूल किए गए एनोटेशन का उपयोग शेड्यूलर को एक विशिष्ट समय अवधि के लिए ट्रिगर करने के लिए किया जाता है।

@Scheduled(cron = "0 * 9 * * ?")
public void cronJobSch() throws Exception {
}

निम्नलिखित एक नमूना कोड है जो दिखाता है कि कार्य को हर मिनट 9:00 बजे शुरू करने और हर दिन 9:59 पूर्वाह्न पर समाप्त करने का तरीका बताया गया है

package com.tutorialspoint.demo.scheduler;

import java.text.SimpleDateFormat;
import java.util.Date;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class Scheduler {
   @Scheduled(cron = "0 * 9 * * ?")
   public void cronJobSch() {
      SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
      Date now = new Date();
      String strDate = sdf.format(now);
      System.out.println("Java cron job expression:: " + strDate);
   }
}

निम्न स्क्रीनशॉट दिखाता है कि आवेदन 09:03:23 पर कैसे शुरू हुआ है और उस समय से हर एक मिनट के लिए क्रोन जॉब शेड्यूलर कार्य निष्पादित किया गया है।

निर्धारित दर

फिक्स्ड रेट शेड्यूलर का उपयोग विशिष्ट समय पर कार्यों को निष्पादित करने के लिए किया जाता है। यह पिछले कार्य के पूरा होने की प्रतीक्षा नहीं करता है। मान मिलीसेकंड में होना चाहिए। नमूना कोड यहाँ दिखाया गया है -

@Scheduled(fixedRate = 1000)
public void fixedRateSch() { 
}

एप्लिकेशन स्टार्टअप से प्रत्येक सेकंड पर किसी कार्य को निष्पादित करने के लिए एक नमूना कोड यहां दिखाया गया है -

package com.tutorialspoint.demo.scheduler;

import java.text.SimpleDateFormat;
import java.util.Date;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class Scheduler {
   @Scheduled(fixedRate = 1000)
   public void fixedRateSch() {
      SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");

      Date now = new Date();
      String strDate = sdf.format(now);
      System.out.println("Fixed Rate scheduler:: " + strDate);
   }
}

निम्न स्क्रीनशॉट को देखें जो उस एप्लिकेशन को दिखाता है जो 09:12:00 बजे शुरू हुआ है और उसके बाद हर दूसरे फिक्स्ड रेट शेड्यूलर कार्य को निष्पादित किया गया है।

निर्धारित देरी

एक निश्चित समय पर कार्यों को निष्पादित करने के लिए फिक्स्ड डिले शेड्यूलर का उपयोग किया जाता है। इसे पिछले कार्य के पूरा होने की प्रतीक्षा करनी चाहिए। मान मिलीसेकंड में होना चाहिए। एक नमूना कोड यहाँ दिखाया गया है -

@Scheduled(fixedDelay = 1000, initialDelay = 1000)
public void fixedDelaySch() {
}

यहां, आरंभिक समय वह समय है जिसके बाद प्रारंभिक विलंब मूल्य के बाद पहली बार कार्य निष्पादित किया जाएगा।

एप्लिकेशन स्टार्टअप पूरा होने के 3 सेकंड के बाद हर दूसरे के लिए कार्य निष्पादित करने का एक उदाहरण नीचे दिखाया गया है -

package com.tutorialspoint.demo.scheduler;

import java.text.SimpleDateFormat;
import java.util.Date;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class Scheduler {
   @Scheduled(fixedDelay = 1000, initialDelay = 3000)
   public void fixedDelaySch() {
      SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
      Date now = new Date();
      String strDate = sdf.format(now);
      System.out.println("Fixed Delay scheduler:: " + strDate);
   }
}

निम्न स्क्रीनशॉट को ध्यान से देखें, जो उस एप्लिकेशन को दिखाता है जो 09:18:39 पर शुरू हुआ है और प्रत्येक 3 सेकंड के बाद, निर्धारित देरी शेड्यूलर कार्य को प्रत्येक सेकंड पर निष्पादित किया गया है।

डिफ़ॉल्ट रूप से, स्प्रिंग बूट एप्लिकेशन अनुप्रयोग शुरू होने पर HTTP 8080 पोर्ट का उपयोग करता है।

आपको स्प्रिंग बूट एप्लिकेशन में HTTPS और पोर्ट 443 को कॉन्फ़िगर करने के लिए नीचे दिए गए चरणों का पालन करने की आवश्यकता है -

  • एसएसएल प्रमाणपत्र प्राप्त करें - एक स्व-हस्ताक्षरित प्रमाण पत्र बनाएं या एक प्रमाणपत्र प्राधिकरण से प्राप्त करें

  • HTTPS और 443 पोर्ट को सक्षम करें

स्व-हस्ताक्षरित प्रमाण पत्र

स्व-हस्ताक्षरित प्रमाण पत्र बनाने के लिए, जावा रन टाइम वातावरण प्रमाणपत्र प्रबंधन उपयोगिता कुंजी उपकरण के साथ बंडल में आता है। इस उपयोगिता उपकरण का उपयोग स्व-हस्ताक्षरित प्रमाण पत्र बनाने के लिए किया जाता है। इसे यहाँ दिए गए कोड में दिखाया गया है -

keytool -genkey -alias tomcat -storetype PKCS12 -keyalg RSA -keysize 2048 -keystore keystore.p12 -validity 3650
Enter keystore password:
   Re-enter new password:
   What is your first and last name?
   [Unknown]:
   What is the name of your organizational unit?
   [Unknown]:
   What is the name of your organization?
   [Unknown]:
   What is the name of your City or Locality?
   [Unknown]:
   What is the name of your State or Province?
   [Unknown]:
   What is the two-letter country code for this unit?
   [Unknown]:
   Is CN = Unknown, OU=Unknown, O = Unknown, L = Unknown, ST = Unknown, C = Unknown correct?
   [no]: yes

यह कोड keCSore.p12 के नाम से PKCS12 कीस्टोर फाइल जनरेट करेगा और सर्टिफिकेट उर्फ ​​नाम tomcat है।

HTTPS कॉन्फ़िगर करें

हमें सर्वर पोर्ट को 443, की-स्टोर फ़ाइल पथ, की-स्टोर-पासवर्ड, की-स्टोर-टाइप और कुंजी उपनाम नाम के रूप में application.properties फ़ाइल में प्रदान करना होगा। यहां दिए गए कोड को ध्यान से देखें -

server.port: 443
server.ssl.key-store: keystore.p12
server.ssl.key-store-password: springboot
server.ssl.keyStoreType: PKCS12
server.ssl.keyAlias: tomcat

आप नीचे दिए गए कोड का उपयोग कर सकते हैं यदि आप YAML गुणों का उपयोग अनुप्रयोग के नीचे कर रहे हैं।

server:
   port: 443
   ssl:
      key-store: keystore.p12
      key-store-password: springboot
      keyStoreType: PKCS12
      keyAlias: tomcat

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

मावेन के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रैडल के लिए, आप कमांड का उपयोग कर सकते हैं

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, JAR फ़ाइल को निम्न कमांड का उपयोग करके चलाएं -

java –jar <JARFILE>

अब, आवेदन को एक्सटैट पोर्ट 443 पर https के साथ शुरू किया गया है जैसा कि दिखाया गया है -

यूरेका सर्वर एक एप्लिकेशन है जो सभी क्लाइंट-सर्विस एप्लिकेशन के बारे में जानकारी रखता है। प्रत्येक माइक्रो सेवा यूरेका सर्वर में पंजीकृत होगी और यूरेका सर्वर प्रत्येक पोर्ट और आईपी पते पर चलने वाले सभी क्लाइंट एप्लिकेशन को जानता है। यूरेका सर्वर को डिस्कवरी सर्वर के रूप में भी जाना जाता है।

इस अध्याय में, हम यूरेका सर्वर बनाने के तरीके के बारे में विस्तार से जानेंगे।

यूरेका सर्वर का निर्माण

यूरेका सर्वर स्प्रिंग क्लाउड के बंडल के साथ आता है। इसके लिए, हमें यूरेका सर्वर को विकसित करने और इसे डिफ़ॉल्ट पोर्ट 8761 पर चलाने की आवश्यकता है।

स्प्रिंग इनिशिएटिव होमपेज पर जाएं https://start.spring.io/और यूरेका सर्वर निर्भरता के साथ स्प्रिंग बूट परियोजना डाउनलोड करें। इसे नीचे स्क्रीनशॉट में दिखाया गया है -

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल में प्रोजेक्ट डाउनलोड करने के बाद, हमें @EnableEurekaServer एनोटेशन जोड़ना होगा। @EnableEurekaServer एनोटेशन का उपयोग आपके स्प्रिंग बूट एप्लिकेशन को यूरेका सर्वर के रूप में कार्य करने के लिए किया जाता है।

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल का कोड नीचे दिखाया गया है -

package com.tutorialspoint.eurekaserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer
public class EurekaserverApplication {
   public static void main(String[] args) {
      SpringApplication.run(EurekaserverApplication.class, args);
   }
}

सुनिश्चित करें कि स्प्रिंग क्लाउड यूरेका सर्वर निर्भरता आपके बिल्ड कॉन्फ़िगरेशन फ़ाइल में जोड़ी गई है।

मावेन उपयोगकर्ता निर्भरता के लिए कोड नीचे दिखाया गया है -

<dependency>
<groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-eureka-server</artifactId>
</dependency>

ग्रेडेल उपयोगकर्ता निर्भरता के लिए कोड नीचे दिया गया है -

compile('org.springframework.cloud:spring-cloud-starter-eureka-server')

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है -

Maven pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" 
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>eurekaserver</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>eurekaserver</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-eureka-server</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
ext {
   springCloudVersion = 'Edgware.RELEASE'
}
dependencies {
   compile('org.springframework.cloud:spring-cloud-starter-eureka-server')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}
dependencyManagement {
   imports {
      mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

डिफ़ॉल्ट रूप से, यूरेका सर्वर खोज में खुद को पंजीकृत करता है। आपको नीचे दिए गए कॉन्फ़िगरेशन को अपने एप्लिकेशन में जोड़ना चाहिए। प्रोपराइटीज़ फ़ाइल या एप्लीकेशन.माइल फ़ाइल।

application.properties फ़ाइल नीचे दी गई है -

eureka.client.registerWithEureka = false
eureka.client.fetchRegistry = false
server.port = 8761

Application.yml फ़ाइल नीचे दी गई है -

eureka:
   client:
      registerWithEureka: false
      fetchRegistry: false
server:
   port: 8761

अब, आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिखाए गए मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, नीचे दिखाए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप नीचे दिखाए गए कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, JAR फ़ाइल को निम्न कमांड का उपयोग करके चलाएं -

java –jar <JARFILE>

आप पा सकते हैं कि आवेदन टॉमकट बंदरगाह 8761 पर शुरू हो गया है जैसा कि नीचे दिखाया गया है -

अब, URL को हिट करें http://localhost:8761/ अपने वेब ब्राउज़र में और आप यूरेका सर्वर को पोर्ट 8761 पर चला सकते हैं जैसा कि नीचे दिखाया गया है -

इस अध्याय में, आप यूरेका सर्वर में स्प्रिंग बूट माइक्रो सेवा एप्लिकेशन को पंजीकृत करने के तरीके के बारे में विस्तार से जानने जा रहे हैं। आवेदन को पंजीकृत करने से पहले, कृपया सुनिश्चित करें कि यूरेका सर्वर पोर्ट 8761 पर चल रहा है या पहले यूरेका सर्वर का निर्माण करें और इसे चलाएं। यूरेका सर्वर के निर्माण के बारे में अधिक जानकारी के लिए, आप पिछले अध्याय का उल्लेख कर सकते हैं।

सबसे पहले, आपको यूरेका सर्वर के साथ माइक्रोसैस को पंजीकृत करने के लिए हमारी बिल्ड कॉन्फ़िगरेशन फ़ाइल में निम्न निर्भरताएं जोड़ने की आवश्यकता है।

मावेन उपयोगकर्ता निम्नलिखित निर्भरता को इसमें जोड़ सकते हैं pom.xml फ़ाइल -

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता निम्नलिखित निर्भरता को इसमें जोड़ सकते हैं build.gradle फ़ाइल -

compile('org.springframework.cloud:spring-cloud-starter-eureka')

अब, हमें मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल में @EnableEurekaClient एनोटेशन जोड़ने की आवश्यकता है। @EnableEurekaClient एनोटेशन आपके स्प्रिंग बूट एप्लिकेशन को यूरेका क्लाइंट के रूप में कार्य करता है।

मुख्य स्प्रिंग बूट आवेदन नीचे दिया गया है -

package com.tutorialspoint.eurekaclient;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;

@SpringBootApplication
@EnableEurekaClient
public class EurekaclientApplication {
   public static void main(String[] args) {
      SpringApplication.run(EurekaclientApplication.class, args);
   }
}

यूरेका सर्वर में स्प्रिंग बूट एप्लिकेशन को पंजीकृत करने के लिए हमें अपने एप्लिकेशन में निम्नलिखित कॉन्फ़िगरेशन को जोड़ने की आवश्यकता है। फ़ाइल या Application.yml फ़ाइल और हमारे कॉन्फ़िगरेशन में यूरेका सर्वर URL निर्दिष्ट करें।

Application.yml फ़ाइल के लिए कोड नीचे दिया गया है -

eureka:
   client:
      serviceUrl:
         defaultZone: http://localhost:8761/eureka
      instance:
      preferIpAddress: true
spring:
   application:
      name: eurekaclient

Application.properties फ़ाइल के लिए कोड नीचे दिया गया है -

eureka.client.serviceUrl.defaultZone  = http://localhost:8761/eureka
eureka.client.instance.preferIpAddress = true
spring.application.name = eurekaclient

अब, मुख्य स्प्रिंग बूट एप्लिकेशन में स्ट्रिंग वापस करने के लिए रेस्ट एंडपॉइंट जोड़ें और बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर वेब निर्भरता। नीचे दिए गए कोड को ध्यान से देखें -

package com.tutorialspoint.eurekaclient;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@EnableEurekaClient
@RestController
public class EurekaclientApplication {
   public static void main(String[] args) {
      SpringApplication.run(EurekaclientApplication.class, args);
   }
   @RequestMapping(value = "/")
   public String home() {
      return "Eureka Client application";
   }
}

संपूर्ण कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।

For Maven user - pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>eurekaclient</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>

   <name>eurekaclient</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-eureka</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>
   
   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>
   
   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>   
   </build>
   
</projecta>

For Gradle user – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}") } } apply plugin: 'java' apply plugin: 'eclipse' apply plugin: 'org.springframework.boot' group = 'com.tutorialspoint' version = '0.0.1-SNAPSHOT' sourceCompatibility = 1.8 repositories { mavenCentral() } ext { springCloudVersion = 'Edgware.RELEASE' } dependencies { compile('org.springframework.cloud:spring-cloud-starter-eureka') testCompile('org.springframework.boot:spring-boot-starter-test') compile('org.springframework.boot:spring-boot-starter-web') } dependencyManagement { imports { mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्नलिखित Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब दिखाए अनुसार कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, आवेदन Tomcat पोर्ट 8080 पर शुरू हो गया है और यूरेका क्लाइंट एप्लिकेशन को यूरेका सर्वर के साथ पंजीकृत किया गया है, जो निम्नानुसार दिखाया गया है।

अपने वेब ब्राउज़र में URL http: // localhost: 8761 / मारो और आप देख सकते हैं कि यूरेका क्लाइंट एप्लिकेशन यूरेका सर्वर के साथ पंजीकृत है।

अब URL को हिट करें http://localhost:8080/ अपने वेब ब्राउज़र में और बाकी समापन बिंदु आउटपुट देखें।

ज़ूल सर्वर एक गेटवे एप्लिकेशन है जो सभी अनुरोधों को संभालता है और माइक्रोसर्विस एप्लिकेशन की डायनेमिक रूटिंग करता है। Zuul सर्वर को एज सर्वर के रूप में भी जाना जाता है।

उदाहरण के लिए, /api/user उपयोगकर्ता सेवा के लिए मैप किया गया है और / एपीआई / उत्पादों को उत्पाद सेवा के लिए मैप किया गया है और ज़ुअल सर्वर गतिशील रूप से संबंधित बैकएंड एप्लिकेशन के अनुरोधों को रूट करता है।

इस अध्याय में, हम विस्तार से देखने जा रहे हैं कि स्प्रिंग बूट में ज़ूल सर्वर सर्वर कैसे बनाया जाए।

Zuul सर्वर अनुप्रयोग बनाना

ज़ूल सर्वर को स्प्रिंग क्लाउड निर्भरता के साथ बंडल किया गया है। आप स्प्रिंग आरंभिक पृष्ठ से स्प्रिंग बूट परियोजना डाउनलोड कर सकते हैंhttps://start.spring.io/ और Zuul सर्वर निर्भरता चुनें।

अपने मुख्य स्प्रिंग बूट एप्लिकेशन पर @EnableZuulProxy एनोटेशन जोड़ें। @EnableZuulProxy एनोटेशन का उपयोग आपके स्प्रिंग बूट एप्लिकेशन को Zulul प्रॉक्सी सर्वर के रूप में करने के लिए किया जाता है।

package com.tutorialspoint.zuulserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

@SpringBootApplication
@EnableZuulProxy
public class ZuulserverApplication {
   public static void main(String[] args) {
      SpringApplication.run(ZuulserverApplication.class, args);
   }
}

आपको हमारी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड स्टार्टर ज़ूल निर्भरता को जोड़ना होगा।

मावेन उपयोगकर्ताओं को आपके ऊपर निम्नलिखित निर्भरता को जोड़ना होगा pom.xml फ़ाइल -

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>

ग्रेडल उपयोगकर्ताओं के लिए, अपनी build.gradle फ़ाइल में नीचे की निर्भरता जोड़ें

compile('org.springframework.cloud:spring-cloud-starter-zuul')

ज़ूल राउटिंग के लिए, अपने एप्लिकेशन में निम्नलिखित गुण जोड़ें।

spring.application.name = zuulserver
zuul.routes.products.path = /api/demo/**
zuul.routes.products.url = http://localhost:8080/
server.port = 8111

इसका मतलब है कि http को कॉल करता है /api/demo/उत्पादों की सेवा के लिए आगे बढ़ें। उदाहरण के लिए,/api/demo/products को अग्रेषित किया जाता है /products

yaml फ़ाइल उपयोगकर्ता नीचे दिखाए गए application.yml फ़ाइल का उपयोग कर सकते हैं -

server:
   port: 8111
spring:
   application:  
      name: zuulserver
zuul:

routes:
   products:
      path: /api/demo/**
      url: http://localhost:8080/

Note - http://localhost:8080/ आवेदन Zuul प्रॉक्सी के माध्यम से मार्ग से पहले ही चल रहा होना चाहिए।

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।

मावेन उपयोगकर्ता नीचे दी गई pom.xml फ़ाइल का उपयोग कर सकते हैं -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>zuulserver</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>

   <name>zuulserver</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-zuul</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
</project>

ग्रेडल उपयोगकर्ता नीचे दी गई build.gradle फ़ाइल का उपयोग कर सकते हैं -

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
ext {
   springCloudVersion = 'Edgware.RELEASE'
}
dependencies {
   compile('org.springframework.cloud:spring-cloud-starter-zuul')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}
dependencyManagement {
   imports {
      mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिए गए मावेन या ग्रेडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप नीचे दिए गए कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप नीचे दिए गए कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, नीचे दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएं -

java –jar <JARFILE>

आप पा सकते हैं आवेदन यहाँ पर दिखाए गए अनुसार Tomcat पोर्ट 8111 पर शुरू हो गया है।

अब, URL को हिट करें http://localhost:8111/api/demo/products आपके वेब ब्राउज़र में और आप का आउटपुट देख सकते हैं /products नीचे दिखाए गए अनुसार अंतिम बिंदु -

स्प्रिंग क्लाउड कॉन्फ़िगरेशन सर्वर एक केंद्रीकृत अनुप्रयोग है जो सभी एप्लिकेशन संबंधित कॉन्फ़िगरेशन गुणों का प्रबंधन करता है। इस अध्याय में, आप स्प्रिंग क्लाउड कॉन्फ़िगरेशन सर्वर बनाने के तरीके के बारे में विस्तार से जानेंगे।

स्प्रिंग क्लाउड कॉन्फ़िगरेशन सर्वर बनाना

सबसे पहले, स्प्रिंग आरंभिक पृष्ठ से स्प्रिंग बूट प्रोजेक्ट डाउनलोड करें और स्प्रिंग क्लाउड कॉन्फ़िगरेशन सर्वर निर्भरता चुनें। नीचे दिए गए स्क्रीनशॉट को ध्यान से देखें -

अब, अपने क्लाउड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड कॉन्फ़िगरेशन सर्वर निर्भरता जोड़ें जैसा कि नीचे बताया गया है -

मावेन उपयोगकर्ता नीचे निर्भरता को pom.xml फ़ाइल में जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-config-server</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता आपकी बिल्ड.gradle फ़ाइल में नीचे की निर्भरता जोड़ सकते हैं।

compile('org.springframework.cloud:spring-cloud-config-server')

अब, अपने मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल में @EnableConfigServer एनोटेशन जोड़ें। @EnableConfigServer एनोटेशन आपके स्प्रिंग बूट एप्लिकेशन को एक कॉन्फ़िगरेशन सर्वर के रूप में कार्य करता है।

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल नीचे दी गई है -

package com.tutorialspoint.configserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;

@SpringBootApplication
@EnableConfigServer
public class ConfigserverApplication {
   public static void main(String[] args) {
      SpringApplication.run(ConfigserverApplication.class, args);
   }
}

अब, नीचे दिए गए कॉन्फ़िगरेशन को अपनी प्रॉपर्टीज़ फ़ाइल में जोड़ें और application.properties फ़ाइल को bootstrap.properties फ़ाइल में बदलें। नीचे दिए गए कोड को ध्यान से देखें -

server.port = 8888
spring.cloud.config.server.native.searchLocations=file:///C:/configprop/
SPRING_PROFILES_ACTIVE=native

कॉन्फ़िगरेशन सर्वर टॉमकैट पोर्ट 8888 पर चलता है और एप्लिकेशन कॉन्फ़िगरेशन गुण मूल खोज स्थानों से लोड किए जाते हैं।

में अब file:///C:/configprop/, अपने क्लाइंट एप्लिकेशन को रखें - application.properties फ़ाइल। उदाहरण के लिए, आपका क्लाइंट एप्लिकेशन नाम हैconfig-client, उसके बाद अपने application.properties फ़ाइल का नाम बदलें config-client.properties और गुण फ़ाइल को पथ पर रखें file:///C:/configprop/

कॉन्फ़िग-क्लाइंट प्रॉपर्टीज़ फ़ाइल का कोड नीचे दिया गया है -

welcome.message = Welcome to Spring cloud config server

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है -

मावेन उपयोगकर्ता उपयोग कर सकते हैं pom.xml नीचे दिया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>configserver</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>

   <name>configserver</name>
   <description>Demo project for Spring Boot</description>
   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-config-server</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

ग्रेडल उपयोगकर्ता नीचे दी गई build.gradle फ़ाइल का उपयोग कर सकते हैं -

<scope>import</scope>
</dependency>
</dependencies>
buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}") } } apply plugin: 'java' apply plugin: 'eclipse' apply plugin: 'org.springframework.boot' group = 'com.tutorialspoint' version = '0.0.1-SNAPSHOT' sourceCompatibility = 1.8 repositories { mavenCentral() } ext { springCloudVersion = 'Edgware.RELEASE' } dependencies { compile('org.springframework.cloud:spring-cloud-config-server') testCompile('org.springframework.boot:spring-boot-starter-test') } dependencyManagement { imports { mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

अब, एक निष्पादन योग्य JAR फ़ाइल बनाएँ, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चलाएं -

मावेन के लिए, नीचे दी गई कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, नीचे दिए गए कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

निम्न आदेश का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, यहाँ दिखाए गए अनुसार टॉमकैट बंदरगाह 8888 पर आवेदन शुरू हो गया है -

अब URL को हिट करें http://localhost:8888/config-client/default/master आपके वेब ब्राउज़र पर और आप अपने विन्यास-ग्राहक अनुप्रयोग विन्यास गुण देख सकते हैं जैसा कि यहाँ दिखाया गया है।

कुछ अनुप्रयोगों को कॉन्फ़िगरेशन गुणों की आवश्यकता हो सकती है जिन्हें एक बदलाव की आवश्यकता हो सकती है और डेवलपर्स को इसे प्रदर्शन करने के लिए उन्हें नीचे ले जाना या एप्लिकेशन को पुनरारंभ करना पड़ सकता है। हालांकि, यह उत्पादन में डाउनटाइम और एप्लिकेशन को पुनरारंभ करने की आवश्यकता के कारण हो सकता है। स्प्रिंग क्लाउड कॉन्फ़िगरेशन सर्वर डेवलपर्स को एप्लिकेशन को फिर से शुरू किए बिना और बिना किसी डाउनटाइम के नए कॉन्फ़िगरेशन गुणों को लोड करने देता है।

स्प्रिंग क्लाउड कॉन्फ़िगरेशन सर्वर के साथ काम करना

सबसे पहले, स्प्रिंग बूट प्रोजेक्ट डाउनलोड करें https://start.spring.io/और स्प्रिंग क्लाउड कॉन्फ़िगरेशन क्लाइंट निर्भरता चुनें। अब, अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड स्टार्टर कॉन्फ़िगरेशन निर्भरता जोड़ें।

मावेन उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-config</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता निम्नलिखित निर्भरता को इसमें जोड़ सकते हैं build.gradle फ़ाइल।

compile('org.springframework.cloud:spring-cloud-starter-config')

अब, आपको अपने मुख्य स्प्रिंग बूट एप्लिकेशन में @RefreshScope एनोटेशन जोड़ना होगा। कॉन्फ़िगरेशन सर्वर से कॉन्फ़िगरेशन गुण मान लोड करने के लिए @RefreshScope एनोटेशन का उपयोग किया जाता है।

package com.example.configclient;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.context.config.annotation.RefreshScope;

@SpringBootApplication
@RefreshScope
public class ConfigclientApplication {
   public static void main(String[] args) {
      SpringApplication.run(ConfigclientApplication.class, args);
   }
}

अब, अपने एप्लिकेशन में कॉन्फ़िगरेशन सर्वर URL जोड़ें। फाइल फाइल और अपना आवेदन नाम प्रदान करें।

Note - http: // localhost: 8888 कॉन्फिग सर्वर को कॉन्फिगर क्लाइंट एप्लिकेशन शुरू करने से पहले चलाया जाना चाहिए।

spring.application.name = config-client
spring.cloud.config.uri = http://localhost:8888

कॉन्फ़िगरेशन सर्वर से स्वागत संदेश को पढ़ने के लिए एक साधारण REST समापन बिंदु लिखने के लिए कोड नीचे दिया गया है -

package com.example.configclient;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RefreshScope
@RestController
public class ConfigclientApplication {
   @Value("${welcome.message}")
   String welcomeText;
   
   public static void main(String[] args) {
      SpringApplication.run(ConfigclientApplication.class, args);
   }
   @RequestMapping(value = "/")
   public String welcomeText() {
      return welcomeText;
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्नलिखित Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप नीचे दिखाए गए कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप नीचे दिखाए गए कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, यहाँ दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ:

java –jar <JARFILE>

अब, यहाँ दिखाए गए अनुसार Tomcat पोर्ट 8080 पर आवेदन शुरू हो गया है -

आप कंसोल विंडो में लॉग देख सकते हैं; विन्यास-क्लाइंट अनुप्रयोग विन्यास को ला रहा हैhttps://localhost:8888

2017-12-08 12:41:57.682  INFO 1104 --- [           
   main] c.c.c.ConfigServicePropertySourceLocator : 
   Fetching config from server at: http://localhost:8888

अब URL को हिट करें, http://localhost:8080/ welcome message is loaded from the Configuration server.

Now, go and change the property value on the Configuration server and hit the actuator Endpoint POST URL http://localhost:8080/refresh and see the new configuration property value in the URL http://localhost:8080/

Spring Boot Actuator provides secured endpoints for monitoring and managing your Spring Boot application. By default, all actuator endpoints are secured. In this chapter, you will learn in detail about how to enable Spring Boot actuator to your application.

Enabling Spring Boot Actuator

To enable Spring Boot actuator endpoints to your Spring Boot application, we need to add the Spring Boot Starter actuator dependency in our build configuration file.

Maven users can add the below dependency in your pom.xml file.

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

Gradle users can add the below dependency in your build.gradle file.

compile group: 'org.springframework.boot', name: 'spring-boot-starter-actuator'

In the application.properties file, we need to disable the security for actuator endpoints.

management.security.enabled = false

YAML file users can add the following property in your application.yml file.

management:
   security:
      enabled: false

If you want to use the separate port number for accessing the Spring boot actutator endpoints add the management port number in application.properties file.

management.port = 9000

YAML file users can add the following property in your application.yml file.

management:
   port: 9000

Now, you can create an executable JAR file, and run the Spring Boot application by using the following Maven or Gradle commands.

For Maven, you can use the following command −

mvn clean install

After “BUILD SUCCESS”, you can find the JAR file under the target directory.

For Gradle, you can use the following command −

gradle clean build

After “BUILD SUCCESSFUL”, you can find the JAR file under the build/libs directory.

Now, you can run the JAR file by using the following command −

java –jar <JARFILE>

Now, the application has started on the Tomcat port 8080. Note that if you specified the management port number, then same application is running on two different port numbers.

Some important Spring Boot Actuator endpoints are given below. You can enter them in your web browser and monitor your application behavior.

ENDPOINTS USAGE
/metrics To view the application metrics such as memory used, memory free, threads, classes, system uptime etc.
/env To view the list of Environment variables used in the application.
/beans To view the Spring beans and its types, scopes and dependency.
/health To view the application health
/info To view the information about the Spring Boot application.
/trace To view the list of Traces of your Rest endpoints.

Monitoring your application by using Spring Boot Actuator Endpoint is slightly difficult. Because, if you have ‘n’ number of applications, every application has separate actuator endpoints, thus making monitoring difficult. Spring Boot Admin Server is an application used to manage and monitor your Microservice application.

To handle such situations, CodeCentric Team provides a Spring Boot Admin UI to manage and monitor all your Spring Boot application Actuator endpoints at one place.

For building a Spring Boot Admin Server we need to add the below dependencies in your build configuration file.

Maven users can add the below dependencies in your pom.xml file −

<dependency>
   <groupId>de.codecentric</groupId>
   <artifactId>spring-boot-admin-server</artifactId>
   <version>1.5.5</version>
</dependency>
<dependency>
   <groupId>de.codecentric</groupId>
   <artifactId>spring-boot-admin-server-ui</artifactId>
   <version>1.5.5</version>
</dependency>

Gradle users can add the below dependencies in your build.gradle file −

compile group: 'de.codecentric', name: 'spring-boot-admin-server', version: '1.5.5'
compile group: 'de.codecentric', name: 'spring-boot-admin-server-ui', version: '1.5.5'

Add the @EnableAdminServer annotation in your main Spring Boot application class file. The @EnableAdminServer annotation is used to make your as Admin Server to monitor all other microservices.

package com.tutorialspoint.adminserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import de.codecentric.boot.admin.config.EnableAdminServer;

@SpringBootApplication
@EnableAdminServer
public class AdminserverApplication {   
   public static void main(String[] args) {
      SpringApplication.run(AdminserverApplication.class, args);
   }
}

Now, define the server.port and application name in application.properties file a shown −

server.port = 9090
spring.application.name = adminserver

For YAML users, use the following properties to define the port number and application name in application.yml file.

server:
   port: 9090
spring:
   application:
      name: adminserver

The build configuration file is given below.

For Maven users – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>adminserver</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>

   <name>adminserver</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter</artifactId>
      </dependency>

      <dependency>
         <groupId>de.codecentric</groupId>
         <artifactId>spring-boot-admin-server</artifactId>
         <version>1.5.5</version>
      </dependency>
      
      <dependency>
         <groupId>de.codecentric</groupId>
         <artifactId>spring-boot-admin-server-ui</artifactId>
         <version>1.5.5</version>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

For Gradle users – build.gradle file

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8
repositories {   
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter')
   compile group: 'de.codecentric', name: 'spring-boot-admin-server', version: '1.5.5'
   compile group: 'de.codecentric', name: 'spring-boot-admin-server-ui', version: '1.5.5'   
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

You can create an executable JAR file, and run the Spring Boot application by using the following Maven or Gradle commands −

For Maven, use the command shown here −

mvn clean install

After “BUILD SUCCESS”, you can find the JAR file under target directory.

For Gradle, use the command shown here −

gradle clean build

After “BUILD SUCCESSFUL”, you can find the JAR file under build/libs directory.

Now, run the JAR file by using the command given below −

java –jar <JARFILE>

Now, the application has started on the Tomcat port 9090 as shown here −

Now hit the below URL from your web browser and see the Admin Server UI.

http://localhost:9090/

For monitoring and managing your microservice application via Spring Boot Admin Server, you should add the Spring Boot Admin starter client dependency and point out the Admin Server URI into the application properties file.

Note − For monitoring an application, you should enable the Spring Boot Actuator Endpoints for your Microservice application.

First, add the following Spring Boot Admin starter client dependency and Spring Boot starter actuator dependency in your build configuration file.

Maven users can add the following dependencies in your pom.xml file −

<dependency>
   <groupId>de.codecentric</groupId>
   <artifactId>spring-boot-admin-starter-client</artifactId>
   <version>1.5.5</version>
</dependency>
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

Gradle users can add the following dependencies in your build.gradle file.

compile group: 'de.codecentric', name: 'spring-boot-admin-starter-client', version: '1.5.5'
compile('org.springframework.boot:spring-boot-starter-actuator')

Now, add the Spring Boot Admin Server URL into your application properties file.

For properties file users, add the following properties in the application.properties file.

spring.boot.admin.url = http://localhost:9090/

For YAML users, add the following property in application.yml file.

spring:
   boot:
      admin:
         url: http://localhost:9000/

Now, create an executable JAR file, and run the Spring Boot application by using the following Maven or Gradle commands.

For Maven, you can use the command as shown −

mvn clean install

After “BUILD SUCCESS”, you can find the JAR file under the target directory.

For Gradle, you can use the command as shown −

gradle clean build

After “BUILD SUCCESSFUL”, you can find the JAR file under the build/libs directory.

Now, run the JAR file by using the command shown −

java –jar <JARFILE>

Now, the application has started on the Tomcat port 9090 as shown −

Now hit the following URL from your web browser and see your spring Boot application is registered with Spring Boot Admin Server.

http://localhost:9090/

Now, click the Details button and the see the actuator endpoints in Admin Server UI.

Swagger2 is an open source project used to generate the REST API documents for RESTful web services. It provides a user interface to access our RESTful web services via the web browser.

To enable the Swagger2 in Spring Boot application, you need to add the following dependencies in our build configurations file.

<dependency>
   <groupId>io.springfox</groupId>
   <artifactId>springfox-swagger2</artifactId>
   <version>2.7.0</version>
</dependency>
<dependency>
   <groupId>io.springfox</groupId>
   <artifactId>springfox-swagger-ui</artifactId>
   <version>2.7.0</version>
</dependency>

For Gradle users, add the following dependencies in your build.gradle file.

compile group: 'io.springfox', name: 'springfox-swagger2', version: '2.7.0'
compile group: 'io.springfox', name: 'springfox-swagger-ui', version: '2.7.0'

Now, add the @EnableSwagger2 annotation in your main Spring Boot application. The @EnableSwagger2 annotation is used to enable the Swagger2 for your Spring Boot application.

The code for main Spring Boot application is shown below −

package com.tutorialspoint.swaggerdemo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

@SpringBootApplication
@EnableSwagger2
public class SwaggerDemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(SwaggerDemoApplication.class, args);
   }
}

Next, create Docket Bean to configure Swagger2 for your Spring Boot application. We need to define the base package to configure REST API(s) for Swagger2.

@Bean
   public Docket productApi() {
      return new Docket(DocumentationType.SWAGGER_2).select()
         .apis(RequestHandlerSelectors.basePackage("com.tutorialspoint.swaggerdemo")).build();
   }

Now, add this bean in main Spring Boot application class file itself and your main Spring Boot application class will look as shown below −

package com.tutorialspoint.swaggerdemo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;

import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

@SpringBootApplication
@EnableSwagger2
public class SwaggerDemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(SwaggerDemoApplication.class, args);
   }
   @Bean
   public Docket productApi() {
      return new Docket(DocumentationType.SWAGGER_2).select()
         .apis(RequestHandlerSelectors.basePackage("com.tutorialspoint.swaggerdemo")).build();
   }
}

Now, add the below Spring Boot Starter Web dependency in your build configuration file to write a REST Endpoints as shown below −

Maven users can add the following dependency in your pom.xml file −

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

Gradle users can add the following dependency in build.gradle file −

compile('org.springframework.boot:spring-boot-starter-web')

Now, the code to build two simple RESTful web services GET and POST in Rest Controller file is shown here −

package com.tutorialspoint.swaggerdemo;

import java.util.ArrayList;
import java.util.List;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class SwaggerAPIController {
   @RequestMapping(value = "/products", method = RequestMethod.GET)
   public List<String> getProducts() {
      List<String> productsList = new ArrayList<>();
      productsList.add("Honey");
      productsList.add("Almond");
      return productsList;
   }
   @RequestMapping(value = "/products", method = RequestMethod.POST)
   public String createProduct() {
      return "Product is saved successfully";
   }
}

The complete build configuration file is given below −

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   <modelVersion>4.0.0</modelVersion>

   <groupId>com.tutorialspoint</groupId>
   <artifactId>swagger-demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>swagger-demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
      
      <dependency>
         <groupId>io.springfox</groupId>
         <artifactId>springfox-swagger2</artifactId>
         <version>2.7.0</version>
      </dependency>

      <dependency>
         <groupId>io.springfox</groupId>
         <artifactId>springfox-swagger-ui</artifactId>
         <version>2.7.0</version>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
} dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
   compile group: 'io.springfox', name: 'springfox-swagger2', version: '2.7.0'
   compile group: 'io.springfox', name: 'springfox-swagger-ui', version: '2.7.0'
}

You can create an executable JAR file, and run the Spring Boot application by using the following Maven or Gradle commands.

For Maven, you can use the command shown here −

mvn clean install

After “BUILD SUCCESS”, you can find the JAR file under the target directory.

For Gradle, you can use the command as shown here −

gradle clean build

After “BUILD SUCCESSFUL”, you can find the JAR file under the build/libs directory.

Now, run the JAR file by using the command shown here −

java –jar <JARFILE>

Now, the application will start on the Tomcat port 8080 as shown −

Now, hit the URL in your web browser and see the Swagger API functionalities.

http://localhost:8080/swagger-ui.html

Docker is a container management service that eases building and deployment. If you are a beginner to Docker, you can learn about is in detail at this link − https://www.tutorialspoint.com/docker/index.htm

In this chapter, we are going to see How to create a Docker image by using Maven and Gradle dependencies for your Spring Boot application.

Create Dockerfile

First, create a file with the name Dockerfile under the directories src/main/docker with the contents shown below. Note that this file is important to create a Docker image.

FROM java:8
VOLUME /tmp
ADD dockerapp-0.0.1-SNAPSHOT.jar app.jar
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

Maven

For Maven, add the Docker Maven plugin into your build configuration file pom.xml

<properties>
   <docker.image.prefix>spring-boot-tutorialspoint</docker.image.prefix>
</properties>

<build>
   <plugins>
      <plugin>
         <groupId>com.spotify</groupId>
         <artifactId>docker-maven-plugin</artifactId>
         <version>1.0.0</version>
         
         <configuration>
            <imageName>${docker.image.prefix}/${project.artifactId}</imageName> <dockerDirectory>src/main/docker</dockerDirectory> <resources> <resource> <directory>${project.build.directory}</directory>
                  <include>${project.build.finalName}.jar</include>
               </resource>
            </resources>
         </configuration>
      </plugin>
      
      <plugin>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
   </plugins>
   
</build>

पूरा pom.xml फ़ाइल नीचे दिया गया है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>dockerapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>dockerapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <docker.image.prefix>spring-boot-tutorialspoint</docker.image.prefix>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>com.spotify</groupId>
            <artifactId>docker-maven-plugin</artifactId>
            <version>1.0.0</version>
            
            <configuration>
               <imageName>${docker.image.prefix}/${project.artifactId}</imageName> <dockerDirectory>src/main/docker</dockerDirectory> <resources> <resource> <directory>${project.build.directory}</directory>
                     <include>${project.build.finalName}.jar</include>
                  </resource>
               </resources>
            </configuration>
         </plugin>
         
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

अब, आप मावेन कमांड का उपयोग करके अपना एप्लिकेशन चला सकते हैं mvn package docker:build

Note - एक्सपोज़ डेमॉन को सक्षम करें tcp://localhost:2375 टीएलएस के बिना।

निर्माण सफलता के बाद, आप नीचे दिखाए अनुसार कंसोल पर आउटपुट देख सकते हैं -

अब, डॉकर चित्रों को डॉक चित्रों का उपयोग करके कमांड द्वारा देखें और कंसोल पर छवि जानकारी देखें।

Gradle

ग्रैड बिल्ड कॉन्फ़िगरेशन का उपयोग करके डॉकर छवि बनाने के लिए, हमें जोड़ने की आवश्यकता है docker प्लगइन और एक कार्य लिखने की जरूरत है buildDocker एक डॉकर छवि बनाने के लिए।

ग्रेडल डॉकर कॉन्फ़िगरेशन के लिए कोड नीचे दिया गया है।

buildscript {
   .....
   dependencies {
      .....
      classpath('se.transmode.gradle:gradle-docker:1.2')
   }
}

group = 'spring-boot-tutorialspoint'

.....
apply plugin: 'docker'

task buildDocker(type: Docker, dependsOn: build) {
   applicationName = jar.baseName
   dockerfile = file('src/main/docker/Dockerfile')
   doFirst {
      copy {
         from jar
         into stageDir
      }
   }
}

पूर्ण build.gradle फ़ाइल नीचे दी गई है।

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
      classpath('se.transmode.gradle:gradle-docker:1.2')
   }
}

group = 'spring-boot-tutorialspoint'

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'
apply plugin: 'docker'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}
task buildDocker(type: Docker, dependsOn: build) {
   applicationName = jar.baseName
   dockerfile = file('src/main/docker/Dockerfile')
   doFirst {
      copy {
         from jar
         into stageDir
      }
   }
}

अब, नीचे दिखाए गए कमांड का उपयोग करके एक डॉकटर छवि बनाएं -

gradle build buildDocker

कमांड निष्पादित करने के बाद, आप कंसोल विंडो पर BUILD SUCCESSFUL लॉग देख सकते हैं।

अब, कमांड का उपयोग करके डॉकर छवियों को देखें docker images और कंसोल पर छवि की जानकारी देखें।

किसी भी समस्या के होने पर, अधिकांश डेवलपर लॉग को ट्रेस करने में कठिनाई का सामना करते हैं। इसे स्प्रिंग क्लाउड स्लीथ और जिपकिन सर्वर द्वारा स्प्रिंग बूट एप्लिकेशन के लिए हल किया जा सकता है।

स्प्रिंग क्लाउड स्लीथ

स्प्रिंग क्लाउड स्लीथ लॉग निम्न प्रारूप में छपे हैं -

[application-name,traceid,spanid,zipkin-export]

कहाँ पे,

  • आवेदन-नाम = आवेदन का नाम

  • ट्रेसिड = प्रत्येक अनुरोध और प्रतिक्रिया ट्रेसिड एक ही सेवा या एक सेवा से दूसरी सेवा पर कॉल करते समय समान है।

  • स्पैनिड = स्पैन आईडी ट्रेस आईडी के साथ मुद्रित की जाती है। स्पैन आईडी हर अनुरोध और प्रतिक्रिया को एक सेवा से दूसरे सेवा पर कॉल करने के लिए अलग है।

  • जिपकिन-एक्सपोर्ट = डिफ़ॉल्ट रूप से यह गलत है। यदि यह सही है, तो लॉग को जिपकिन सर्वर पर निर्यात किया जाएगा।

अब, अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड स्टार्टर स्लीथ निर्भरता को निम्नानुसार जोड़ें -

Maven उपयोगकर्ता आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-sleuth</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता आपकी build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

compile('org.springframework.cloud:spring-cloud-starter-sleuth')

अब, अपने स्प्रिंग बूट एप्लीकेशन में लॉग्स जोड़ें बाकी कंट्रोलर क्लास फ़ाइल जैसा कि यहाँ दिखाया गया है -

package com.tutorialspoint.sleuthapp;

import java.util.logging.Level;
import java.util.logging.Logger;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class SleuthappApplication {
   private static final Logger LOG = Logger.getLogger(SleuthappApplication.class.getName());
   public static void main(String[] args) {
      SpringApplication.run(SleuthappApplication.class, args);
   }
   @RequestMapping("/")
   public String index() {
      LOG.log(Level.INFO, "Index API is calling");
      return "Welcome Sleuth!";
   }
}

अब, आवेदन का नाम आवेदन में जोड़ें।

spring.application.name = tracinglogs

बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए पूरा कोड नीचे दिया गया है -

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>sleuthapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>

   <name>sleuthapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-sleuth</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
ext {
   springCloudVersion = 'Edgware.RELEASE'
}
dependencies {
   compile('org.springframework.cloud:spring-cloud-starter-sleuth')
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}
dependencyManagement {
   imports {
      mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

मावेन के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, यहाँ दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, Tomcat पोर्ट 8080 पर आवेदन शुरू हो गया है।

अब, अपने वेब ब्राउज़र में URL को हिट करें और कंसोल लॉग में आउटपुट देखें।

http://localhost:8080/

कंसोल विंडो में आप निम्न लॉग देख सकते हैं। ध्यान रखें कि लॉग निम्न प्रारूप में मुद्रित होता है [आवेदन-नाम, ट्रेसिड, स्पिड, जिपकिन-एक्सपोर्ट]

जिपक सर्वर

जिपकिन एक ऐसा एप्लिकेशन है जो आपके स्प्रिंग बूट एप्लिकेशन के स्प्रिंग क्लाउड स्लीथ लॉग की निगरानी और प्रबंधन करता है। ज़िपकिन सर्वर बनाने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में जिपकिन यूआई और जिपकिन सर्वर निर्भरताएँ जोड़ने की आवश्यकता है।

Maven उपयोगकर्ता आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

<dependency>
   <groupId>io.zipkin.java</groupId>
   <artifactId>zipkin-server</artifactId>
</dependency>
<dependency>
   <groupId>io.zipkin.java</groupId>
   <artifactId>zipkin-autoconfigure-ui</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता आपकी बिल्ड.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

compile('io.zipkin.java:zipkin-autoconfigure-ui')
compile('io.zipkin.java:zipkin-server')

अब, अनुप्रयोग गुण फ़ाइल में server.port = 9411 कॉन्फ़िगर करें।

गुण फ़ाइल उपयोगकर्ताओं के लिए, नीचे दी गई संपत्ति को application.properties फ़ाइल में जोड़ें।

server.port = 9411

YAML उपयोगकर्ताओं के लिए, application.yml फ़ाइल में निम्न गुण जोड़ें।

server:
   port: 9411

अपने मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ी में @EnableZipkinServer एनोटेशन जोड़ें। @EnableZipkinServer एनोटेशन का उपयोग आपके एप्लिकेशन एक्ट को जिपकिन सर्वर के रूप में सक्षम करने के लिए किया जाता है।

package com.tutorialspoint.zipkinapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import zipkin.server.EnableZipkinServer;

@SpringBootApplication
@EnableZipkinServer
public class ZipkinappApplication {
   public static void main(String[] args) {
      SpringApplication.run(ZipkinappApplication.class, args);
   }
}

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए कोड नीचे दिया गया है।

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>zipkinapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>zipkinapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>io.zipkin.java</groupId>
         <artifactId>zipkin-server</artifactId>
      </dependency>
      <dependency>
         <groupId>io.zipkin.java</groupId>
         <artifactId>zipkin-autoconfigure-ui</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}") } } apply plugin: 'java' apply plugin: 'eclipse' apply plugin: 'org.springframework.boot' group = 'com.tutorialspoint' version = '0.0.1-SNAPSHOT' sourceCompatibility = 1.8 repositories { mavenCentral() } ext { springCloudVersion = 'Edgware.RELEASE' } dependencies { compile('io.zipkin.java:zipkin-autoconfigure-ui') compile('io.zipkin.java:zipkin-server') testCompile('org.springframework.boot:spring-boot-starter-test') } dependencyManagement { imports { mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, नीचे दी गई कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, नीचे दिए गए कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, आवेदन नीचे दिखाए गए अनुसार Tomcat पोर्ट 9411 पर शुरू हो गया है -

अब, नीचे दिए गए URL को हिट करें और Zipkin सर्वर UI देखें।

http://localhost:9411/zipkin/

उसके बाद, अपने क्लाइंट सेवा एप्लिकेशन में निम्न निर्भरता जोड़ें और ज़िपकिन यूआई के माध्यम से माइक्रो सर्विस लॉग का पता लगाने के लिए ज़िपकिन सर्वर URL को इंगित करें।

अब, अपनी क्लाउड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड स्टार्टर जिपक निर्भरता जोड़ें जैसा कि दिखाया गया है -

Maven उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-sleuth-zipkin</artifactId>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

compile('org.springframework.cloud:spring-cloud-sleuth-zipkin')

अब, जोड़ें Always Sampler Bean ज़िपक सर्वर में लॉग निर्यात करने के लिए अपने स्प्रिंग बूट आवेदन में।

@Bean
public AlwaysSampler defaultSampler() {
   return new AlwaysSampler();
}

अगर आप ऑलवेज़समलर बीन को जोड़ते हैं, तो स्वचालित रूप से स्प्रिंग स्लीथ जिपकिन एक्सपोर्ट विकल्प झूठे से सच में बदल जाएगा।

इसके बाद, क्लाइंट सेवा Application.properties फ़ाइल में अपने जिप्किन सर्वर बेस URL को कॉन्फ़िगर करें।

spring.zipkin.baseUrl = http://localhost:9411/zipkin/

फिर, ट्रेस आईडी प्रदान करें और ज़िपकिन यूआई में निशान ढूंढें।

http://localhost:9411/zipkin/traces/{traceid}/

फ्लाईवे आपके डेटाबेस स्कीमा को आसानी से और मज़बूती से आपके सभी उदाहरणों में विकसित करने के लिए एक संस्करण नियंत्रण अनुप्रयोग है। फ्लाईवे के बारे में अधिक जानने के लिए, आप लिंक का उपयोग कर सकते हैं - www.flywaydb.org

कई सॉफ्टवेयर प्रोजेक्ट रिलेशनल डेटाबेस का उपयोग करते हैं। इसके लिए डेटाबेस माइग्रेशन से निपटने की आवश्यकता होती है, जिसे अक्सर स्कीमा माइग्रेशन भी कहा जाता है।

इस अध्याय में, आप अपने स्प्रिंग बूट एप्लिकेशन में फ्लाईवे डेटाबेस को कॉन्फ़िगर करने के तरीके के बारे में विस्तार से जानने जा रहे हैं।

फ्लाईवे डेटाबेस को कॉन्फ़िगर करना

सबसे पहले, स्प्रिंग आरंभिक पृष्ठ www.start.spring.io से स्प्रिंग बूट प्रोजेक्ट डाउनलोड करें और निम्नलिखित निर्भरताएं चुनें -

  • स्प्रिंग बूट स्टार्टर वेब
  • Flyway
  • MySQL
  • JDBC

Maven उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

<dependency>
   <groupId>org.flywaydb</groupId>
   <artifactId>flyway-core</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
   <scope>test</scope>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

compile('org.flywaydb:flyway-core')
compile('org.springframework.boot:spring-boot-starter-jdbc')
compile('org.springframework.boot:spring-boot-starter-web')
compile('mysql:mysql-connector-java')

एप्लिकेशन प्रॉपर्टीज में, हमें डेटा स्रोत बनाने के लिए डेटाबेस प्रॉपर्टीज को कॉन्फ़िगर करना होगा और फ्लाईवे प्रॉपर्टीज को भी अप्वाइंट करना होगा।

गुण फ़ाइल उपयोगकर्ताओं के लिए, नीचे दिए गए गुणों को application.properties फ़ाइल में जोड़ें।

spring.application.name = flywayapp  

spring.datasource.driverClassName = com.mysql.jdbc.Driver
spring.datasource.url = jdbc:mysql://localhost:3306/USERSERVICE?autoreconnect=true
spring.datasource.username = root
spring.datasource.password = root
spring.datasource.testOnBorrow = true
spring.datasource.testWhileIdle = true
spring.datasource.timeBetweenEvictionRunsMillis = 60000
spring.datasource.minEvictableIdleTimeMillis = 30000
spring.datasource.validationQuery = SELECT 1
spring.datasource.max-active = 15
spring.datasource.max-idle = 10
spring.datasource.max-wait = 8000

flyway.url = jdbc:mysql://localhost:3306/mysql
flyway.schemas = USERSERVICE
flyway.user = root
flyway.password = root

YAML उपयोगकर्ता application.yml फ़ाइल में निम्नलिखित गुण जोड़ सकते हैं।

spring:
   application:
      name: flywayapp  
   datasource: 
      driverClassName: com.mysql.jdbc.Driver
      url: "jdbc:mysql://localhost:3306/USERSERVICE?autoreconnect=true"
      password: "root"
      username: "root"
      testOnBorrow: true
      testWhileIdle: true
      timeBetweenEvictionRunsMillis: 60000
      minEvictableIdleTimeMillis: 30000
      validationQuery: SELECT 1
      max-active: 15
      max-idle: 10
      max-wait: 8000
flyway:
   url: jdbc:mysql://localhost:3306/mysql
   schemas: USERSERVICE
   user: "root"
   password: "root"

अब, के तहत एक SQL फ़ाइल बनाएँ src/main/resources/db/migrationनिर्देशिका। SQL फ़ाइल को "V1__Initial.sql" नाम दें

CREATE TABLE USERS (ID INT AUTO_INCREMENT PRIMARY KEY, USERID VARCHAR(45));
INSERT INTO USERS (ID, USERID) VALUES (1, 'tutorialspoint.com');

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल कोड नीचे दिया गया है -

package com.tutorialspoint.flywayapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class FlywayappApplication {
   public static void main(String[] args) {
      SpringApplication.run(FlywayappApplication.class, args);
   }
}

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>flywayapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>flywayapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.flywaydb</groupId>
         <artifactId>flyway-core</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-jdbc</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>mysql</groupId>
         <artifactId>mysql-connector-java</artifactId>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.flywaydb:flyway-core')
   compile('org.springframework.boot:spring-boot-starter-jdbc')
   compile('org.springframework.boot:spring-boot-starter-web')
   compile('mysql:mysql-connector-java')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिए गए मावेन या ग्रेडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप यहाँ दिखाए गए कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप यहाँ दिखाए गए कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, JAR फ़ाइल को निम्न कमांड का उपयोग करके चलाएं -

java –jar <JARFILE>

अब, टॉमकैट 8080 पोर्ट पर शुरू हुआ और कंसोल विंडो में आप यहां दिखाए गए अनुसार फ्लाईवे डेटाबेस लॉग देख सकते हैं।

अब आप डेटाबेस पर जा सकते हैं और चुनिंदा क्वेरी कर सकते हैं।

स्प्रिंग बूट रेस्टफुल वेब सेवा का उपयोग करके, आप जीमेल ट्रांसपोर्ट लेयर सिक्योरिटी के साथ एक ईमेल भेज सकते हैं। इस अध्याय में, आइए विस्तार से समझते हैं कि इस सुविधा का उपयोग कैसे करें।

सबसे पहले, हमें आपकी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर मेल निर्भरता जोड़ने की आवश्यकता है।

मावेन उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-mail</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता आपकी बिल्ड.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

compile('org.springframework.boot:spring-boot-starter-mail')

मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल का कोड नीचे दिया गया है -

package com.tutorialspoint.emailapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class EmailappApplication {
   public static void main(String[] args) {
      SpringApplication.run(EmailappApplication.class, args);
   }
}

जैसा कि दिखाया गया है, आप रेस्ट कंट्रोलर क्लास फाइल में ईमेल भेजने के लिए एक साधारण रेस्ट एपीआई लिख सकते हैं।

package com.tutorialspoint.emailapp;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class EmailController {
   @RequestMapping(value = "/sendemail")
   public String sendEmail() {
      return "Email sent successfully";
   }   
}

आप अटैचमेंट के साथ ईमेल भेजने के लिए एक विधि लिख सकते हैं। Mail.smtp गुण और प्रयुक्त PasswordAuthentication परिभाषित करें।

private void sendmail() throws AddressException, MessagingException, IOException {
   Properties props = new Properties();
   props.put("mail.smtp.auth", "true");
   props.put("mail.smtp.starttls.enable", "true");
   props.put("mail.smtp.host", "smtp.gmail.com");
   props.put("mail.smtp.port", "587");
   
   Session session = Session.getInstance(props, new javax.mail.Authenticator() {
      protected PasswordAuthentication getPasswordAuthentication() {
         return new PasswordAuthentication("[email protected]", "<your password>");
      }
   });
   Message msg = new MimeMessage(session);
   msg.setFrom(new InternetAddress("[email protected]", false));

   msg.setRecipients(Message.RecipientType.TO, InternetAddress.parse("[email protected]"));
   msg.setSubject("Tutorials point email");
   msg.setContent("Tutorials point email", "text/html");
   msg.setSentDate(new Date());

   MimeBodyPart messageBodyPart = new MimeBodyPart();
   messageBodyPart.setContent("Tutorials point email", "text/html");

   Multipart multipart = new MimeMultipart();
   multipart.addBodyPart(messageBodyPart);
   MimeBodyPart attachPart = new MimeBodyPart();

   attachPart.attachFile("/var/tmp/image19.png");
   multipart.addBodyPart(attachPart);
   msg.setContent(multipart);
   Transport.send(msg);   
}

अब, शेष एपीआई से उपरोक्त Sendmail () विधि को कॉल करें -

@RequestMapping(value = "/sendemail")
public String sendEmail() throws AddressException, MessagingException, IOException {
   sendmail();
   return "Email sent successfully";   
}

Note - ईमेल भेजने से पहले कृपया अपने जीमेल अकाउंट सेटिंग्स में कम सुरक्षित ऐप्स को अनुमति दें।

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>emailapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>emailapp</name>
   <description>Demo project for Spring Boot</description>
   
   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>
   
   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
   <java.version>1.8</java.version>
   </properties>
   
   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-mail</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>
   
   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build> 
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   compile('org.springframework.boot:spring-boot-starter-mail')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

अब, आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिखाए गए मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप कमांड को दिखाए अनुसार उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप कमांड को दिखाए अनुसार उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, नीचे दी गई कमांड का उपयोग करके JAR फ़ाइल चलाएं -

java –jar <JARFILE>

आप देख सकते हैं कि आवेदन टॉमकैट पोर्ट 8080 पर शुरू हो गया है।

अब अपने वेब ब्राउजर से निम्न URL को हिट करें और आपको एक ईमेल प्राप्त होगा।

http://localhost:8080/sendemail

हिस्टिक्स नेटफ्लिक्स से लाइब्रेरी है। हिस्टिक्स सेवाओं के बीच पहुंच के बिंदुओं को अलग करता है, उन पर कैस्केडिंग विफलताओं को रोकता है और फ़ॉलबैक विकल्प प्रदान करता है।

उदाहरण के लिए, जब आप 3 rd पार्टी एप्लिकेशन को कॉल कर रहे हैं , तो प्रतिक्रिया भेजने में अधिक समय लगता है। तो उस समय, नियंत्रण फ़ॉलबैक विधि पर जाता है और आपके आवेदन के लिए कस्टम प्रतिक्रिया देता है।

इस अध्याय में आप यह देखने जा रहे हैं कि स्प्रिंग बूट एप्लिकेशन में हिस्टिक्स को कैसे लागू किया जाए।

सबसे पहले, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड स्टार्टर हिस्ट्रिक्स निर्भरता जोड़ने की आवश्यकता है।

Maven उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता बिल्ड.ग्रेड फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

compile('org.springframework.cloud:spring-cloud-starter-hystrix')

अब, अपने मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल में @EnableHystrix एनोटेशन जोड़ें। @EnableHystrix एनोटेशन का उपयोग आपके स्प्रिंग बूट एप्लिकेशन में Hystrix फ़ंक्शंस को सक्षम करने के लिए किया जाता है।

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल कोड नीचे दिया गया है -

package com.tutorialspoint.hystrixapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;

@SpringBootApplication
@EnableHystrix
public class HystrixappApplication {
   public static void main(String[] args) {
      SpringApplication.run(HystrixappApplication.class, args);
   }
}

अब एक साधारण रेस्ट कंट्रोलर लिखें, जिसमें यह अनुरोध किए गए समय से 3 सेकंड के बाद स्ट्रिंग लौटाता है।

@RequestMapping(value = "/")
public String hello() throws InterruptedException {
   Thread.sleep(3000);
   return "Welcome Hystrix";
}

अब, रेस्ट API के लिए @Hystrix कमांड और @HystrixProperty जोड़ें और मिलीसेकंड मान में टाइमआउट को परिभाषित करें।

@HystrixCommand(fallbackMethod = "fallback_hello", commandProperties = {
   @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1000")
})

अगला, यदि अनुरोध का जवाब देने में लंबा समय लगता है, तो फ़ॉलबैक विधि fallback_hello () को परिभाषित करें।

private String fallback_hello() {
   return "Request fails. It takes long time to response";
}

बाकी रेस्ट कंट्रोलर क्लास फ़ाइल जिसमें REST API और Hystrix गुण हैं, को यहाँ दिखाया गया है -

@RequestMapping(value = "/")
@HystrixCommand(fallbackMethod = "fallback_hello", commandProperties = {
   @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1000")
})
public String hello() throws InterruptedException {
   Thread.sleep(3000);
   return "Welcome Hystrix";
}
private String fallback_hello() {
   return "Request fails. It takes long time to response";
}

इस उदाहरण में, मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फ़ाइल में REST API लिखा गया है।

package com.tutorialspoint.hystrixapp;

import org.springframework.boot.SpringApplication;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixProperty;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;

@SpringBootApplication
@EnableHystrix
@RestController
public class HystrixappApplication {
   public static void main(String[] args) {
      SpringApplication.run(HystrixappApplication.class, args);
   }
   @RequestMapping(value = "/")
   @HystrixCommand(fallbackMethod = "fallback_hello", commandProperties = {
      @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1000")
   })
   public String hello() throws InterruptedException {
      Thread.sleep(3000);
      return "Welcome Hystrix";
   }
   private String fallback_hello() {
      return "Request fails. It takes long time to response";
   }
}

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।

Maven – pom.xml file

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>hystrixapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>hystrixapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-hystrix</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
ext {
   springCloudVersion = 'Edgware.RELEASE'
}
dependencies {
   compile('org.springframework.cloud:spring-cloud-starter-hystrix')
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}
dependencyManagement {
   imports {
      mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्नलिखित Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रैडल के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, नीचे दी गई कमांड का उपयोग करके JAR फ़ाइल चलाएं -

java –jar <JARFILE>

यह नीचे दिखाए गए अनुसार टॉमकैट पोर्ट 8080 पर आवेदन शुरू करेगा -

अब, URL को हिट करें http://localhost:8080/अपने वेब ब्राउज़र से, और Hystrix प्रतिक्रिया देखें। API को प्रतिक्रिया देने में 3 सेकंड का समय लगता है, लेकिन Hystrix मध्यांतर 1 सेकंड है।

इस अध्याय में, हम समझते हैं कि वेब सॉकेट के साथ स्प्रिंग बूट का उपयोग करके एक इंटरैक्टिव वेब एप्लिकेशन कैसे बनाया जाए।

वेब सॉकेट के साथ स्प्रिंग बूट में एक इंटरैक्टिव वेब एप्लिकेशन बनाने के लिए, आपको निम्नलिखित निर्भरताएं जोड़ने की आवश्यकता है।

Maven उपयोगकर्ताओं को pom.xml फ़ाइल में निम्न निर्भरताएँ जोड़नी चाहिए।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-websocket</artifactId>
</dependency>
<dependency>
   <groupId>org.webjars</groupId>
   <artifactId>webjars-locator</artifactId>
</dependency>
<dependency>
   <groupId>org.webjars</groupId>
   <artifactId>sockjs-client</artifactId>
   <version>1.0.2</version>
</dependency>

<dependency>
   <groupId>org.webjars</groupId>
   <artifactId>stomp-websocket</artifactId>
   <version>2.3.3</version>
</dependency>
<dependency>
   <groupId>org.webjars</groupId>
   <artifactId>bootstrap</artifactId>
   <version>3.3.7</version>        </dependency>
<dependency>
   <groupId>org.webjars</groupId>
   <artifactId>jquery</artifactId>
   <version>3.1.0</version>
</dependency>

ग्रेड उपयोगकर्ता आपके build.gradle फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं -

compile("org.springframework.boot:spring-boot-starter-websocket")
compile("org.webjars:webjars-locator")
compile("org.webjars:sockjs-client:1.0.2")
compile("org.webjars:stomp-websocket:2.3.3")
compile("org.webjars:bootstrap:3.3.7")
compile("org.webjars:jquery:3.1.0")

हमें STOMP मैसेजिंग के साथ काम करने के लिए एक संदेश हैंडलिंग नियंत्रक बनाते हैं। STOMP संदेशों को @Controller वर्ग फ़ाइल में रूट किया जा सकता है। उदाहरण के लिए, GreetingController संदेशों को "हेलो" गंतव्य पर संभालने के लिए मैप किया गया है।

package com.tutorialspoint.websocketapp;

import org.springframework.messaging.handler.annotation.MessageMapping;
import org.springframework.messaging.handler.annotation.SendTo;
import org.springframework.stereotype.Controller;

@Controller
public class GreetingController {
   @MessageMapping("/hello")
   @SendTo("/topic/greetings")
   public Greeting greeting(HelloMessage message) throws Exception {
      Thread.sleep(1000); // simulated delay
      return new Greeting("Hello, " + message.getName() + "!");
   }
}

अब, STOMP मैसेजिंग के लिए स्प्रिंग कॉन्फ़िगर करें। एक WebSocketConfig वर्ग फ़ाइल लिखें जो नीचे दिए गए अनुसार AbstractWebSocketMessageBrokerConfigurer वर्ग का विस्तार करती है।

package com.tutorialspoint.websocketapp;

import org.springframework.context.annotation.Configuration;
import org.springframework.messaging.simp.config.MessageBrokerRegistry;
import org.springframework.web.socket.config.annotation.AbstractWebSocketMessageBrokerConfigurer;
import org.springframework.web.socket.config.annotation.EnableWebSocketMessageBroker;
import org.springframework.web.socket.config.annotation.StompEndpointRegistry;

@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {
   @Override
   public void configureMessageBroker(MessageBrokerRegistry config) {
      config.enableSimpleBroker("/topic");
      config.setApplicationDestinationPrefixes("/app");
   }
   @Override
   public void registerStompEndpoints(StompEndpointRegistry registry) {
      registry.addEndpoint("/tutorialspoint-websocket").withSockJS();
   }
}

@EnableWebSocketMessageBroker एनोटेशन का उपयोग STOMP समापन बिंदु बनाने के लिए वेब सॉकेट संदेश ब्रोकर को कॉन्फ़िगर करने के लिए किया जाता है।

आप दिखाए गए अनुसार src / main / resource / static / index.html के अंतर्गत एक ब्राउज़र क्लाइंट फ़ाइल बना सकते हैं -

<!DOCTYPE html>
<html>
   <head>
      <title>Hello WebSocket</title>
      <link href = "/webjars/bootstrap/css/bootstrap.min.css" rel = "stylesheet">
      <link href = "/main.css" rel = "stylesheet">
      <script src = "/webjars/jquery/jquery.min.js"></script>
      <script src = "/webjars/sockjs-client/sockjs.min.js"></script>
      <script src = "/webjars/stomp-websocket/stomp.min.js"></script>
      <script src = "/app.js"></script>
   </head>
   
   <body>
      <noscript>
         <h2 style = "color: #ff0000">
            Seems your browser doesn't support Javascript! Websocket relies on Javascript being
            enabled. Please enable Javascript and reload this page!
         </h2>
      </noscript>
      <div id = "main-content" class = "container">
         <div class = "row">
            <div class = "col-md-6">
               <form class = "form-inline">
                  <div class = "form-group">
                     <label for = "connect">WebSocket connection:</label>
                     <button id = "connect" class = "btn btn-default" type = "submit">Connect</button>
                     <button id = "disconnect" class = "btn btn-default" type = "submit" disabled = "disabled">Disconnect
                     </button>
                  </div>
               </form>
            </div>
            
            <div class = "col-md-6">
               <form class = "form-inline">
                  <div class = "form-group">
                     <label for = "name">What is your name?</label>
                     <input type = "text" id = "name" class = "form-control" placeholder = "Your name here...">
                  </div>
                  <button id = "send" class = "btn btn-default" type = "submit">Send</button>
               </form>
            </div>
         </div>
         
         <div class  =  "row">
            <div class  =  "col-md-12">
               <table id  =  "conversation" class = "table table-striped">
                  <thead>
                     <tr>
                        <th>Greetings</th>
                     </tr>
                  </thead>
                  <tbody id  =  "greetings"></tbody>
               </table>
            </div>
         </div>
      </div>
   </body>
</html>

हमें STOMP का उपयोग करके संदेशों का उपभोग और उत्पादन करने के लिए एक app.js फ़ाइल बनाएँ।

var stompClient = null;

function setConnected(connected) {
   $("#connect").prop("disabled", connected);
   $("#disconnect").prop("disabled", !connected); if (connected) { $("#conversation").show();
   } else {
      $("#conversation").hide(); } $("#greetings").html("");
}

function connect() {
   var socket = new SockJS('/tutorialspoint-websocket');
   stompClient = Stomp.over(socket);
   stompClient.connect({}, function (frame) {
      setConnected(true);
      console.log('Connected: ' + frame);
      stompClient.subscribe('/topic/greetings', function (greeting) {
         showGreeting(JSON.parse(greeting.body).content);
      });
   });
}
function disconnect() {
   if (stompClient !== null) {
      stompClient.disconnect();
   }
   setConnected(false);
   console.log("Disconnected");
}
function sendName() {
   stompClient.send("/app/hello", {}, JSON.stringify({'name': $("#name").val()})); } function showGreeting(message) { $("#greetings").append("<tr><td>" + message + "</td></tr>");
}
$(function () { $( "form" ).on('submit', function (e) {e.preventDefault();});
   $( "#connect" ).click(function() { connect(); }); $( "#disconnect" ).click(function() { disconnect(); });
   $( "#send" ).click(function() { sendName(); });
});

मुख्य स्प्रिंग बूट एप्लिकेशन का कोड नीचे दिखाया गया है।

package com.tutorialspoint.websocketapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class WebsocketappApplication {
   public static void main(String[] args) {
      SpringApplication.run(WebsocketappApplication.class, args);
   }  
}

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>websocketapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>websocketapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
   </parent>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-websocket</artifactId>
      </dependency>
      <dependency>
         <groupId>org.webjars</groupId>
         <artifactId>webjars-locator</artifactId>
      </dependency>
      <dependency>
         <groupId>org.webjars</groupId>
         <artifactId>sockjs-client</artifactId>
         <version>1.0.2</version>
      </dependency>
      
      <dependency>
         <groupId>org.webjars</groupId>
         <artifactId>stomp-websocket</artifactId>
         <version>2.3.3</version>
      </dependency>
      <dependency>
         <groupId>org.webjars</groupId>
         <artifactId>bootstrap</artifactId>
         <version>3.3.7</version>
      </dependency>
      
      <dependency>
         <groupId>org.webjars</groupId>
         <artifactId>jquery</artifactId>
         <version>3.1.0</version>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>
   
   <properties>
      <java.version>1.8</java.version>
   </properties>
   
   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:1.5.9.RELEASE")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

jar {
   baseName = 'websocketapp'
   version =  '0.1.0'
}
sourceCompatibility = 1.8
targetCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile("org.springframework.boot:spring-boot-starter-websocket")
   compile("org.webjars:webjars-locator")
   compile("org.webjars:sockjs-client:1.0.2")
   compile("org.webjars:stomp-websocket:2.3.3")
   compile("org.webjars:bootstrap:3.3.7")
   compile("org.webjars:jquery:3.1.0")

   testCompile("org.springframework.boot:spring-boot-starter-test")
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिखाए गए अनुसार मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप नीचे दिए गए कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप कमांड को दिखाए अनुसार उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

यहां दिए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, आवेदन Tomcat पोर्ट 8080 पर शुरू किया गया है जैसा कि दिखाया गया है।

अब, URL को हिट करें http://localhost:8080/ अपने वेब ब्राउज़र में और वेब सॉकेट कनेक्ट करें और ग्रीटिंग भेजें और संदेश प्राप्त करें।

बैच सेवा एक कार्य में एक से अधिक कमांड निष्पादित करने की एक प्रक्रिया है। इस अध्याय में, आप स्प्रिंग बूट एप्लिकेशन में बैच सेवा बनाने का तरीका जानने जा रहे हैं।

आइए एक उदाहरण पर विचार करें जहां हम CSQL फाइल सामग्री को HSQLDB में सहेजने जा रहे हैं।

बैच सेवा कार्यक्रम बनाने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर बैच निर्भरता और HSQLDB निर्भरता जोड़ने की आवश्यकता है।

Maven उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-batch</artifactId>
</dependency>
<dependency>
   <groupId>org.hsqldb</groupId>
   <artifactId>hsqldb</artifactId>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

compile("org.springframework.boot:spring-boot-starter-batch")
compile("org.hsqldb:hsqldb")

अब, classpath संसाधनों के तहत सरल CSV डेटा फ़ाइल जोड़ें - src / main / resource और फ़ाइल को फ़ाइल के रूप में नाम दें। क्लिक करें: -

William,John
Mike, Sebastian
Lawarance, Lime

अगला, एचएसक्यूएलडीबी के लिए एक एसक्यूएल स्क्रिप्ट लिखें - क्लासपाथ संसाधन निर्देशिका के तहत - request_fail_hystrix_timeout

DROP TABLE USERS IF EXISTS;
CREATE TABLE USERS  (
   user_id BIGINT IDENTITY NOT NULL PRIMARY KEY,
   first_name VARCHAR(20),
   last_name VARCHAR(20)
);

दिखाए गए अनुसार USERS मॉडल के लिए एक POJO वर्ग बनाएं -

package com.tutorialspoint.batchservicedemo;
public class User {
   private String lastName;
   private String firstName;

   public User() {
   }
   public User(String firstName, String lastName) {
      this.firstName = firstName;
      this.lastName = lastName;
   }
   public void setFirstName(String firstName) {
      this.firstName = firstName;
   }
   public String getFirstName() {
      return firstName;
   }
   public String getLastName() {
      return lastName;
   }
   public void setLastName(String lastName) {
      this.lastName = lastName;
   }

   @Override
   public String toString() {
      return "firstName: " + firstName + ", lastName: " + lastName;
   }   
}

अब, CSV फ़ाइल से डेटा पढ़ने और SQL में डेटा लिखने से पहले ऑपरेशन करने के लिए एक मध्यवर्ती प्रोसेसर बनाएँ।

package com.tutorialspoint.batchservicedemo;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.batch.item.ItemProcessor;

public class UserItemProcessor implements ItemProcessor<User, User> {
   private static final Logger log = LoggerFactory.getLogger(UserItemProcessor.class);

   @Override
   public User process(final User user) throws Exception {
      final String firstName = user.getFirstName().toUpperCase();
      final String lastName = user.getLastName().toUpperCase();
      final User transformedPerson = new User(firstName, lastName);

      log.info("Converting (" + user + ") into (" + transformedPerson + ")");
      return transformedPerson;
   }
}

CSV से डेटा पढ़ने के लिए और नीचे दिखाए अनुसार SQL फ़ाइल में लिखने के लिए, हम एक बैच कॉन्फ़िगरेशन फ़ाइल बनाते हैं। हमें कॉन्फ़िगरेशन क्लास फ़ाइल में @EnableBatchProcessing एनोटेशन जोड़ने की आवश्यकता है। @EnableBatchProcessing एनोटेशन का उपयोग आपके स्प्रिंग बूट अनुप्रयोग के लिए बैच संचालन को सक्षम करने के लिए किया जाता है।

package com.tutorialspoint.batchservicedemo;

import javax.sql.DataSource;
import org.springframework.batch.core.Job;
import org.springframework.batch.core.Step;

import org.springframework.batch.core.configuration.annotation.EnableBatchProcessing;
import org.springframework.batch.core.configuration.annotation.JobBuilderFactory;
import org.springframework.batch.core.configuration.annotation.StepBuilderFactory;
import org.springframework.batch.core.launch.support.RunIdIncrementer;
import org.springframework.batch.item.database.BeanPropertyItemSqlParameterSourceProvider;
import org.springframework.batch.item.database.JdbcBatchItemWriter;
import org.springframework.batch.item.file.FlatFileItemReader;
import org.springframework.batch.item.file.mapping.BeanWrapperFieldSetMapper;
import org.springframework.batch.item.file.mapping.DefaultLineMapper;
import org.springframework.batch.item.file.transform.DelimitedLineTokenizer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.ClassPathResource;

@Configuration
@EnableBatchProcessing
public class BatchConfiguration {
   @Autowired
   public JobBuilderFactory jobBuilderFactory;

   @Autowired
   public StepBuilderFactory stepBuilderFactory;

   @Autowired
   public DataSource dataSource;

   @Bean
   public FlatFileItemReader<User> reader() {
      FlatFileItemReader<User> reader = new FlatFileItemReader<User>();
      reader.setResource(new ClassPathResource("file.csv"));
      reader.setLineMapper(new DefaultLineMapper<User>() {
         {
            setLineTokenizer(new DelimitedLineTokenizer() {
               {
                  setNames(new String[] { "firstName", "lastName" });
               }
            });
            setFieldSetMapper(new BeanWrapperFieldSetMapper<User>() {
               {
                  setTargetType(User.class);
               }
            });
         }
      });
      return reader;
   }
   @Bean
   public UserItemProcessor processor() {
      return new UserItemProcessor();
   }
   @Bean
   public JdbcBatchItemWriter<User> writer() {
      JdbcBatchItemWriter<User> writer = new JdbcBatchItemWriter<User>();
      writer.setItemSqlParameterSourceProvider(new BeanPropertyItemSqlParameterSourceProvider<User>());
      writer.setSql("INSERT INTO USERS (first_name, last_name) VALUES (:firstName, :lastName)");
      writer.setDataSource(dataSource);
      return writer;
   }
   @Bean
   public Job importUserJob(JobCompletionNotificationListener listener) {
      return jobBuilderFactory.get("importUserJob").incrementer(
         new RunIdIncrementer()).listener(listener).flow(step1()).end().build();
   }
   @Bean
   public Step step1() {
      return stepBuilderFactory.get("step1").<User, User>chunk(10).reader(reader()).processor(processor()).writer(writer()).build();
   }
}

reader() CSV फ़ाइल से डेटा पढ़ने के लिए विधि का उपयोग किया जाता है और लेखक () पद्धति का उपयोग SQL में डेटा लिखने के लिए किया जाता है।

इसके बाद, हमें एक जॉब कम्प्लीमेंट नोटिफिकेशन श्रोता वर्ग लिखना होगा - जिसका उपयोग नौकरी पूरा होने के बाद सूचित करने के लिए किया जाता है।

package com.tutorialspoint.batchservicedemo;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import org.springframework.batch.core.BatchStatus;
import org.springframework.batch.core.JobExecution;
import org.springframework.batch.core.listener.JobExecutionListenerSupport;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.stereotype.Component;

@Component
public class JobCompletionNotificationListener extends JobExecutionListenerSupport {
   private static final Logger log = LoggerFactory.getLogger(JobCompletionNotificationListener.class);
   private final JdbcTemplate jdbcTemplate;

   @Autowired
   public JobCompletionNotificationListener(JdbcTemplate jdbcTemplate) {
      this.jdbcTemplate = jdbcTemplate;
   }
   @Override
   public void afterJob(JobExecution jobExecution) {
      if (jobExecution.getStatus() == BatchStatus.COMPLETED) {
         log.info("!!! JOB FINISHED !! It's time to verify the results!!");

         List<User> results = jdbcTemplate.query(
            "SELECT first_name, last_name FROM USERS", new RowMapper<User>() {
            
            @Override
            public User mapRow(ResultSet rs, int row) throws SQLException {
               return new User(rs.getString(1), rs.getString(2));
            }
         });

         for (User person : results) {
            log.info("Found <" + person + "> in the database.");
         }
      }
   }
}

अब, एक निष्पादन योग्य JAR फ़ाइल बनाएँ, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन को चलाएं।

मावेन के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप कमांड को दिखाए अनुसार उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

यहां दिए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

आप कंसोल विंडो में आउटपुट को देख सकते हैं -

अपाचे काफ्का एक ओपन सोर्स प्रोजेक्ट है जिसका इस्तेमाल गलती-सहिष्णु मैसेजिंग सिस्टम पर आधारित संदेशों को प्रकाशित और सब्सक्राइब करने के लिए किया जाता है। यह तेज, स्केलेबल है और डिजाइन द्वारा वितरित किया गया है। यदि आप काफ्का के लिए एक शुरुआत कर रहे हैं, या इस पर एक बेहतर समझ हासिल करना चाहते हैं, तो कृपया इस लिंक को देखें - www.tutorialspoint.com/apache_kafka/

इस अध्याय में, हम यह देखने जा रहे हैं कि स्प्रिंग बूट एप्लिकेशन में अपाचे काफ्का को कैसे लागू किया जाए।

सबसे पहले, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग काफ्का निर्भरता जोड़ने की आवश्यकता है।

मावेन उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.kafka</groupId>
   <artifactId>spring-kafka</artifactId>
   <version>2.1.0.RELEASE</version>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

compile group: 'org.springframework.kafka', name: 'spring-kafka', version: '2.1.0.RELEASE'

संदेश उत्पन्न करना

अपाचे काफ्का में संदेश उत्पन्न करने के लिए, हमें निर्माता विन्यास के लिए विन्यास वर्ग को परिभाषित करने की आवश्यकता है -

package com.tutorialspoint.kafkademo;

import java.util.HashMap;
import java.util.Map;

import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.common.serialization.StringSerializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.core.DefaultKafkaProducerFactory;
import org.springframework.kafka.core.KafkaTemplate;
import org.springframework.kafka.core.ProducerFactory;

@Configuration
public class KafkaProducerConfig {
   @Bean
   public ProducerFactory<String, String> producerFactory() {
      Map<String, Object> configProps = new HashMap<>();
      configProps.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:9092");
      configProps.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
      configProps.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
      return new DefaultKafkaProducerFactory<>(configProps);
   }
   @Bean
   public KafkaTemplate<String, String> kafkaTemplate() {
      return new KafkaTemplate<>(producerFactory());
   }
}

संदेश प्रकाशित करने के लिए, काफ्का टेम्प्लेट ऑब्जेक्ट को ऑटो तार करें और दिखाए गए अनुसार संदेश का उत्पादन करें।

@Autowired
private KafkaTemplate<String, String> kafkaTemplate;
 
public void sendMessage(String msg) {
   kafkaTemplate.send(topicName, msg);
}

एक संदेश का उपभोग करना

संदेशों का उपभोग करने के लिए, हमें नीचे दिखाए गए अनुसार एक उपभोक्ता कॉन्फ़िगरेशन क्लास फ़ाइल लिखने की आवश्यकता है।

package com.tutorialspoint.kafkademo;

import java.util.HashMap;
import java.util.Map;

import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.common.serialization.StringDeserializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.annotation.EnableKafka;
import org.springframework.kafka.config.ConcurrentKafkaListenerContainerFactory;
import org.springframework.kafka.core.ConsumerFactory;
import org.springframework.kafka.core.DefaultKafkaConsumerFactory;

@EnableKafka
@Configuration
public class KafkaConsumerConfig {
   @Bean
   public ConsumerFactory<String, String> consumerFactory() {
      Map<String, Object> props = new HashMap<>();
      props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:2181");
      props.put(ConsumerConfig.GROUP_ID_CONFIG, "group-id");
      props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
      props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
      return new DefaultKafkaConsumerFactory<>(props);
   }
   @Bean
   public ConcurrentKafkaListenerContainerFactory<String, String> kafkaListenerContainerFactory() {
      ConcurrentKafkaListenerContainerFactory<String, String> 
      factory = new ConcurrentKafkaListenerContainerFactory<>();
      factory.setConsumerFactory(consumerFactory());
      return factory;
   }
}

अगला, संदेशों को सुनने के लिए एक श्रोता लिखें।

@KafkaListener(topics = "tutorialspoint", groupId = "group-id")
public void listen(String message) {
   System.out.println("Received Messasge in group - group-id: " + message);
}

हमें मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल से ApplicationRunner वर्ग रन विधि से sendMessage () विधि को कॉल करें और उसी वर्ग फ़ाइल से संदेश का उपभोग करें।

आपका मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल कोड नीचे दिया गया है -

package com.tutorialspoint.kafkademo;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.kafka.core.KafkaTemplate;

@SpringBootApplication
public class KafkaDemoApplication implements ApplicationRunner {
   @Autowired
   private KafkaTemplate<String, String> kafkaTemplate;

   public void sendMessage(String msg) {
      kafkaTemplate.send("tutorialspoint", msg);
   }
   public static void main(String[] args) {
      SpringApplication.run(KafkaDemoApplication.class, args);
   }
   @KafkaListener(topics = "tutorialspoint", groupId = "group-id")
   public void listen(String message) {
      System.out.println("Received Messasge in group - group-id: " + message);
   }
   @Override
   public void run(ApplicationArguments args) throws Exception {
      sendMessage("Hi Welcome to Spring For Apache Kafka");
   }
}

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए कोड नीचे दिया गया है।

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>kafka-demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>kafka-demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.kafka</groupId>
         <artifactId>spring-kafka</artifactId>
         <version>2.1.0.RELEASE</version>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter')
   compile group: 'org.springframework.kafka', name: 'spring-kafka', version: '2.1.0.RELEASE'
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

अब, एक निष्पादन योग्य JAR फ़ाइल बनाएँ, और नीचे दिए गए मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चलाएं -

मावेन के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रैडल के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

यहां दिए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

आप कंसोल विंडो में आउटपुट देख सकते हैं।

Twilio एक 3 rd पार्टी एप्लिकेशन है जिसका उपयोग हमारे एप्लिकेशन से एसएमएस भेजने और वॉयस कॉल करने के लिए किया जाता है। यह हमें एसएमएस भेजने और प्रोग्राम करने के लिए वॉयस कॉल करने की अनुमति देता है।

इस अध्याय में, आप सीखना चाहते हैं कि ट्विनियो के साथ स्प्रिंग बूट का उपयोग करके एसएमएस भेजने और आवाज कॉल को कैसे लागू किया जाए।

Note- हमने एसएमएस भेजने और वॉयस कॉल करने के लिए ट्विलियो में ट्रेल अकाउंट का इस्तेमाल किया। आप Twilio के बारे में www.twilio.com पर अधिक जान सकते हैं ।

सबसे पहले, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में टिलिओ निर्भरता को जोड़ना होगा।

मावेन उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

<dependency>
   <groupId>com.twilio.sdk</groupId>
   <artifactId>twilio</artifactId>
   <version>7.16.1</version>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

compile group: "com.twilio.sdk", name:"twilio", version: "7.16.1"

अब, दिखाए गए अनुसार स्थिर खाते में ACCOUNT_SID और AUTH_ID के साथ ट्विलियो खाते को इनिशियलाइज़ करें -

static {
   Twilio.init(ACCOUNT_SID, AUTH_ID);
}

एसएमएस भेजना

एसएमएस भेजने के लिए, हमें Message.create () पद्धति से एक नंबर और नंबर प्रदान करना होगा। संदेश बॉडी कंटेंट भी हमें मैसेज के लिए प्रदान करने की आवश्यकता है Message.creator () जैसा कि दिखाया गया है -

Message.creator(new PhoneNumber("to-number"), new PhoneNumber("from-number"),
   "Message from Spring Boot Application").create();

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल नीचे दिख रही है।

package com.tutorialspoint.smsdemo;

import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

import com.twilio.Twilio;
import com.twilio.rest.api.v2010.account.Message;
import com.twilio.type.PhoneNumber;

@SpringBootApplication
public class SmsdemoApplication implements ApplicationRunner {
   private final static String ACCOUNT_SID = "<your-account-sid>";
   private final static String AUTH_ID = "<your-auth-id>";

   static {
      Twilio.init(ACCOUNT_SID, AUTH_ID);
   }
   public static void main(String[] args) {
      SpringApplication.run(SmsdemoApplication.class, args);
   }
   @Override
   public void run(ApplicationArguments arg0) throws Exception {
      Message.creator(new PhoneNumber("to-number"), new PhoneNumber("from-number"),
         "Message from Spring Boot Application").create();
   }
}

कॉन्फ़िगरेशन फ़ाइल बनाने का पूरा कोड नीचे दिया गया है -

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>smsdemo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>smsdemo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
      <dependency>
         <groupId>com.twilio.sdk</groupId>
         <artifactId>twilio</artifactId>
         <version>7.16.1</version>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter')
   testCompile('org.springframework.boot:spring-boot-starter-test')
   compile group: "com.twilio.sdk", name:"twilio", version: "7.11.+"   
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्नलिखित मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रैडल के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

नीचे दिए गए आदेश का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, आप अपने "नंबर" को एसएमएस प्राप्त करेंगे।

"नंबर" के लिए संदेश प्राप्त हुआ।

Sent from your Twilio trail account
- Message from Spring Boot Application

Note- इस उदाहरण में, हमने ट्रेल खाते का उपयोग किया। तो, आपको एसएमएस भेजने से पहले संख्याओं का सत्यापन करना चाहिए।

आवाज कॉल

Twilio का उपयोग करके वॉइस कॉल करने के लिए, हमें Call.creator () विधि को कॉल करने की आवश्यकता है। इस विधि के लिए, हमें यहां दिखाए गए अनुसार एक नंबर, से-नंबर और वॉइस-नोट प्रदान करना होगा।

Call.creator(new PhoneNumber("<to-number>"), new PhoneNumber("<from-number>"),
   new URI("http://demo.twilio.com/docs/voice.xml")).create();

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल का कोड नीचे दिया गया है।

package com.tutorialspoint.smsdemo; 

import java.net.URI;

import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

import com.twilio.Twilio;
import com.twilio.rest.api.v2010.account.Call;
import com.twilio.type.PhoneNumber;

@SpringBootApplication
public class SmsdemoApplication implements ApplicationRunner {
   private final static String ACCOUNT_SID = "<ACCOUNT-SID>";
   private final static String AUTH_ID = "AUTH-ID";

   static {
      Twilio.init(ACCOUNT_SID, AUTH_ID);
   }
   public static void main(String[] args) {
      SpringApplication.run(SmsdemoApplication.class, args);
   }
   @Override
   public void run(ApplicationArguments arg0) throws Exception {
      Call.creator(new PhoneNumber("<to-number>"), new PhoneNumber("<from-number>"),
         new URI("http://demo.twilio.com/docs/voice.xml")).create();
   }
}

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए कोड नीचे दिया गया है -

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>smsdemo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>smsdemo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
      <dependency>
         <groupId>com.twilio.sdk</groupId>
         <artifactId>twilio</artifactId>
         <version>7.16.1</version>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter')
   testCompile('org.springframework.boot:spring-boot-starter-test')
   compile group: "com.twilio.sdk", name:"twilio", version: "7.11.+"   
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

मावेन के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रैडल के लिए, दिखाए गए अनुसार कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, यहाँ दी गई कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, आप Twilio से अपने "टू-नंबर" पर कॉल प्राप्त करेंगे।

कॉल अटेंड करने के बाद कोई भी कुंजी दबाएं, आपको वॉयस नोट सुनाई देगा https://demo.twilio.com/docs/voice.xml

Note- इस उदाहरण में, हमने ट्रेल खाते का उपयोग किया। इसलिए, आपको कॉल करने से पहले संख्याओं का सत्यापन करना चाहिए।

यूनिट टेस्टिंग डेवलपर्स द्वारा किए गए परीक्षण में से एक है जो यह सुनिश्चित करने के लिए किया जाता है कि व्यक्तिगत इकाई या घटक कार्यात्मकता ठीक काम कर रही है।

इस ट्यूटोरियल में, हम यह देखने जा रहे हैं कि मॉकिटो और वेब कंट्रोलर का उपयोग करके यूनिट टेस्ट केस कैसे लिखें।

Mockito

स्प्रिंग बीन्स में मॉकिटो मोक्स को इंजेक्ट करने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में मॉकिटो-कोर निर्भरता को जोड़ना होगा।

मावेन उपयोगकर्ता आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

<dependency>
   <groupId>org.mockito</groupId>
   <artifactId>mockito-core</artifactId>
   <version>2.13.0</version>
</dependency>
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
   <scope>test</scope>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

compile group: 'org.mockito', name: 'mockito-core', version: '2.13.0'
testCompile('org.springframework.boot:spring-boot-starter-test')

सेवा वर्ग लिखने के लिए कोड जिसमें एक विधि है जो स्ट्रिंग मान लौटाता है, यहां दिया गया है।

package com.tutorialspoint.mockitodemo;

import org.springframework.stereotype.Service;

@Service
public class ProductService {
   public String getProductName() {
      return "Honey";
   } 
}

अब, दिखाए गए अनुसार ProductService वर्ग को किसी अन्य सेवा वर्ग फ़ाइल में इंजेक्ट करें।

package com.tutorialspoint.mockitodemo;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class OrderService {
   @Autowired
   ProductService productService;

   public OrderService(ProductService productService) {
      this.productService = productService;
   }
   public String getProductName() {
      return productService.getProductName();
   }
}

मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल नीचे दी गई है -

package com.tutorialspoint.mockitodemo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class MockitoDemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(MockitoDemoApplication.class, args);
   }
}

फिर, परीक्षण के लिए अनुप्रयोग संदर्भ कॉन्फ़िगर करें। जब टेस्ट केस चल रहे हों तो क्लास को कॉन्फ़िगर करने के लिए @Profile ("टेस्ट") एनोटेशन का उपयोग किया जाता है।

package com.tutorialspoint.mockitodemo;

import org.mockito.Mockito;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.context.annotation.Profile;

@Profile("test")
@Configuration
public class ProductServiceTestConfiguration {
   @Bean
   @Primary
   public ProductService productService() {
      return Mockito.mock(ProductService.class);
   }
}

अब, आप के तहत ऑर्डर सर्विस के लिए एक यूनिट टेस्ट केस लिख सकते हैं src/test/resources पैकेज।

package com.tutorialspoint.mockitodemo;

import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mockito;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.ActiveProfiles;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@SpringBootTest
@ActiveProfiles("test")
@RunWith(SpringJUnit4ClassRunner.class)
public class MockitoDemoApplicationTests {
   @Autowired
   private OrderService orderService;
   
   @Autowired
   private ProductService productService;

   @Test
   public void whenUserIdIsProvided_thenRetrievedNameIsCorrect() {
      Mockito.when(productService.getProductName()).thenReturn("Mock Product Name");
      String testName = orderService.getProductName();
      Assert.assertEquals("Mock Product Name", testName);
   }
}

बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए पूरा कोड नीचे दिया गया है।

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>mockito-demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>

   <name>mockito-demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter</artifactId>
      </dependency>
      <dependency>
         <groupId>org.mockito</groupId>
         <artifactId>mockito-core</artifactId>
         <version>2.13.0</version>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter')
   compile group: 'org.mockito', name: 'mockito-core', version: '2.13.0'
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न Maven या Gradle1 कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

मावेन के लिए, आप कमांड को दिखाए अनुसार उपयोग कर सकते हैं -

mvn clean install

आप कंसोल विंडो में परीक्षा परिणाम देख सकते हैं।

ग्रेडल के लिए, आप कमांड को दिखाए अनुसार उपयोग कर सकते हैं -

gradle clean build

आप कंसोल विंडो में बाकी परिणाम देख सकते हैं।

स्प्रिंग बूट रेस्ट कंट्रोलर फ़ाइल के लिए यूनिट टेस्ट लिखने का एक आसान तरीका प्रदान करता है। SpringJUnit4ClassRunner और MockMvc की सहायता से, हम रेस्ट कंट्रोलर फ़ाइल के लिए यूनिट टेस्ट लिखने के लिए एक वेब एप्लिकेशन संदर्भ बना सकते हैं।

यूनिट टेस्ट के तहत लिखा जाना चाहिए src/test/java टेस्ट लिखने के लिए डायरेक्टरी और क्लासपैथ संसाधनों को नीचे रखा जाना चाहिए src/test/resources निर्देशिका।

यूनिट टेस्ट लिखने के लिए, हमें आपकी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर टेस्ट निर्भरता जोड़ने की आवश्यकता है जैसा कि नीचे दिखाया गया है।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
   <scope>test</scope>
</dependency>

ग्रेडल उपयोगकर्ता आपकी बिल्ड.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

testCompile('org.springframework.boot:spring-boot-starter-test')

टेस्ट केस लिखने से पहले, हमें पहले रैस्टफुल वेब सेवाओं का निर्माण करना चाहिए। रेस्टफुल वेब सेवाओं के निर्माण के बारे में अधिक जानकारी के लिए, कृपया इस ट्यूटोरियल में दिए गए अध्याय को देखें।

REST नियंत्रक के लिए एक यूनिट टेस्ट लिखना

इस खंड में, हम देखते हैं कि REST नियंत्रक के लिए एक यूनिट टेस्ट कैसे लिखें।

सबसे पहले, हमें MockMvc का उपयोग करके वेब एप्लिकेशन संदर्भ बनाने के लिए उपयोग की जाने वाली Abstract क्लास फ़ाइल बनाने और mapToJson () और mapFromJson () विधियों को जावा ऑब्जेक्ट को JSON स्ट्रिंग में बदलने और जावा ऑब्जेक्ट को जावा ऑब्जेक्ट में बदलने के लिए परिभाषित करने की आवश्यकता है।

package com.tutorialspoint.demo;

import java.io.IOException;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
import org.springframework.web.context.WebApplicationContext;

import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.ObjectMapper;

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = DemoApplication.class)
@WebAppConfiguration
public abstract class AbstractTest {
   protected MockMvc mvc;
   @Autowired
   WebApplicationContext webApplicationContext;

   protected void setUp() {
      mvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).build();
   }
   protected String mapToJson(Object obj) throws JsonProcessingException {
      ObjectMapper objectMapper = new ObjectMapper();
      return objectMapper.writeValueAsString(obj);
   }
   protected <T> T mapFromJson(String json, Class<T> clazz)
      throws JsonParseException, JsonMappingException, IOException {
      
      ObjectMapper objectMapper = new ObjectMapper();
      return objectMapper.readValue(json, clazz);
   }
}

इसके बाद, एक क्लास फाइल लिखें जो एब्सट्रैक्ट क्लास को बढ़ाती है और प्रत्येक विधि जैसे GET, POST, PUT और DELETE के लिए एक यूनिट टेस्ट लिखें।

GET API टेस्ट केस के लिए कोड नीचे दिया गया है। यह एपीआई उत्पादों की सूची देखने के लिए है।

@Test
public void getProductsList() throws Exception {
   String uri = "/products";
   MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.get(uri)
      .accept(MediaType.APPLICATION_JSON_VALUE)).andReturn();
   
   int status = mvcResult.getResponse().getStatus();
   assertEquals(200, status);
   String content = mvcResult.getResponse().getContentAsString();
   Product[] productlist = super.mapFromJson(content, Product[].class);
   assertTrue(productlist.length > 0);
}

POST API टेस्ट केस के लिए कोड नीचे दिया गया है। यह एपीआई एक उत्पाद बनाने के लिए है।

@Test
public void createProduct() throws Exception {
   String uri = "/products";
   Product product = new Product();
   product.setId("3");
   product.setName("Ginger");
   
   String inputJson = super.mapToJson(product);
   MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.post(uri)
      .contentType(MediaType.APPLICATION_JSON_VALUE).content(inputJson)).andReturn();
   
   int status = mvcResult.getResponse().getStatus();
   assertEquals(201, status);
   String content = mvcResult.getResponse().getContentAsString();
   assertEquals(content, "Product is created successfully");
}

PUT API टेस्ट केस के लिए कोड नीचे दिया गया है। यह एपीआई मौजूदा उत्पाद को अद्यतन करने के लिए है।

@Test
public void updateProduct() throws Exception {
   String uri = "/products/2";
   Product product = new Product();
   product.setName("Lemon");
   
   String inputJson = super.mapToJson(product);
   MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.put(uri)
      .contentType(MediaType.APPLICATION_JSON_VALUE).content(inputJson)).andReturn();
   
   int status = mvcResult.getResponse().getStatus();
   assertEquals(200, status);
   String content = mvcResult.getResponse().getContentAsString();
   assertEquals(content, "Product is updated successsfully");
}

Delete API Test केस के लिए कोड नीचे दिया गया है। यह API मौजूदा उत्पाद को हटा देगा।

@Test
public void deleteProduct() throws Exception {
   String uri = "/products/2";
   MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.delete(uri)).andReturn();
   int status = mvcResult.getResponse().getStatus();
   assertEquals(200, status);
   String content = mvcResult.getResponse().getContentAsString();
   assertEquals(content, "Product is deleted successsfully");
}

पूर्ण नियंत्रक परीक्षण कक्षा फ़ाइल नीचे दी गई है -

package com.tutorialspoint.demo;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;

import org.junit.Before;
import org.junit.Test;
import org.springframework.http.MediaType;
import org.springframework.test.web.servlet.MvcResult;
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;

import com.tutorialspoint.demo.model.Product;

public class ProductServiceControllerTest extends AbstractTest {
   @Override
   @Before
   public void setUp() {
      super.setUp();
   }
   @Test
   public void getProductsList() throws Exception {
      String uri = "/products";
      MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.get(uri)
         .accept(MediaType.APPLICATION_JSON_VALUE)).andReturn();
      
      int status = mvcResult.getResponse().getStatus();
      assertEquals(200, status);
      String content = mvcResult.getResponse().getContentAsString();
      Product[] productlist = super.mapFromJson(content, Product[].class);
      assertTrue(productlist.length > 0);
   }
   @Test
   public void createProduct() throws Exception {
      String uri = "/products";
      Product product = new Product();
      product.setId("3");
      product.setName("Ginger");
      String inputJson = super.mapToJson(product);
      MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.post(uri)
         .contentType(MediaType.APPLICATION_JSON_VALUE)
         .content(inputJson)).andReturn();
      
      int status = mvcResult.getResponse().getStatus();
      assertEquals(201, status);
      String content = mvcResult.getResponse().getContentAsString();
      assertEquals(content, "Product is created successfully");
   }
   @Test
   public void updateProduct() throws Exception {
      String uri = "/products/2";
      Product product = new Product();
      product.setName("Lemon");
      String inputJson = super.mapToJson(product);
      MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.put(uri)
         .contentType(MediaType.APPLICATION_JSON_VALUE)
         .content(inputJson)).andReturn();
      
      int status = mvcResult.getResponse().getStatus();
      assertEquals(200, status);
      String content = mvcResult.getResponse().getContentAsString();
      assertEquals(content, "Product is updated successsfully");
   }
   @Test
   public void deleteProduct() throws Exception {
      String uri = "/products/2";
      MvcResult mvcResult = mvc.perform(MockMvcRequestBuilders.delete(uri)).andReturn();
      int status = mvcResult.getResponse().getStatus();
      assertEquals(200, status);
      String content = mvcResult.getResponse().getContentAsString();
      assertEquals(content, "Product is deleted successsfully");
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे दिए गए मावेन या ग्रेडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, आप नीचे दिए गए कमांड का उपयोग कर सकते हैं -

mvn clean install

अब, आप कंसोल विंडो में परीक्षा परिणाम देख सकते हैं।

ग्रेडल के लिए, आप नीचे दिखाए अनुसार कमांड का उपयोग कर सकते हैं -

gradle clean build

आप नीचे दिखाए गए अनुसार कंसोल विंडो में बाकी परिणाम देख सकते हैं।

स्प्रिंग बूट डेटाबेस के लिए एक डेटा स्रोत बनाने के लिए एक बहुत अच्छा समर्थन प्रदान करता है। स्प्रिंग बूट में डेटा स्रोत बनाने के लिए हमें कोई अतिरिक्त कोड लिखने की आवश्यकता नहीं है। बस निर्भरता को जोड़ना और कॉन्फ़िगरेशन विवरण करना डेटा स्रोत बनाने और डेटाबेस को जोड़ने के लिए पर्याप्त है।

इस अध्याय में, हम डेटाबेस को जोड़ने के लिए स्प्रिंग बूट JDBC ड्राइवर कनेक्शन का उपयोग करने जा रहे हैं।

सबसे पहले, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर JDBC निर्भरता जोड़ने की आवश्यकता है।

Maven उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

compile('org.springframework.boot:spring-boot-starter-jdbc')

H2 डेटाबेस से कनेक्ट करें

H2 डेटाबेस को जोड़ने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में H2 डेटाबेस निर्भरता को जोड़ना होगा।

मावेन उपयोगकर्ताओं के लिए, अपनी pom.xml फ़ाइल में नीचे की निर्भरता जोड़ें।

<dependency>
   <groupId>com.h2database</groupId>
   <artifactId>h2</artifactId>
</dependency>

ग्रेडल उपयोगकर्ताओं के लिए, अपनी build.gradle फ़ाइल में नीचे की निर्भरता जोड़ें।

compile('com.h2database:h2')

हमें H2 डेटाबेस को जोड़ने के लिए classpath src / main / Resources डायरेक्टरी के तहत स्कीमा.एसक्यूएल फाइल और data.sql फाइल बनाने की जरूरत है।

स्कीमा। एसक्यूएल फ़ाइल नीचे दी गई है।

CREATE TABLE PRODUCT (ID INT PRIMARY KEY, PRODUCT_NAME VARCHAR(25));

Data.sql फ़ाइल नीचे दी गई है।

INSERT INTO PRODUCT (ID,PRODUCT_NAME) VALUES (1,'Honey');
INSERT INTO PRODUCT (ID,PRODUCT_NAME) VALUES (2,'Almond');

MySQL कनेक्ट करें

MySQL डेटाबेस को जोड़ने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में MySQL निर्भरता को जोड़ना होगा।

मावेन उपयोगकर्ताओं के लिए, अपनी pom.xml फ़ाइल में निम्न निर्भरता जोड़ें।

<dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
</dependency>

ग्रेडल उपयोगकर्ताओं के लिए, अपनी build.gradle फ़ाइल में निम्न निर्भरता जोड़ें।

compile('mysql:mysql-connector-java')

अब दिखाए गए अनुसार MySQL में डेटाबेस और टेबल बनाएं -

गुण फ़ाइल उपयोगकर्ताओं के लिए, application.properties फ़ाइल में निम्न गुण जोड़ें।

spring.datasource.driverClassName = com.mysql.jdbc.Driver
spring.datasource.url = jdbc:mysql://localhost:3306/PRODUCTSERVICE?autoreconnect = true
spring.datasource.username = root
spring.datasource.password = root
spring.datasource.testOnBorrow = true
spring.datasource.testWhileIdle = true
spring.datasource.timeBetweenEvictionRunsMillis = 60000
spring.datasource.minEvictableIdleTimeMillis = 30000
spring.datasource.validationQuery = SELECT 1
spring.datasource.max-active = 15
spring.datasource.max-idle = 10
spring.datasource.max-wait = 8000

YAML उपयोगकर्ताओं के लिए, application.yml फ़ाइल में निम्नलिखित गुण जोड़ें।

spring:
   datasource: 
      driverClassName: com.mysql.jdbc.Driver
      url: "jdbc:mysql://localhost:3306/PRODUCTSERVICE?autoreconnect=true"
      username: "root"
      password: "root"
      testOnBorrow: true
      testWhileIdle: true
      timeBetweenEvictionRunsMillis: 60000
      minEvictableIdleTimeMillis: 30000
      validationQuery: SELECT 1
      max-active: 15
      max-idle: 10
      max-wait: 8000

रेडिस कनेक्ट करें

रेडिस एक खुला स्रोत डेटाबेस है जिसका उपयोग इन-मेमोरी डेटा संरचना को संग्रहीत करने के लिए किया जाता है। स्प्रिंग बूट एप्लिकेशन में रेडिस डेटाबेस को जोड़ने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में रेडिस निर्भरता को जोड़ना होगा।

Maven उपयोगकर्ताओं को आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़नी चाहिए।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-redis</artifactId>
</dependency>

ग्रेडल उपयोगकर्ताओं को आपकी बिल्ड.ग्रेड फ़ाइल में निम्न निर्भरता जोड़नी चाहिए।

compile('org.springframework.boot:spring-boot-starter-data-redis')

Redis कनेक्शन के लिए, हमें RedisTemplate का उपयोग करना होगा। RedisTemplate के लिए हमें JedisConnectionFactory विवरण प्रदान करने की आवश्यकता है।

@Bean
JedisConnectionFactory jedisConnectionFactory() {
   JedisConnectionFactory jedisConFactory = new JedisConnectionFactory();
   jedisConFactory.setHostName("localhost");
   jedisConFactory.setPort(6000);
   jedisConFactory.setUsePool(true);
   return jedisConFactory;
}
@Bean
public RedisTemplate<String, Object> redisTemplate() {
   RedisTemplate<String, Object> template = new RedisTemplate<>();
   template.setConnectionFactory(jedisConnectionFactory());
   template.setKeySerializer(new StringRedisSerializer());
   template.setHashKeySerializer(new StringRedisSerializer());
   template.setHashValueSerializer(new StringRedisSerializer());
   template.setValueSerializer(new StringRedisSerializer());
   return template;
}

अब RedisTemplate क्लास को ऑटो वायर करें और Redis डेटाबेस से डेटा एक्सेस करें।

@Autowired

RedisTemplate<String, Object> redis;
Map<Object,Object> datalist = redis.opsForHash().entries(“Redis_code_index_key”);

JDBCTemplate

स्प्रिंग बूट एप्लिकेशन में JdbcTemplate का उपयोग करके रिलेशनल डेटाबेस तक पहुंचने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर JDBC निर्भरता जोड़ने की आवश्यकता है।

उसके बाद, यदि आपने @ JdbcTemplate वर्ग का उपयोग किया है, तो स्प्रिंग बूट स्वचालित रूप से डेटाबेस को जोड़ता है और JdbcTemplate ऑब्जेक्ट के लिए डेटा स्रोत सेट करता है।

@Autowired
JdbcTemplate jdbcTemplate;
Collection<Map<String, Object>> rows = jdbc.queryForList("SELECT QUERY");

@Repository एनोटेशन को क्लास फ़ाइल में जोड़ा जाना चाहिए। @Repository एनोटेशन का उपयोग आपके स्प्रिंग बूट एप्लिकेशन के लिए डेटाबेस रिपॉजिटरी बनाने के लिए किया जाता है।

@Repository
public class ProductServiceDAO {
}

एकाधिक डेटा स्रोत

हम सिंगल स्प्रिंग बूट एप्लिकेशन में 'n' नंबर डेटा स्रोत रख सकते हैं। यहां दिए गए उदाहरण से पता चलता है कि स्प्रिंग बूट एप्लिकेशन में 1 से अधिक डेटा स्रोत कैसे बनाएं। अब, एप्लिकेशन गुण फ़ाइल में दो डेटा स्रोत कॉन्फ़िगरेशन विवरण जोड़ें।

गुण फ़ाइल उपयोगकर्ताओं के लिए, निम्न गुणों को अपने application.properties फ़ाइल में जोड़ें।

spring.dbProductService.driverClassName = com.mysql.jdbc.Driver
spring.dbProductService.url = jdbc:mysql://localhost:3306/PRODUCTSERVICE?autoreconnect = true
spring.dbProductService.username = root
spring.dbProductService.password = root
spring.dbProductService.testOnBorrow = true
spring.dbProductService.testWhileIdle = true
spring.dbProductService.timeBetweenEvictionRunsMillis = 60000
spring.dbProductService.minEvictableIdleTimeMillis = 30000
spring.dbProductService.validationQuery = SELECT 1
spring.dbProductService.max-active = 15
spring.dbProductService.max-idle = 10
spring.dbProductService.max-wait = 8000

spring.dbUserService.driverClassName = com.mysql.jdbc.Driver
spring.dbUserService.url = jdbc:mysql://localhost:3306/USERSERVICE?autoreconnect = true
spring.dbUserService.username = root
spring.dbUserService.password = root
spring.dbUserService.testOnBorrow = true
spring.dbUserService.testWhileIdle = true
spring.dbUserService.timeBetweenEvictionRunsMillis = 60000
spring.dbUserService.minEvictableIdleTimeMillis = 30000
spring.dbUserService.validationQuery = SELECT 1
spring.dbUserService.max-active = 15
spring.dbUserService.max-idle = 10
spring.dbUserService.max-wait = 8000

यमल उपयोगकर्ताओं को आपके एप्लिकेशन में निम्नलिखित गुण जोड़ना चाहिए।

spring:
   dbProductService: 
      driverClassName: com.mysql.jdbc.Driver
      url: "jdbc:mysql://localhost:3306/PRODUCTSERVICE?autoreconnect=true"
      password: "root"
      username: "root"
      testOnBorrow: true
      testWhileIdle: true
      timeBetweenEvictionRunsMillis: 60000
      minEvictableIdleTimeMillis: 30000
      validationQuery: SELECT 1
      max-active: 15
      max-idle: 10
      max-wait: 8000
   dbUserService: 
      driverClassName: com.mysql.jdbc.Driver
      url: "jdbc:mysql://localhost:3306/USERSERVICE?autoreconnect=true"
      password: "root"
      username: "root"
      testOnBorrow: true
      testWhileIdle: true
      timeBetweenEvictionRunsMillis: 60000
      minEvictableIdleTimeMillis: 30000
      validationQuery: SELECT 1    
      max-active: 15
      max-idle: 10
      max-wait: 8000

अब, एक DataSource और कई डेटा स्रोतों के लिए JdbcTemplate बनाने के लिए एक कॉन्फ़िगरेशन वर्ग बनाएँ।

import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.jdbc.core.JdbcTemplate;

@Configuration
public class DatabaseConfig {
   @Bean(name = "dbProductService")
   @ConfigurationProperties(prefix = "spring.dbProductService")
   @Primary
   public DataSource createProductServiceDataSource() {
      return DataSourceBuilder.create().build();
   }
   @Bean(name = "dbUserService")
   @ConfigurationProperties(prefix = "spring.dbUserService")
   public DataSource createUserServiceDataSource() {
      return DataSourceBuilder.create().build();
   }
   @Bean(name = "jdbcProductService")
   @Autowired
   public JdbcTemplate createJdbcTemplate_ProductService(@Qualifier("dbProductService") DataSource productServiceDS) {
      return new JdbcTemplate(productServiceDS);
   }
   @Bean(name = "jdbcUserService")
   @Autowired
   public JdbcTemplate createJdbcTemplate_UserService(@Qualifier("dbUserService") DataSource userServiceDS) {
      return new JdbcTemplate(userServiceDS);
   }
}

फिर, @Qualifier एनोटेशन का उपयोग करके JDBCTemplate ऑब्जेक्ट को ऑटो वायर।

@Qualifier("jdbcProductService")
@Autowired
JdbcTemplate jdbcTemplate;

@Qualifier("jdbcUserService")
@Autowired
JdbcTemplate jdbcTemplate;

अगर एक स्प्रिंग बूट सुरक्षा निर्भरता को क्लासपाथ पर जोड़ा जाता है, तो स्प्रिंग बूट एप्लिकेशन को स्वचालित रूप से सभी HTTP एंडपॉइंट्स के लिए मूल प्रमाणीकरण की आवश्यकता होती है। समापन बिंदु "/" और "/ घर" किसी भी प्रमाणीकरण की आवश्यकता नहीं है। अन्य सभी समापन बिंदुओं को प्रमाणीकरण की आवश्यकता होती है।

अपने स्प्रिंग बूट एप्लिकेशन में स्प्रिंग बूट सुरक्षा जोड़ने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर सुरक्षा निर्भरता जोड़ने की आवश्यकता है।

मावेन उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-security</artifactId>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

compile("org.springframework.boot:spring-boot-starter-security")

एक वेब अनुप्रयोग सुरक्षित करना

सबसे पहले, Thymeleaf टेम्पलेट्स का उपयोग करके एक असुरक्षित वेब एप्लिकेशन बनाएं।

फिर, के तहत एक home.html फ़ाइल बनाएँ src/main/resources/templates निर्देशिका।

<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:th = "http://www.thymeleaf.org" 
   xmlns:sec = "http://www.thymeleaf.org/thymeleaf-extras-springsecurity3">
   
   <head>
      <title>Spring Security Example</title>
   </head>
   <body>
      <h1>Welcome!</h1>
      <p>Click <a th:href = "@{/hello}">here</a> to see a greeting.</p>
   </body>
   
</html>

सरल दृश्य /hello Thymeleaf टेम्पलेट्स का उपयोग करके HTML फ़ाइल में परिभाषित किया गया है।

अब, एक hello.html बनाएँ src/main/resources/templates निर्देशिका।

<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:th = "http://www.thymeleaf.org" 
   xmlns:sec = "http://www.thymeleaf.org/thymeleaf-extras-springsecurity3">
   
   <head>
      <title>Hello World!</title>
   </head>
   <body>
      <h1>Hello world!</h1>
   </body>
   
</html>

अब, हमें स्प्रिंग एमवीसी - घर और हैलो विचारों के लिए नियंत्रक देखें।

इसके लिए, एक MVC कॉन्फ़िगरेशन फ़ाइल बनाएँ जो WebMvcConfigurerAdapter का विस्तार करती है।

package com.tutorialspoint.websecuritydemo;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

@Configuration
public class MvcConfig extends WebMvcConfigurerAdapter {
   @Override
   public void addViewControllers(ViewControllerRegistry registry) {
      registry.addViewController("/home").setViewName("home");
      registry.addViewController("/").setViewName("home");
      registry.addViewController("/hello").setViewName("hello");
      registry.addViewController("/login").setViewName("login");
   }
}

अब, अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर सुरक्षा निर्भरता जोड़ें।

मावेन उपयोगकर्ता आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-security</artifactId>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं।

compile("org.springframework.boot:spring-boot-starter-security")

अब, एक वेब सुरक्षा कॉन्फ़िगरेशन फ़ाइल बनाएं, जिसका उपयोग मूल प्रमाणीकरण का उपयोग करके HTTP एंडपॉइंट्स तक पहुंचने के लिए आपके एप्लिकेशन को सुरक्षित करने के लिए किया जाता है।

package com.tutorialspoint.websecuritydemo;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;

@Configuration
@EnableWebSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
   @Override
   protected void configure(HttpSecurity http) throws Exception {
      http
         .authorizeRequests()
            .antMatchers("/", "/home").permitAll()
            .anyRequest().authenticated()
            .and()
         .formLogin()
            .loginPage("/login")
            .permitAll()
            .and()
            .logout()
            .permitAll();
   }
   @Autowired
   public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
      auth
         .inMemoryAuthentication()
         .withUser("user").password("password").roles("USER");
   }
}

अब, के तहत एक login.html फ़ाइल बनाएँ src/main/resources निर्देशिका लॉगिन स्क्रीन के माध्यम से HTTP समापन बिंदु का उपयोग करने की अनुमति देने के लिए निर्देशिका।

<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml" xmlns:th = "http://www.thymeleaf.org"
   xmlns:sec = "http://www.thymeleaf.org/thymeleaf-extras-springsecurity3">
   
   <head>
      <title>Spring Security Example </title>
   </head>
   <body>
      <div th:if = "${param.error}">
         Invalid username and password.
      </div>
      <div th:if = "${param.logout}">
         You have been logged out.
      </div>
      
      <form th:action = "@{/login}" method = "post">
         <div>
            <label> User Name : <input type = "text" name = "username"/> </label>
         </div>
         <div>
            <label> Password: <input type = "password" name = "password"/> </label>
         </div>
         <div>
            <input type = "submit" value = "Sign In"/>
         </div>
      </form>
      
   </body>
</html>

अंत में, hello.html फ़ाइल को अपडेट करें - उपयोगकर्ता को एप्लिकेशन से साइन-आउट करने की अनुमति दें और नीचे दिखाए अनुसार वर्तमान उपयोगकर्ता नाम प्रदर्शित करें -

<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml" xmlns:th = "http://www.thymeleaf.org" 
   xmlns:sec = "http://www.thymeleaf.org/thymeleaf-extras-springsecurity3">
   
   <head>
      <title>Hello World!</title>
   </head>
   <body>
      <h1 th:inline = "text">Hello [[${#httpServletRequest.remoteUser}]]!</h1>
      <form th:action = "@{/logout}" method = "post">
         <input type = "submit" value = "Sign Out"/>
      </form>
   </body>
   
</html>

मुख्य स्प्रिंग बूट एप्लिकेशन का कोड नीचे दिया गया है -

package com.tutorialspoint.websecuritydemo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class WebsecurityDemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(WebsecurityDemoApplication.class, args);
   }
}

बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए पूरा कोड नीचे दिया गया है।

Maven – pom.xml

<?xml version  =  "1.0" encoding  =  "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>websecurity-demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>websecurity-demo</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-security</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-thymeleaf</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.security</groupId>
         <artifactId>spring-security-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-security')
   compile('org.springframework.boot:spring-boot-starter-thymeleaf')
   compile('org.springframework.boot:spring-boot-starter-web')
   
   testCompile('org.springframework.boot:spring-boot-starter-test')
   testCompile('org.springframework.security:spring-security-test')
}

अब, एक निष्पादन योग्य JAR फ़ाइल बनाएँ, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन को चलाएं।

मावेन उपयोगकर्ता नीचे दिए गए आदेश का उपयोग कर सकते हैं -

mvn clean install

"बिल्ड सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडेल उपयोगकर्ता दिखाए गए अनुसार कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, नीचे दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएं -

java –jar <JARFILE>

URL को हिट करें http://localhost:8080/अपने वेब ब्राउज़र में। आप आउटपुट को दिखाए अनुसार देख सकते हैं।

इस अध्याय में, आप JWT के साथ स्प्रिंग बूट सुरक्षा तंत्र और OAuth2 के बारे में विस्तार से जानेंगे।

प्राधिकरण सर्वर

प्राधिकरण सर्वर वेब एपीआई सुरक्षा के लिए एक सर्वोच्च वास्तुशिल्प घटक है। ऑथराइजेशन सर्वर एक केंद्रीकरण ऑथराइजेशन पॉइंट काम करता है जो आपके ऐप्स और HTTP एंडपॉइंट्स को आपके एप्लिकेशन की विशेषताओं की पहचान करने की अनुमति देता है।

संसाधन सर्वर

रिसोर्स सर्वर एक ऐसा एप्लिकेशन है, जो क्लाइंट सर्वर को रिसोर्स सर्वर HTTP एंडपॉइंट एक्सेस करने के लिए एक्सेस टोकन प्रदान करता है। यह उन पुस्तकालयों का संग्रह है जिनमें HTTP समापन बिंदु, स्थिर संसाधन और डायनामिक वेब पेज शामिल हैं।

OAuth2

OAuth2 एक प्राधिकरण ढांचा है जो एप्लिकेशन वेब सुरक्षा को क्लाइंट से संसाधनों तक पहुंचने में सक्षम बनाता है। OAuth2 एप्लिकेशन बनाने के लिए, हमें अनुदान प्रकार (प्राधिकरण कोड), क्लाइंट आईडी और क्लाइंट रहस्य पर ध्यान देने की आवश्यकता है।

JWT टोकन

JWT टोकन एक JSON वेब टोकन है, जिसका उपयोग दो पक्षों के बीच सुरक्षित दावों का प्रतिनिधित्व करने के लिए किया जाता है। आप www.jwt.io/ पर JWT टोकन के बारे में अधिक जान सकते हैं ।

अब, हम एक OAuth2 एप्लिकेशन बनाने जा रहे हैं जो JWT टोकन की सहायता से प्राधिकरण सर्वर, संसाधन सर्वर का उपयोग करने में सक्षम बनाता है।

आप डेटाबेस को एक्सेस करके JWT टोकन के साथ स्प्रिंग बूट सिक्योरिटी को लागू करने के लिए निम्न चरणों का उपयोग कर सकते हैं।

सबसे पहले, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में निम्न निर्भरताएं जोड़ने की आवश्यकता है।

Maven उपयोगकर्ता आपकी pom.xml फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-security</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.security.oauth</groupId>
   <artifactId>spring-security-oauth2</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.security</groupId>
   <artifactId>spring-security-jwt</artifactId>
</dependency>

<dependency>
   <groupId>com.h2database</groupId>
   <artifactId>h2</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
   <scope>test</scope>
</dependency>

<dependency>
   <groupId>org.springframework.security</groupId>
   <artifactId>spring-security-test</artifactId>
   <scope>test</scope>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

compile('org.springframework.boot:spring-boot-starter-security')
compile('org.springframework.boot:spring-boot-starter-web')
testCompile('org.springframework.boot:spring-boot-starter-test')
testCompile('org.springframework.security:spring-security-test')

compile("org.springframework.security.oauth:spring-security-oauth2")
compile('org.springframework.security:spring-security-jwt')
compile("org.springframework.boot:spring-boot-starter-jdbc")
compile("com.h2database:h2:1.4.191")

कहाँ पे,

  • Spring Boot Starter Security - वसंत सुरक्षा लागू करता है

  • Spring Security OAuth2 - प्राधिकरण सर्वर और संसाधन सर्वर को सक्षम करने के लिए OAUTH2 संरचना को लागू करता है।

  • Spring Security JWT - वेब सुरक्षा के लिए JWT टोकन जेनरेट करता है

  • Spring Boot Starter JDBC - उपयोगकर्ता उपलब्ध है या नहीं, यह सुनिश्चित करने के लिए डेटाबेस तक पहुँचता है।

  • Spring Boot Starter Web - HTTP एंडपॉइंट लिखता है।

  • H2 Database - प्रमाणीकरण और प्राधिकरण के लिए उपयोगकर्ता जानकारी संग्रहीत करता है।

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>websecurityapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>websecurityapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-jdbc</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-security</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.security.oauth</groupId>
         <artifactId>spring-security-oauth2</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.security</groupId>
         <artifactId>spring-security-jwt</artifactId>
      </dependency>
      
      <dependency>
         <groupId>com.h2database</groupId>
         <artifactId>h2</artifactId>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
      
      <dependency>
         <groupId>org.springframework.security</groupId>
         <artifactId>spring-security-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}

dependencies {
   compile('org.springframework.boot:spring-boot-starter-security')
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
   testCompile('org.springframework.security:spring-security-test')
   compile("org.springframework.security.oauth:spring-security-oauth2")
   compile('org.springframework.security:spring-security-jwt')
   compile("org.springframework.boot:spring-boot-starter-jdbc")
   compile("com.h2database:h2:1.4.191")  
}

अब, मुख्य स्प्रिंग बूट एप्लिकेशन में, उसी एप्लिकेशन में एक प्रामाणिक सर्वर और संसाधन सर्वर के रूप में कार्य करने के लिए @EnableAuthorizationServer और @EnableResourceServer एनोटेशन जोड़ें।

इसके अलावा, आप JWT टोकन का उपयोग करके वसंत सुरक्षा के साथ एपीआई तक पहुंचने के लिए एक सरल HTTP समापन बिंदु लिखने के लिए निम्न कोड का उपयोग कर सकते हैं।

package com.tutorialspoint.websecurityapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.security.oauth2.config.annotation.web.configuration.EnableAuthorizationServer;
import org.springframework.security.oauth2.config.annotation.web.configuration.EnableResourceServer;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@EnableAuthorizationServer
@EnableResourceServer
@RestController
public class WebsecurityappApplication {
   public static void main(String[] args) {
      SpringApplication.run(WebsecurityappApplication.class, args);
   }
   @RequestMapping(value = "/products")
   public String getProductName() {
      return "Honey";   
   }
}

प्रमाणीकरण के लिए उपयोगकर्ता जानकारी संग्रहीत करने के लिए POJO वर्ग को परिभाषित करने के लिए निम्न कोड का उपयोग करें।

package com.tutorialspoint.websecurityapp;

import java.util.ArrayList;
import java.util.Collection;
import org.springframework.security.core.GrantedAuthority;

public class UserEntity {
   private String username;
   private String password;
   private Collection<GrantedAuthority> grantedAuthoritiesList = new ArrayList<>();
   
   public String getPassword() {
      return password;
   }
   public void setPassword(String password) {
      this.password = password;
   }
   public Collection<GrantedAuthority> getGrantedAuthoritiesList() {
      return grantedAuthoritiesList;
   }
   public void setGrantedAuthoritiesList(Collection<GrantedAuthority> grantedAuthoritiesList) {
      this.grantedAuthoritiesList = grantedAuthoritiesList;
   }
   public String getUsername() {
      return username;
   }
   public void setUsername(String username) {
      this.username = username;
   }
}

अब, निम्न कोड का उपयोग करें और CustomUser वर्ग को परिभाषित करें जो स्प्रिंग बूट प्रमाणीकरण के लिए org.springframework.security.core.userdetails.User वर्ग का विस्तार करता है।

package com.tutorialspoint.websecurityapp;

import org.springframework.security.core.userdetails.User;

public class CustomUser extends User {
   private static final long serialVersionUID = 1L;
   public CustomUser(UserEntity user) {
      super(user.getUsername(), user.getPassword(), user.getGrantedAuthoritiesList());
   }
}

आप डेटाबेस से उपयोगकर्ता जानकारी को पढ़ने और कस्टम उपयोगकर्ता सेवा को भेजने के लिए @Repository वर्ग बना सकते हैं और दी गई प्राधिकारी "ROLE_SYSTEMADMIN" भी जोड़ सकते हैं।

package com.tutorialspoint.websecurityapp;

import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.authority.SimpleGrantedAuthority;
import org.springframework.stereotype.Repository;

@Repository
public class OAuthDao {
   @Autowired
   private JdbcTemplate jdbcTemplate;

   public UserEntity getUserDetails(String username) {
      Collection<GrantedAuthority> grantedAuthoritiesList = new ArrayList<>();
      String userSQLQuery = "SELECT * FROM USERS WHERE USERNAME=?";
      List<UserEntity> list = jdbcTemplate.query(userSQLQuery, new String[] { username },
         (ResultSet rs, int rowNum) -> {
         
         UserEntity user = new UserEntity();
         user.setUsername(username);
         user.setPassword(rs.getString("PASSWORD"));
         return user;
      });
      if (list.size() > 0) {
         GrantedAuthority grantedAuthority = new SimpleGrantedAuthority("ROLE_SYSTEMADMIN");
         grantedAuthoritiesList.add(grantedAuthority);
         list.get(0).setGrantedAuthoritiesList(grantedAuthoritiesList);
         return list.get(0);
      }
      return null;
   }
}

आप कस्टम उपयोगकर्ता विवरण सेवा वर्ग बना सकते हैं, जो डीएओ रिपॉजिटरी वर्ग को दिखाने के लिए org.springframework.security.core.userdetails.UserDetailsService का विस्तार करता है।

package com.tutorialspoint.websecurityapp;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Service;

@Service
public class CustomDetailsService implements UserDetailsService {
   @Autowired
   OAuthDao oauthDao;

   @Override
   public CustomUser loadUserByUsername(final String username) throws UsernameNotFoundException {
      UserEntity userEntity = null;
      try {
         userEntity = oauthDao.getUserDetails(username);
         CustomUser customUser = new CustomUser(userEntity);
         return customUser;
      } catch (Exception e) {
         e.printStackTrace();
         throw new UsernameNotFoundException("User " + username + " was not found in the database");
      }
   }
}

इसके बाद, पासवर्ड एन्कोडर (BCryptPasswordEncoder) को परिभाषित करने और AuthenticationManager बीन को परिभाषित करने के लिए वेब सुरक्षा को सक्षम करने के लिए एक @configuration वर्ग बनाएं। सुरक्षा कॉन्फ़िगरेशन वर्ग को WebSecurityConfigurerAdapter वर्ग का विस्तार करना चाहिए।

package com.tutorialspoint.websecurityapp;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import org.springframework.security.authentication.AuthenticationManager;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.builders.WebSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.config.http.SessionCreationPolicy;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;

@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity(prePostEnabled = true)
public class SecurityConfiguration extends WebSecurityConfigurerAdapter {
   @Autowired
   private CustomDetailsService customDetailsService;

   @Bean
   public PasswordEncoder encoder() {
      return new BCryptPasswordEncoder();
   }
   @Override
   @Autowired
   protected void configure(AuthenticationManagerBuilder auth) throws Exception {
      auth.userDetailsService(customDetailsService).passwordEncoder(encoder());
   }
   @Override
   protected void configure(HttpSecurity http) throws Exception {
      http.authorizeRequests().anyRequest().authenticated().and().sessionManagement()
         .sessionCreationPolicy(SessionCreationPolicy.NEVER);
   }
   @Override
   public void configure(WebSecurity web) throws Exception {
      web.ignoring();
   }
   @Override
   @Bean
   public AuthenticationManager authenticationManagerBean() throws Exception {
      return super.authenticationManagerBean();
   }
}

अब, क्लाइंट आईडी, क्लाइंट सीक्रेट को जोड़ने के लिए OAuth2 कॉन्फ़िगरेशन क्लास को परिभाषित करें, टोकन कुंजीक और सत्यापनकर्ता कुंजी के लिए JwtAccessTokenConverter, निजी कुंजी और सार्वजनिक कुंजी को परिभाषित करें, और स्कॉप्स के साथ टोकन वैधता के लिए ClientDetServiceConfigurer कॉन्फ़िगर करें।

package com.tutorialspoint.websecurityapp;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import org.springframework.security.authentication.AuthenticationManager;
import org.springframework.security.oauth2.config.annotation.configurers.ClientDetailsServiceConfigurer;
import org.springframework.security.oauth2.config.annotation.web.configuration.AuthorizationServerConfigurerAdapter;
import org.springframework.security.oauth2.config.annotation.web.configurers.AuthorizationServerEndpointsConfigurer;
import org.springframework.security.oauth2.config.annotation.web.configurers.AuthorizationServerSecurityConfigurer;
import org.springframework.security.oauth2.provider.token.store.JwtAccessTokenConverter;
import org.springframework.security.oauth2.provider.token.store.JwtTokenStore;

@Configuration
public class OAuth2Config extends AuthorizationServerConfigurerAdapter {
   private String clientid = "tutorialspoint";
   private String clientSecret = "my-secret-key";
   private String privateKey = "private key";
   private String publicKey = "public key";

   @Autowired
   @Qualifier("authenticationManagerBean")
   private AuthenticationManager authenticationManager;
   
   @Bean
   public JwtAccessTokenConverter tokenEnhancer() {
      JwtAccessTokenConverter converter = new JwtAccessTokenConverter();
      converter.setSigningKey(privateKey);
      converter.setVerifierKey(publicKey);
      return converter;
   }
   @Bean
   public JwtTokenStore tokenStore() {
      return new JwtTokenStore(tokenEnhancer());
   }
   @Override
   public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {
      endpoints.authenticationManager(authenticationManager).tokenStore(tokenStore())
      .accessTokenConverter(tokenEnhancer());
   }
   @Override
   public void configure(AuthorizationServerSecurityConfigurer security) throws Exception {
      security.tokenKeyAccess("permitAll()").checkTokenAccess("isAuthenticated()");
   }
   @Override
   public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
      clients.inMemory().withClient(clientid).secret(clientSecret).scopes("read", "write")
         .authorizedGrantTypes("password", "refresh_token").accessTokenValiditySeconds(20000)
         .refreshTokenValiditySeconds(20000);

   }
}

अब, Opensl का उपयोग करके एक निजी कुंजी और सार्वजनिक कुंजी बनाएं।

आप निजी कुंजी बनाने के लिए निम्न आदेशों का उपयोग कर सकते हैं।

openssl genrsa -out jwt.pem 2048
openssl rsa -in jwt.pem

आप उपयोग कर सकते हैं सार्वजनिक कुंजी पीढ़ी के लिए नीचे दिए गए आदेशों का उपयोग करें।

openssl rsa -in jwt.pem -pubout

1.5 रिलीज से अधिक बाद वाले स्प्रिंग बूट के संस्करण के लिए, OAuth2 रिसोर्स फ़िल्टर ऑर्डर को परिभाषित करने के लिए अपने एप्लिकेशन में नीचे की संपत्ति जोड़ें।

security.oauth2.resource.filter-order=3

YAML फ़ाइल उपयोगकर्ता YAML फ़ाइल में नीचे की संपत्ति जोड़ सकते हैं।

security:
   oauth2:
      resource:
         filter-order: 3

अब, classpath संसाधनों के तहत schema.sql और data.sql फ़ाइल बनाएँ src/main/resources/directory H2 डेटाबेस के लिए आवेदन कनेक्ट करने के लिए।

स्कीमा। एसक्यूएल फ़ाइल निम्नानुसार है -

CREATE TABLE USERS (ID INT PRIMARY KEY, USERNAME VARCHAR(45), PASSWORD VARCHAR(60));

Data.sql फ़ाइल निम्नानुसार है -

INSERT INTO USERS (ID, USERNAME,PASSWORD) VALUES (
   1, '[email protected]','$2a$08$fL7u5xcvsZl78su29x1ti.dxI.9rYO8t0q5wk2ROJ.1cdR53bmaVG'); INSERT INTO USERS (ID, USERNAME,PASSWORD) VALUES ( 2, '[email protected]','$2a$08$fL7u5xcvsZl78su29x1ti.dxI.9rYO8t0q5wk2ROJ.1cdR53bmaVG');

Note - पासवर्ड डेटाबेस तालिका में Bcrypt एनकोडर के प्रारूप में संग्रहीत किया जाना चाहिए।

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

मावेन के लिए, आप नीचे दिए गए कमांड का उपयोग कर सकते हैं -

mvn clean install

"निर्माण सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप कमांड को दिखाए अनुसार उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, यहाँ दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

आवेदन टॉमकैट पोर्ट 8080 पर शुरू किया गया है।

अब OAUTH2 टोकन प्राप्त करने के लिए POSTMAN के माध्यम से POST विधि URL को हिट करें।

http://localhost:8080/oauth/token

अब, अनुरोध हेडर को इस प्रकार जोड़ें -

  • Authorization - अपने क्लाइंट आईडी और ग्राहक रहस्य के साथ मूल प्रामाणिक।

  • Content Type - आवेदन / x-www-form-urlencoded

अब, अनुरोध पैरामीटर्स को इस प्रकार जोड़ें -

  • अनुदान_प्रकार = पासवर्ड
  • उपयोगकर्ता नाम = आपका उपयोगकर्ता नाम
  • पासवर्ड = आपका पासवर्ड

अब, एपीआई को हिट करें और दिखाए गए अनुसार access_token प्राप्त करें -

अब, रिक्वेस्ट हेडर में बियरर एक्सेस टोकन के साथ रिसोर्स सर्वर एपीआई को दिखाए गए अनुसार हिट करें।

फिर आप नीचे दिखाए अनुसार आउटपुट देख सकते हैं -

Google क्लाउड प्लेटफ़ॉर्म क्लाउड कंप्यूटिंग सेवाएँ प्रदान करता है जो क्लाउड वातावरण में स्प्रिंग बूट एप्लिकेशन चलाती हैं। इस अध्याय में, हम यह देखने जा रहे हैं कि जीसीपी ऐप इंजन प्लेटफॉर्म में स्प्रिंग बूट एप्लिकेशन को कैसे तैनात किया जाए।

सबसे पहले, ग्रैडल को स्प्रिंग इनिशिएटिव पेज www.start.spring.io से स्प्रिंग बूट एप्लिकेशन डाउनलोड करें । निम्नलिखित स्क्रीनशॉट को देखें।

अब, build.gradle फ़ाइल में, Google क्लाउड एपेंगीइन प्लगइन और एपेंगाइन क्लासपाथ निर्भरता जोड़ें।

Build.gradle फ़ाइल का कोड नीचे दिया गया है -

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
      classpath 'com.google.cloud.tools:appengine-gradle-plugin:1.3.3'
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'
apply plugin: 'com.google.cloud.tools.appengine'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

अब, एक साधारण HTTP एंडपॉइंट लिखें और यह स्ट्रिंग की सफलता को दिखाए गए अनुसार दिखाया गया है -

package com.tutorialspoint.appenginedemo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class AppengineDemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(AppengineDemoApplication.class, args);
   }
   @RequestMapping(value = "/")
   public String success() {
      return "APP Engine deployment success";
   }
}

अगला, src / main / appengine निर्देशिका के तहत app.yml फ़ाइल को दिखाए अनुसार जोड़ें -

runtime: java
env: flex

handlers:
- url: /.*
   script: this field is required, but ignored

अब, Google क्लाउड कंसोल पर जाएं और पृष्ठ के शीर्ष पर सक्रिय Google क्लाउड शेल पर क्लिक करें।

अब, Google क्लाउड शेल का उपयोग करके अपनी स्रोत फ़ाइलों और ग्रेड फ़ाइल को अपनी Google क्लाउड मशीन की होम निर्देशिका में ले जाएं।

अब, कमांड ग्रेड एपेंग्नेपडॉयल निष्पादित करें और यह आपके एप्लिकेशन को Google क्लाउड एपेंगाइन में तैनात करेगा।

Note - जीसीपी को बिलिंग सक्षम होना चाहिए और अपने आवेदन को एपेंग्नेइन में तैनात करने से पहले, आपको जीसीपी में एपेंगाइन प्लेटफॉर्म बनाना चाहिए।

आपके आवेदन को GCP एपेंजी प्लेटफॉर्म पर तैनात करने में कुछ मिनट लगेंगे।

सफल बनाने के बाद आप कंसोल विंडो में सर्विस यूआरएल देख सकते हैं।

अब, सेवा URL को हिट करें और आउटपुट देखें।

Google क्लाउड एसक्यूएल

Google क्लाउड एसक्यूएल को अपने स्प्रिंग बूट एप्लिकेशन में जोड़ने के लिए, आपको अपने एप्लिकेशन में निम्नलिखित गुण जोड़ना चाहिए।

JDBC URL प्रारूप

jdbc:mysql://google/<DATABASE-NAME>?cloudSqlInstance = <GOOGLE_CLOUD_SQL_INSTANCE_NAME> &socketFactory = com.google.cloud.sql.mysql.SocketFactory&user = <USERNAME>&password = <PASSWORD>

Note - स्प्रिंग बूट एप्लिकेशन और Google क्लाउड SQL एक ही GCP प्रोजेक्ट में होने चाहिए।

Application.properties फ़ाइल नीचे दी गई है।

spring.dbProductService.driverClassName = com.mysql.jdbc.Driver
spring.dbProductService.url = jdbc:mysql://google/PRODUCTSERVICE?cloudSqlInstance = springboot-gcp-cloudsql:asia-northeast1:springboot-gcp-cloudsql-instance&socketFactory = com.google.cloud.sql.mysql.SocketFactory&user = root&password = rootspring.dbProductService.username = root

spring.dbProductService.password = root
spring.dbProductService.testOnBorrow = true
spring.dbProductService.testWhileIdle = true
spring.dbProductService.timeBetweenEvictionRunsMillis = 60000
spring.dbProductService.minEvictableIdleTimeMillis = 30000
spring.dbProductService.validationQuery = SELECT 1
spring.dbProductService.max-active = 15
spring.dbProductService.max-idle = 10
spring.dbProductService.max-wait = 8000

YAML फ़ाइल उपयोगकर्ता आपके Application.yml फ़ाइल में नीचे गुण जोड़ सकते हैं।

spring:
   datasource: 
      driverClassName: com.mysql.jdbc.Driver
      url: "jdbc:mysql://google/PRODUCTSERVICE?cloudSqlInstance=springboot-gcp-cloudsql:asia-northeast1:springboot-gcp-cloudsql-instance&socketFactory=com.google.cloud.sql.mysql.SocketFactory&user=root&password=root"
      password: "root"
      username: "root"
      testOnBorrow: true
      testWhileIdle: true
      validationQuery: SELECT 1
      
      max-active: 15
      max-idle: 10
      max-wait: 8000

इस अध्याय में, हम ग्रैड बिल्ड के साथ स्प्रिंग बूट एप्लिकेशन का उपयोग करके Google OAuth2 साइन-इन जोड़ने का तरीका देखने जा रहे हैं।

सबसे पहले, अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट OAuth2 सुरक्षा निर्भरता जोड़ें और आपकी बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint.projects'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter')
   testCompile('org.springframework.boot:spring-boot-starter-test')
   compile('org.springframework.security.oauth:spring-security-oauth2')
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

अब, नीचे दिए गए मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल में स्प्रिंग बूट के माध्यम से प्रमाणित करने के बाद Google से उपयोगकर्ता प्रिंसिपल को पढ़ने के लिए HTTP समापन बिंदु जोड़ें।

package com.tutorialspoint.projects.googleservice;

import java.security.Principal;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class GoogleserviceApplication {
   public static void main(String[] args) {
      SpringApplication.run(GoogleserviceApplication.class, args);
   }
   @RequestMapping(value = "/user")
   public Principal user(Principal principal) {
      return principal;
   }
}

अब, वेब सुरक्षा के लिए OAuth2SSO को सक्षम करने के लिए एक कॉन्फ़िगरेशन फ़ाइल लिखें और index.html फ़ाइल के लिए प्रमाणीकरण को हटा दें जैसा कि दिखाया गया है -

package com.tutorialspoint.projects.googleservice;

import org.springframework.boot.autoconfigure.security.oauth2.client.EnableOAuth2Sso;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;

@Configuration
@EnableOAuth2Sso
public class WebSecurityConfiguration extends WebSecurityConfigurerAdapter {
   @Override
   protected void configure(HttpSecurity http) throws Exception {
      http
         .csrf()
         .disable()
         .antMatcher("/**")
         .authorizeRequests()
         .antMatchers("/", "/index.html")
         .permitAll()
         .anyRequest()
         .authenticated();
   }
}

इसके बाद, स्थिर संसाधनों के तहत index.html फ़ाइल जोड़ें और नीचे दिखाए गए Google उपयोगकर्ता प्रिंसिपल को पढ़ने के लिए उपयोगकर्ता HTTP Endpoint में रीडायरेक्ट करने के लिए लिंक जोड़ें -

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "ISO-8859-1">
      <title>Insert title here</title>
   </head>
   <body>
      <a href = "user">Click here to Google Login</a>
   </body>
</html>

Note - Google क्लाउड कंसोल में - Gmail सेवाओं, Analytics सेवाओं और Google+ सेवा API (एस) को सक्षम करें।

फिर, क्रेडेंशियल अनुभाग पर जाएं और क्रेडेंशियल्स बनाएं और OAuth क्लाइंट आईडी चुनें।

अगला, OAuth2 सहमति स्क्रीन में एक उत्पाद का नाम प्रदान करें।

अगला, "वेब एप्लिकेशन" के रूप में एप्लिकेशन प्रकार चुनें, अधिकृत जावास्क्रिप्ट उत्पत्ति और अधिकृत पुनर्निर्देशित यूआरआई प्रदान करें।

अब, आपका OAuth2 क्लाइंट आईडी और क्लाइंट सीक्रेट बनाया गया है।

इसके बाद, अपनी एप्लिकेशन प्रॉपर्टी फ़ाइल में क्लाइंट आईडी और क्लाइंट सीक्रेट जोड़ें।

security.oauth2.client.clientId = <CLIENT_ID>
security.oauth2.client.clientSecret = <CLIENT_SECRET>
security.oauth2.client.accessTokenUri  =  https://www.googleapis.com/oauth2/v3/token
security.oauth2.client.userAuthorizationUri  =  https://accounts.google.com/o/oauth2/auth
security.oauth2.client.tokenName = oauth_token
security.oauth2.client.authenticationScheme = query
security.oauth2.client.clientAuthenticationScheme = form
security.oauth2.client.scope = profile email

security.oauth2.resource.userInfoUri  =  https://www.googleapis.com/userinfo/v2/me
security.oauth2.resource.preferTokenInfo = false

अब, आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न ग्रेड कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

ग्रेडल के लिए, आप कमांड को दिखाए अनुसार उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फ़ाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

कमांड java-JARFILE> का उपयोग करके JAR फ़ाइल चलाएँ और Tomcat पोर्ट 8080 पर एप्लिकेशन शुरू हो गया है।

अब URL को हिट करें http://localhost:8080/ और Google लॉगिन लिंक पर क्लिक करें।

यह Google लॉगिन स्क्रीन पर रीडायरेक्ट करेगा और जीमेल लॉगिन विवरण प्रदान करेगा।

यदि लॉगिन सफलता मिलती है, तो हमें जीमेल उपयोगकर्ता की प्रमुख वस्तु प्राप्त होगी।