स्प्रिंग बूट - इंटरसेप्टर

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

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

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

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

इंटरसेप्टर के साथ काम करने के लिए, आपको बनाने की आवश्यकता है @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>

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

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

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

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