उपभोक्ता वेब सेवाएँ
यह अध्याय 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 पर आवेदन शुरू हो गया है।
अब अपने वेब ब्राउजर में यूआरएल को हिट करें और आप आउटपुट को देख सकते हैं -
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 प्रारूप में अनुरोध निकाय का प्रतिनिधित्व करता है।