स्प्रिंग बूट - स्वैगर 2 को सक्षम करना
स्वैगर 2 एक ओपन सोर्स प्रोजेक्ट है, जिसका इस्तेमाल रेस्टफुल वेब सेवाओं के लिए REST API डॉक्यूमेंट तैयार करने के लिए किया जाता है। यह वेब ब्राउज़र के माध्यम से हमारी Restful वेब सेवाओं तक पहुंचने के लिए एक उपयोगकर्ता इंटरफ़ेस प्रदान करता है।
स्प्रिंग बूट एप्लिकेशन में स्वैगर 2 को सक्षम करने के लिए, आपको हमारी बिल्ड कॉन्फ़िगरेशन फ़ाइल में निम्न निर्भरताएं जोड़ने की आवश्यकता है।
<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>
ग्रेडल उपयोगकर्ताओं के लिए, अपनी build.gradle फ़ाइल में निम्न निर्भरताएँ जोड़ें।
compile group: 'io.springfox', name: 'springfox-swagger2', version: '2.7.0'
compile group: 'io.springfox', name: 'springfox-swagger-ui', version: '2.7.0'
अब, अपने मुख्य स्प्रिंग बूट एप्लिकेशन में @ EnableSwagger2 एनोटेशन जोड़ें। आपके स्प्रिंग बूट एप्लिकेशन के लिए Swagger2 को सक्षम करने के लिए @ EnableSwagger2 एनोटेशन का उपयोग किया जाता है।
मुख्य स्प्रिंग बूट एप्लिकेशन का कोड नीचे दिखाया गया है -
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);
}
}
इसके बाद, अपने स्प्रिंग बूट एप्लिकेशन के लिए Swagger2 को कॉन्फ़िगर करने के लिए Docket Bean बनाएं। हमें Swagger2 के लिए REST API (s) को कॉन्फ़िगर करने के लिए आधार पैकेज को परिभाषित करने की आवश्यकता है।
@Bean
public Docket productApi() {
return new Docket(DocumentationType.SWAGGER_2).select()
.apis(RequestHandlerSelectors.basePackage("com.tutorialspoint.swaggerdemo")).build();
}
अब, इस बीन को मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ाइल में जोड़ें और आपका मुख्य स्प्रिंग बूट एप्लीकेशन क्लास नीचे दिखाया गया है -
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();
}
}
अब, नीचे दिए गए अनुसार स्प्रिंग बूट स्टार्टर वेब निर्भरता को अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में जोड़ने के लिए एक REST समापन बिंदु लिखें।
Maven उपयोगकर्ता आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -
compile('org.springframework.boot:spring-boot-starter-web')
अब, रेस्ट कंट्रोलर फाइल में GET और POST के दो सरल वेब सेवाएं बनाने का कोड यहाँ दिखाया गया है -
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";
}
}
पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है -
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'
}
आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।
मावेन के लिए, आप यहाँ दिखाए गए कमांड का उपयोग कर सकते हैं -
mvn clean install
"बिल्ड सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।
ग्रेडल के लिए, आप कमांड को यहाँ दिखाए अनुसार उपयोग कर सकते हैं -
gradle clean build
“BUILD SUCCESSFUL” के बाद, आप JAR फाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।
अब, यहाँ दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -
java –jar <JARFILE>
अब, आवेदन Tomcat पोर्ट 8080 पर शुरू होगा जैसा कि दिखाया गया है -
अब, अपने वेब ब्राउज़र में URL को हिट करें और स्वैगर एपीआई फ़ंक्शंस देखें।
http://localhost:8080/swagger-ui.html