MEAN.JS - बाकी एपीआई

इस अध्याय में, हम अपने एप्लिकेशन को HTTP तरीकों का उपयोग करके हमारे डेटाबेस के साथ REST API के माध्यम से इंटरैक्ट करते हुए देखेंगे। REST शब्द का अर्थ रीकंस्ट्रक्शन स्टेट ट्रांसफर है, जो एक वास्तुशिल्प शैली है जिसे वेब सेवाओं के साथ संवाद करने के लिए डिज़ाइन किया गया है और एपीआई एप्लीकेशन प्रोग्राम इंटरफ़ेस के लिए है जो एक दूसरे के साथ अनुप्रयोगों को इंटरैक्ट करने की अनुमति देता है।

सबसे पहले, हम सभी आइटम प्राप्त करने, आइटम बनाने और एक आइटम को हटाने के लिए RESTful API बनाएंगे। प्रत्येक आइटम के लिए, _ MongoDB द्वारा स्वचालित रूप से जेनरेट किया जाएगा। नीचे दी गई तालिका में बताया गया है कि कैसे एप्लिकेशन को एपीआई से डेटा का अनुरोध करना चाहिए -

HTTP विधि URL पथ विवरण
प्राप्त

/api/students

इसका उपयोग सभी छात्रों को संग्रह छात्र से प्राप्त करने के लिए किया जाता है।
पद

/api/students/send

इसका उपयोग स्टूडेंट कलेक्शन में स्टूडेंट रिकॉर्ड बनाने के लिए किया जाता है।
हटाएँ

/api/students/student_id

इसका उपयोग संग्रह छात्र से एक छात्र रिकॉर्ड को हटाने के लिए किया जाता है।

रेस्टफुल एपीआई रूट्स

हम सबसे पहले Restful API Routes में Post Method पर चर्चा करेंगे।

पद

पहले हमारे REST API के माध्यम से स्टूडेंट के कलेक्शन में एक रिकॉर्ड बनाते हैं। इस विशेष मामले का कोड server.js फ़ाइल में पाया जा सकता है । संदर्भ के लिए, कोड का एक हिस्सा यहां चिपकाया गया है -

app.post('/api/students/send', function (req, res) {
   var student = new Student(); // create a new instance of the student model
   student.name = req.body.name; // set the student name (comes from the request)
   student.save(function(err) {
      if (err)
         res.send(err);
         res.json({ message: 'student created!' });
   });
});

क्रियान्वयन

आप इस लिंक में इस एप्लिकेशन के लिए स्रोत कोड डाउनलोड कर सकते हैं । ज़िप फ़ाइल डाउनलोड करें; इसे अपने सिस्टम में निकालें। टर्मिनल खोलें और npm मॉड्यूल निर्भरता स्थापित करने के लिए नीचे कमांड चलाएं।

$ cd mean-demon-consuming_rest_api
$ npm install

अनुरोध को पार्स करने के लिए, हमें बॉडी पार्सर पैकेज की आवश्यकता होगी। इसलिए, अपने आवेदन में शामिल करने के लिए नीचे दिए गए आदेश को चलाएं।

npm install --save body-parser

संलग्न स्रोत कोड में पहले से ही यह निर्भरता है, इसलिए उपरोक्त कमांड को चलाने की कोई आवश्यकता नहीं है, यह सिर्फ आपकी जानकारी के लिए है।

एप्लिकेशन को चलाने के लिए, अपने नए बनाए गए प्रोजेक्ट डायरेक्टरी में नेविगेट करें और नीचे दिए गए कमांड के साथ दौड़ें -

npm start

जैसा कि नीचे दी गई छवि में दिखाया गया है, आपको एक पुष्टि मिलेगी -

एपीआई कॉल का परीक्षण करने के लिए कई उपकरण हैं, यहां हम पोस्टमैन रीस्ट क्लाइंट नामक क्रोम के लिए उपयोगकर्ता के अनुकूल एक्सटेंशन में से एक का उपयोग कर रहे हैं ।

Postman REST क्लाइंट खोलें, URL को इस रूप में दर्ज करें http://localhost:3000/api/students/send, पोस्ट विधि का चयन करें । अगला, अनुरोध डेटा दर्ज करें जैसा कि नीचे दिखाया गया है -

ध्यान दें कि हम नाम डेटा को x-www-form-urlencoded के रूप में भेज रहे हैं । यह हमारे सभी डेटा को क्वेरी स्ट्रिंग के रूप में नोड सर्वर को भेज देगा।

छात्र रिकॉर्ड बनाने के लिए भेजें बटन पर क्लिक करें । एक सफलता संदेश नीचे दिखाए गए अनुसार दिखाई देगा -

प्राप्त

इसके बाद, मूंगोडब से सभी छात्र रिकॉर्ड प्राप्त करते हैं। निम्नलिखित मार्ग को लिखने की आवश्यकता है। आप server.js फ़ाइल में पूर्ण कोड पा सकते हैं ।

app.get('/api/students', function(req, res) {
   // use mongoose to get all students in the database
   Student.find(function(err, students) {
      // if there is an error retrieving, send the error.
      // nothing after res.send(err) will execute
      if (err)
         res.send(err);
      res.json(students); // return all students in JSON format
   });
});

इसके बाद, Postman REST क्लाइंट खोलें, URL को इस रूप में दर्ज करें

http://localhost:3000/api/students, GET विधि का चयन करें और सभी छात्रों को प्राप्त करने के लिए भेजें बटन पर क्लिक करें।

हटाएँ

इसके बाद, देखते हैं कि REST एपि कॉल के माध्यम से हमारे मोंगो कलेक्शन से एक रिकॉर्ड कैसे हटाएं।

निम्नलिखित मार्ग को लिखने की आवश्यकता है। आप server.js फ़ाइल में पूर्ण कोड पा सकते हैं ।

app.delete('/api/students/:student_id', function (req, res) {
   Student.remove({
      _id: req.params.student_id
   }, function(err, bear) {
      if (err)
         res.send(err);
      res.json({ message: 'Successfully deleted' });
   });
});

इसके बाद, Postman REST क्लाइंट खोलें, URL को इस रूप में दर्ज करें

http://localhost:3000/api/students/5d1492fa74f1771faa61146d

(यहां 5d1492fa74f1771faa61146d रिकॉर्ड है जिसे हम संग्रह छात्र से हटा देंगे)।

DELETE पद्धति का चयन करें और सभी छात्रों को प्राप्त करने के लिए भेजें बटन पर क्लिक करें ।

आप हटाए गए डेटा के लिए MongoDB चेक कर सकते हैं, GET कॉल करने के लिए http://localhost:3000/api/students/5d1492fa74f1771faa61146d