स्प्रिंग बूट - भवनपूर्ण वेब सेवाएँ

स्प्रिंग बूट एंटरप्राइज़ अनुप्रयोगों के लिए 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, और यह उत्पाद को हैशपॉप रिपॉजिटरी में स्टोर करने के बाद स्ट्रिंग लौटा देगा।

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 फ़ाइल बना सकते हैं, और नीचे दिए गए Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

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

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