एक्सप्रेसजेएस - रेस्टफुल एपीआई
मोबाइल एप्लिकेशन, सिंगल पेज एप्लिकेशन, AJAX कॉल का उपयोग करने और ग्राहकों को डेटा प्रदान करने के लिए एक एपीआई की हमेशा आवश्यकता होती है। इन APIs और समापन बिंदुओं की संरचना और नाम कैसे करें की एक लोकप्रिय स्थापत्य शैली कहा जाता हैREST(Representational Transfer State)। HTTP 1.1REST सिद्धांतों को ध्यान में रखते हुए डिजाइन किया गया था। द्वारा शुरू किया गया थाRoy Fielding 2000 में अपने पेपर फील्डिंग शोध प्रबंध में।
RESTful URI और विधियाँ हमें लगभग सभी जानकारी प्रदान करती हैं जिन्हें हमें अनुरोध करने की आवश्यकता होती है। नीचे दी गई तालिका संक्षेप में बताती है कि विभिन्न क्रियाओं का उपयोग कैसे किया जाना चाहिए और यूआरआई का नाम कैसे होना चाहिए। हम अंत में एक मूवी एपीआई बना रहे हैं; आइए अब चर्चा करते हैं कि यह कैसे संरचित होगा।
तरीका | यूआरआई | विवरण | समारोह |
---|---|---|---|
प्राप्त | /चलचित्र | सुरक्षित, कछुआ | सभी फिल्मों की सूची और उनका विवरण प्राप्त करता है |
प्राप्त | / फिल्मों / 1234 | सुरक्षित, कछुआ | मूवी आईडी 1234 का विवरण मिलता है |
पद | /चलचित्र | एन / ए | प्रदान की गई जानकारी के साथ एक नई फिल्म बनाता है। प्रतिक्रिया में इस नए बनाए गए संसाधन के लिए URI शामिल है। |
डाल | / फिल्मों / 1234 | idempotent | मूवी आईडी 1234 को संशोधित करता है (यदि यह पहले से मौजूद नहीं है तो एक बनाता है)। प्रतिक्रिया में इस नए बनाए गए संसाधन के लिए URI शामिल है। |
हटाएँ | / फिल्मों / 1234 | idempotent | मूवी आईडी 1234 को हटा दिया जाना चाहिए, अगर यह मौजूद है। प्रतिक्रिया में अनुरोध की स्थिति होनी चाहिए। |
DELETE या PUT | /चलचित्र | अमान्य | अमान्य होना चाहिए। DELETE तथा PUT निर्दिष्ट करना चाहिए कि वे किस संसाधन पर काम कर रहे हैं। |
अब एक्सप्रेस में इस एपीआई को बनाते हैं। हम JSON का उपयोग हमारे परिवहन डेटा प्रारूप के रूप में करेंगे क्योंकि यह जावास्क्रिप्ट में काम करना आसान है और इसके अन्य लाभ हैं। अपने को बदलेंindex.js के साथ फाइल करें movies.js निम्नलिखित कार्यक्रम के रूप में फ़ाइल।
index.js
var express = require('express');
var bodyParser = require('body-parser');
var multer = require('multer');
var upload = multer();
var app = express();
app.use(cookieParser());
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(upload.array());
//Require the Router we defined in movies.js
var movies = require('./movies.js');
//Use the Router on the sub route /movies
app.use('/movies', movies);
app.listen(3000);
अब हमारे पास अपना एप्लिकेशन सेट अप हो गया है, आइए हम एपीआई बनाने पर ध्यान केंद्रित करें।
Movies.js फ़ाइल सेट करके प्रारंभ करें। हम फिल्मों को संग्रहीत करने के लिए डेटाबेस का उपयोग नहीं कर रहे हैं, लेकिन उन्हें मेमोरी में स्टोर कर रहे हैं; इसलिए हर बार सर्वर के पुनरारंभ होने पर, हमारे द्वारा जोड़ी गई फिल्में गायब हो जाएंगी। यह आसानी से डेटाबेस या फ़ाइल (नोड एफएस मॉड्यूल का उपयोग करके) का उपयोग करके नकल की जा सकती है।
एक बार जब आप एक्सप्रेस आयात करते हैं, तो एक राउटर बनाएं और मॉड्यूल.एक्सपोर्ट का उपयोग करके इसे निर्यात करें -
var express = require('express');
var router = express.Router();
var movies = [
{id: 101, name: "Fight Club", year: 1999, rating: 8.1},
{id: 102, name: "Inception", year: 2010, rating: 8.7},
{id: 103, name: "The Dark Knight", year: 2008, rating: 9},
{id: 104, name: "12 Angry Men", year: 1957, rating: 8.9}
];
//Routes will go here
module.exports = router;
मार्ग मिलते हैं
आइए हम सभी फिल्मों को प्राप्त करने के लिए GET मार्ग को परिभाषित करते हैं -
router.get('/', function(req, res){
res.json(movies);
});
यह जांचने के लिए कि क्या यह ठीक काम कर रहा है, अपना ऐप चलाएं, फिर अपना टर्मिनल खोलें और दर्ज करें -
curl -i -H "Accept: application/json" -H "Content-Type: application/json" -X GET
localhost:3000/movies
निम्नलिखित प्रतिक्रिया प्रदर्शित की जाएगी -
[{"id":101,"name":"Fight Club","year":1999,"rating":8.1},
{"id":102,"name":"Inception","year":2010,"rating":8.7},
{"id":103,"name":"The Dark Knight","year":2008,"rating":9},
{"id":104,"name":"12 Angry Men","year":1957,"rating":8.9}]
हमारे पास सभी फिल्मों को पाने के लिए एक रास्ता है। आइए अब हम एक विशिष्ट फिल्म बनाने के लिए एक मार्ग बनाते हैं।
router.get('/:id([0-9]{3,})', function(req, res){
var currMovie = movies.filter(function(movie){
if(movie.id == req.params.id){
return true;
}
});
if(currMovie.length == 1){
res.json(currMovie[0])
} else {
res.status(404);//Set status to 404 as movie was not found
res.json({message: "Not Found"});
}
});
यह हमारे द्वारा प्रदान की गई आईडी के अनुसार हमें फ़िल्में देगा। आउटपुट की जाँच करने के लिए, अपने टर्मिनल में निम्न कमांड का उपयोग करें -
curl -i -H "Accept: application/json" -H "Content-Type: application/json" -X GET
localhost:3000/movies/101
आपको निम्न प्रतिक्रिया मिलेगी -
{"id":101,"name":"Fight Club","year":1999,"rating":8.1}
यदि आप एक अमान्य मार्ग पर जाते हैं, तो यह उत्पादन करेगा cannot GET error यदि आप किसी ऐसे आईडी वाले वैध मार्ग पर जाते हैं जो मौजूद नहीं है, तो यह 404 त्रुटि उत्पन्न करेगा।
हमें GET मार्गों के साथ किया जाता है, आइए अब हम आगे बढ़ते हैं POST मार्ग।
पोस्ट मार्ग
संभाल करने के लिए निम्न मार्ग का उपयोग करें POSTed डेटा -
router.post('/', function(req, res){
//Check if all fields are provided and are valid:
if(!req.body.name ||
!req.body.year.toString().match(/^[0-9]{4}$/g) ||
!req.body.rating.toString().match(/^[0-9]\.[0-9]$/g)){
res.status(400);
res.json({message: "Bad Request"});
} else {
var newId = movies[movies.length-1].id+1;
movies.push({
id: newId,
name: req.body.name,
year: req.body.year,
rating: req.body.rating
});
res.json({message: "New movie created.", location: "/movies/" + newId});
}
});
यह एक नई फिल्म बनाएगा और इसे मूवी चर में संग्रहीत करेगा। इस मार्ग की जाँच करने के लिए, अपने टर्मिनल में निम्नलिखित कोड दर्ज करें -
curl -X POST --data "name = Toy%20story&year = 1995&rating = 8.5" http://localhost:3000/movies
निम्नलिखित प्रतिक्रिया प्रदर्शित की जाएगी -
{"message":"New movie created.","location":"/movies/105"}
यह जाँचने के लिए कि क्या यह फ़िल्म ऑब्जेक्ट में जोड़ा गया है, के लिए अनुरोध प्राप्त करें चलाएँ /movies/105फिर। निम्नलिखित प्रतिक्रिया प्रदर्शित की जाएगी -
{"id":105,"name":"Toy story","year":"1995","rating":"8.5"}
हमें PUT और DELETE रूट बनाने के लिए आगे बढ़ना है।
मार्ग मार्ग
PUT मार्ग लगभग POST मार्ग के समान है। हम उस वस्तु के लिए आईडी निर्दिष्ट करेंगे जो अपडेट / बनाई जाएगी। निम्नलिखित तरीके से मार्ग बनाएँ।
router.put('/:id', function(req, res){
//Check if all fields are provided and are valid:
if(!req.body.name ||
!req.body.year.toString().match(/^[0-9]{4}$/g) ||
!req.body.rating.toString().match(/^[0-9]\.[0-9]$/g) ||
!req.params.id.toString().match(/^[0-9]{3,}$/g)){
res.status(400);
res.json({message: "Bad Request"});
} else {
//Gets us the index of movie with given id.
var updateIndex = movies.map(function(movie){
return movie.id;
}).indexOf(parseInt(req.params.id));
if(updateIndex === -1){
//Movie not found, create new
movies.push({
id: req.params.id,
name: req.body.name,
year: req.body.year,
rating: req.body.rating
});
res.json({message: "New movie created.", location: "/movies/" + req.params.id});
} else {
//Update existing movie
movies[updateIndex] = {
id: req.params.id,
name: req.body.name,
year: req.body.year,
rating: req.body.rating
};
res.json({message: "Movie id " + req.params.id + " updated.",
location: "/movies/" + req.params.id});
}
}
});
यह मार्ग उपरोक्त तालिका में निर्दिष्ट कार्य करेगा। यह मौजूद होने पर नए विवरण के साथ ऑब्जेक्ट को अपडेट करेगा। यदि यह मौजूद नहीं है, तो यह एक नई वस्तु बनाएगा। मार्ग की जांच करने के लिए, निम्नलिखित कर्ल कमांड का उपयोग करें। यह एक मौजूदा फिल्म को अपडेट करेगा। एक नई मूवी बनाने के लिए, बस आईडी को गैर-मौजूदा आईडी में बदलें।
curl -X PUT --data "name = Toy%20story&year = 1995&rating = 8.5"
http://localhost:3000/movies/101
Response
{"message":"Movie id 101 updated.","location":"/movies/101"}
DELETE मार्ग
डिलीट रूट बनाने के लिए निम्न कोड का उपयोग करें। -
router.delete('/:id', function(req, res){
var removeIndex = movies.map(function(movie){
return movie.id;
}).indexOf(req.params.id); //Gets us the index of movie with given id.
if(removeIndex === -1){
res.json({message: "Not found"});
} else {
movies.splice(removeIndex, 1);
res.send({message: "Movie id " + req.params.id + " removed."});
}
});
मार्ग की उसी तरह से जाँच करें जैसे हमने अन्य मार्गों की जाँच की। सफल विलोपन पर (उदाहरण के लिए आईडी 105), आपको निम्न आउटपुट मिलेगा -
{message: "Movie id 105 removed."}
अंत में, हमारे movies.js फ़ाइल निम्न की तरह दिखाई देगी।
var express = require('express');
var router = express.Router();
var movies = [
{id: 101, name: "Fight Club", year: 1999, rating: 8.1},
{id: 102, name: "Inception", year: 2010, rating: 8.7},
{id: 103, name: "The Dark Knight", year: 2008, rating: 9},
{id: 104, name: "12 Angry Men", year: 1957, rating: 8.9}
];
router.get('/:id([0-9]{3,})', function(req, res){
var currMovie = movies.filter(function(movie){
if(movie.id == req.params.id){
return true;
}
});
if(currMovie.length == 1){
res.json(currMovie[0])
} else {
res.status(404); //Set status to 404 as movie was not found
res.json({message: "Not Found"});
}
});
router.post('/', function(req, res){
//Check if all fields are provided and are valid:
if(!req.body.name ||
!req.body.year.toString().match(/^[0-9]{4}$/g) ||
!req.body.rating.toString().match(/^[0-9]\.[0-9]$/g)){
res.status(400);
res.json({message: "Bad Request"});
} else {
var newId = movies[movies.length-1].id+1;
movies.push({
id: newId,
name: req.body.name,
year: req.body.year,
rating: req.body.rating
});
res.json({message: "New movie created.", location: "/movies/" + newId});
}
});
router.put('/:id', function(req, res) {
//Check if all fields are provided and are valid:
if(!req.body.name ||
!req.body.year.toString().match(/^[0-9]{4}$/g) ||
!req.body.rating.toString().match(/^[0-9]\.[0-9]$/g) ||
!req.params.id.toString().match(/^[0-9]{3,}$/g)){
res.status(400);
res.json({message: "Bad Request"});
} else {
//Gets us the index of movie with given id.
var updateIndex = movies.map(function(movie){
return movie.id;
}).indexOf(parseInt(req.params.id));
if(updateIndex === -1){
//Movie not found, create new
movies.push({
id: req.params.id,
name: req.body.name,
year: req.body.year,
rating: req.body.rating
});
res.json({
message: "New movie created.", location: "/movies/" + req.params.id});
} else {
//Update existing movie
movies[updateIndex] = {
id: req.params.id,
name: req.body.name,
year: req.body.year,
rating: req.body.rating
};
res.json({message: "Movie id " + req.params.id + " updated.",
location: "/movies/" + req.params.id});
}
}
});
router.delete('/:id', function(req, res){
var removeIndex = movies.map(function(movie){
return movie.id;
}).indexOf(req.params.id); //Gets us the index of movie with given id.
if(removeIndex === -1){
res.json({message: "Not found"});
} else {
movies.splice(removeIndex, 1);
res.send({message: "Movie id " + req.params.id + " removed."});
}
});
module.exports = router;
यह हमारे REST API को पूरा करता है। अब आप इस सरल वास्तुकला शैली और एक्सप्रेस का उपयोग करके बहुत अधिक जटिल एप्लिकेशन बना सकते हैं।