Ko.js - त्वरित गाइड

एक वेब एप्लिकेशन फ्रेमवर्क आपको वेबसाइटों, वेब ऐप्स और बैकएंड के निर्माण के लिए एक साधारण एपीआई प्रदान करता है। आपको निम्न स्तर के प्रोटोकॉल, प्रक्रियाओं आदि के बारे में चिंता करने की आवश्यकता नहीं है।

कोया क्या है?

Koa अनुप्रयोगों के निर्माण के लिए एक न्यूनतम इंटरफ़ेस प्रदान करता है। यह एक बहुत छोटा ढांचा (600 एलओसी) है जो ऐप्स बनाने के लिए आवश्यक उपकरण प्रदान करता है और काफी लचीला है। Koa के लिए npm पर कई मॉड्यूल उपलब्ध हैं, जिन्हें सीधे इसमें प्लग किया जा सकता है। कोए को सभी घंटियों और सीटियों के बिना व्यक्त किया जा सकता है।

क्यों कोया?

कोआ में एक छोटा पदचिह्न (600 एलओसी) है और सर्वर साइड ऐप बनाने के लिए नोड पर अमूर्तता की एक बहुत पतली परत है। यह पूरी तरह से प्लग करने योग्य है और इसमें एक विशाल समुदाय है। यह हमें आसानी से कोआ का विस्तार करने और हमारी आवश्यकताओं के अनुसार उपयोग करने की अनुमति देता है। इसे ब्लीडिंग एज टेक्नोलॉजी (ES6) का उपयोग करके बनाया गया है जो इसे एक्सप्रेस जैसे पुराने फ्रेमवर्क पर बढ़त देता है।

बंदर

पग (पहले जेड के रूप में जाना जाता है) HTML टेम्पलेट लिखने के लिए एक कठिन भाषा है।

  • HTML का निर्माण करता है
  • डायनेमिक कोड का समर्थन करता है
  • पुन: प्रयोज्यता का समर्थन करता है (DRY)

यह Koa के साथ प्रयोग की जाने वाली सबसे लोकप्रिय अस्थायी भाषा है।

MongoDB और Mongoose

MongoDB एक खुला-स्रोत, दस्तावेज़ डेटाबेस है जिसे विकास और स्केलिंग में आसानी के लिए डिज़ाइन किया गया है। हम डेटा संग्रहीत करने के लिए इस डेटाबेस का उपयोग करेंगे।

Mongoose, नोड.जेएस के लिए एक क्लाइंट एपीआई है जो हमारे कोए एप्लिकेशन से हमारे डेटाबेस तक पहुंचना आसान बनाता है।

कोआ फ्रेमवर्क का उपयोग करके विकसित करने के लिए आरंभ करने के लिए, आपको नोड और एनपीएम (नोड पैकेज मैनेजर) स्थापित करने की आवश्यकता है। यदि आपके पास पहले से ये नहीं हैं, तो अपने स्थानीय सिस्टम पर नोड स्थापित करने के लिए नोड सेटअप पर जाएं। पुष्टि करें कि नोड और पीपीएम आपके टर्मिनल में निम्नलिखित कमांड चलाकर स्थापित किए गए हैं।

$ node --version
$ npm --version

आपको इसके समान आउटपुट प्राप्त करना चाहिए -

v5.0.0
3.5.2

कृपया सुनिश्चित करें कि आपका नोड संस्करण 6.5.0 से ऊपर है। अब जब हमारे पास Node और npm सेट अप है, तो आइए समझते हैं कि npm क्या है और इसका उपयोग कैसे करना है।

नोड पैकेज मैनेजर (npm)

npm नोड के लिए पैकेज मैनेजर है। Npm रजिस्ट्री Node.js, फ्रंट-एंड वेब ऐप, मोबाइल ऐप, रोबोट, राउटर और जावास्क्रिप्ट समुदाय की अनगिनत अन्य जरूरतों के लिए ओपन-सोर्स कोड के पैकेज का एक सार्वजनिक संग्रह है। npm हमें इन सभी पैकेजों तक पहुँचने और उन्हें स्थानीय स्तर पर स्थापित करने की अनुमति देता है। आप npmJS पर npm पर उपलब्ध पैकेजों की सूची के माध्यम से ब्राउज़ कर सकते हैं ।

Npm का उपयोग कैसे करें?

Npm का उपयोग करके एक पैकेज स्थापित करने के दो तरीके हैं - विश्व स्तर पर और स्थानीय रूप से।

Globally- इस पद्धति का उपयोग आमतौर पर विकास उपकरण और सीएलआई आधारित पैकेजों को स्थापित करने के लिए किया जाता है। विश्व स्तर पर एक पैकेज स्थापित करने के लिए, निम्नलिखित कमांड का उपयोग करें।

$ npm install -g <package-name>

Locally- इस पद्धति का उपयोग आमतौर पर फ्रेमवर्क और लाइब्रेरी स्थापित करने के लिए किया जाता है। एक स्थानीय रूप से स्थापित पैकेज का उपयोग केवल उस निर्देशिका के भीतर किया जा सकता है जो इसे स्थापित किया गया है। पैकेज को स्थानीय रूप से स्थापित करने के लिए, ऊपर दिए बिना उसी कमांड का उपयोग करें -g झंडा।

$ npm install <package-name>

जब भी हम npm का उपयोग करके कोई प्रोजेक्ट बनाते हैं, तो हमें एक package.json फ़ाइल प्रदान करनी होगी, जिसमें हमारी परियोजना के बारे में सभी विवरण हों। npm इस फ़ाइल को सेट करना हमारे लिए आसान बनाता है। आइए हम अपनी विकास परियोजना स्थापित करें।

Step 1 - अपने टर्मिनल / cmd को फायर करें, एक नया फ़ोल्डर बनाएं जिसका नाम hello-world और cd है -

Step 2 - अब npm का उपयोग करके package.json फ़ाइल बनाने के लिए, निम्नलिखित का उपयोग करें।

npm init

यह आपसे निम्नलिखित जानकारी मांगेगा -

बस एंटर दबाए रखें, और अपना नाम "लेखक नाम" फ़ील्ड में दर्ज करें।

Step 3- अब हमारे पास हमारा पैकेज है। जसन फ़ाइल सेट है, हम कोए स्थापित करेंगे। कोआ स्थापित करने और इसे हमारे पैकेज में जोड़ने के लिए। Json फ़ाइल, निम्न कमांड का उपयोग करें।

$ npm install --save koa

कोआ को सही ढंग से स्थापित करने की पुष्टि करने के लिए, निम्न कमांड चलाएँ।

$ ls node_modules #(dir node_modules for windows)

Tip - --save ध्वज को प्रतिस्थापित किया जा सकता है -Sझंडा। यह ध्वज सुनिश्चित करता है कि कोआ को हमारे पैकेज के लिए एक निर्भरता के रूप में जोड़ा गया है। Json फ़ाइल। इसका एक फायदा है, अगली बार जब हमें अपनी परियोजना की सभी निर्भरताएं स्थापित करने की आवश्यकता है, तो हमें बस कमांड npm इंस्टॉल चलाने की आवश्यकता है और यह इस फाइल में निर्भरताएं ढूंढेगा और उन्हें हमारे लिए स्थापित करेगा।

यह हम सभी कोआ ढांचे का उपयोग करके विकास शुरू करने की आवश्यकता है। हमारी विकास प्रक्रिया को बहुत आसान बनाने के लिए, हम npm, nodemon से एक उपकरण स्थापित करेंगे। यह उपकरण क्या करता है, यह हमारे सर्वर को पुनरारंभ करता है जैसे ही हम अपनी किसी भी फाइल में बदलाव करते हैं, अन्यथा हमें प्रत्येक फाइल संशोधन के बाद सर्वर को मैन्युअल रूप से पुनरारंभ करने की आवश्यकता होती है। Nodemon स्थापित करने के लिए, निम्न कमांड का उपयोग करें।

$ npm install -g nodemon

अब हम सभी कोए में गोता लगाने के लिए तैयार हैं!

एक बार जब हमने विकास स्थापित कर लिया है, तो कोया का उपयोग करके अपना पहला ऐप विकसित करना शुरू करना है। नामक एक नई फ़ाइल बनाएँapp.js और इसमें निम्नलिखित टाइप करें।

var koa = require('koa');
var app = new koa();

app.use(function* (){
   this.body = 'Hello world!';
});

app.listen(3000, function(){
   console.log('Server running on https://localhost:3000')
});

फ़ाइल सहेजें, अपने टर्मिनल पर जाएं और टाइप करें।

$ nodemon app.js

इससे सर्वर शुरू हो जाएगा। इस ऐप का परीक्षण करने के लिए, अपना ब्राउज़र खोलें और पर जाएंhttps://localhost:3000 और आपको निम्न संदेश प्राप्त करना चाहिए।

यह ऐप कैसे काम करता है?

पहली पंक्ति हमारी फ़ाइल में कोआ आयात करती है। वैरिएबल कोआ के माध्यम से इसकी एपीआई तक हमारी पहुंच है। हम इसका उपयोग एप्लिकेशन बनाने और इसे var ऐप में असाइन करने के लिए करते हैं।

app.use(function)- यह फंक्शन एक मिडलवेयर है, जिसे जब भी हमारे सर्वर को रिक्वेस्ट मिलती है, उसे कॉल किया जाता है। हम बाद के अध्यायों में मिडलवेयर के बारे में अधिक जानेंगे। कॉलबैक फ़ंक्शन एक जनरेटर है, जिसे हम अगले अध्याय में देखेंगे। इस जनरेटर के संदर्भ को कोए में संदर्भ कहा जाता है। इस संदर्भ का उपयोग अनुरोध और प्रतिक्रिया वस्तुओं तक पहुंचने और संशोधित करने के लिए किया जाता है। हम इस प्रतिसाद के शरीर की स्थापना कर रहे हैंHello world!

app.listen(port, function)- यह फ़ंक्शन निर्दिष्ट पोर्ट पर कनेक्शन के लिए बाइंड और सुनता है। पोर्ट यहाँ केवल आवश्यक पैरामीटर है। कॉलबैक फ़ंक्शन निष्पादित किया जाता है, अगर ऐप सफलतापूर्वक चलता है।

जावास्क्रिप्ट ईएस 6 की सबसे रोमांचक नई विशेषताओं में से एक एक नई नस्ल है, जिसे जनरेटर कहा जाता है। जनरेटर से पहले, पूरी स्क्रिप्ट का उपयोग आमतौर पर एक शीर्ष से नीचे के क्रम में किया जाता था, कोड निष्पादन को रोकने के लिए एक आसान तरीका के बिना और बाद में उसी स्टैक के साथ फिर से शुरू करना। जनरेटर वे कार्य हैं जिन्हें बाहर निकाला जा सकता है और बाद में फिर से प्रवेश किया जाता है। उनके संदर्भ (वैरिएबल बाइंडिंग) को पुन: प्रवेश द्वारों पर सहेजा जाएगा।

जनरेटर हमें बीच में कोड निष्पादन को रोकने की अनुमति देते हैं। इसलिए, आइए एक साधारण जनरेटर पर नज़र डालें।

var generator_func = function* (){
   yield 1;
   yield 2;
};

var itr = generator_func();
console.log(itr.next());
console.log(itr.next());
console.log(itr.next());

उपरोक्त कोड चलाते समय, निम्नलिखित परिणाम होगा।

{ value: 1, done: false }
{ value: 2, done: false }
{ value: undefined, done: true }

आइए उपरोक्त कोड के अंदर देखें। हम पहले एक जनरेटर बनाते हैं जिसे कहा जाता हैgenerator_func()। हमने इस अजीब दिखने वाले फ़ंक्शन का एक उदाहरण बनाया और इसे सौंपाitr। फिर हमने कॉल करना शुरू कियाnext() इस itr चर पर।

अगला () कॉलिंग जनरेटर शुरू करता है और यह तब तक चलता है जब तक कि यह एक पैदावार नहीं मारता। फिर यह ऑब्जेक्ट को वैल्यू के साथ लौटाता है और किया जाता है, जहां वैल्यू का एक्सप्रेशन वैल्यू होता है। यह अभिव्यक्ति कुछ भी हो सकती है। इस बिंदु पर, यह निष्पादन को रोक देता है। फिर से जब हम इस फ़ंक्शन (अगला) को कॉल करते हैं, तो जनरेटर अंतिम उपज बिंदु से कार्य फिर से शुरू करता है, जो कि पॉज के समय समान होता है, अगली उपज बिंदु तक। यह तब तक किया जाता है जब तक कि कोड में अधिक उपज अंक न हों।

कोए में जनरेटर

तो क्यों हम इस ट्यूटोरियल में जनरेटर पर चर्चा कर रहे हैं। जैसा कि आप नमस्ते विश्व कार्यक्रम से याद कर सकते हैं, हमने एक प्रयोग कियाfunction* ()app.use () के लिए एक कॉलबैक पास करने के लिए संकेतन। कोआ एक ऑब्जेक्ट है, जिसमें मिडलवेयर जनरेटर फ़ंक्शन की एक सरणी होती है, जिनमें से प्रत्येक को प्रत्येक अनुरोध के साथ स्टैक-जैसे तरीके से बनाया और निष्पादित किया जाता है। Koa भी बहाव के बाद नियंत्रण प्रवाह के अपस्ट्रीमिंग को लागू करता है।

इसे बेहतर तरीके से समझने के लिए निम्नलिखित उदाहरण पर एक नज़र डालें।

var koa = require('koa');
var app = koa();
 
app.use(function* (next) {
   //do something before yielding to next generator function 
   
   //in line which will be 1st event in downstream
   console.log("1");
   yield next;
 
   //do something when the execution returns upstream, 
   //this will be last event in upstream
   console.log("2");
});
app.use(function* (next) {
   // This shall be 2nd event downstream
   console.log("3");
   yield next;
 
   // This would be 2nd event upstream
   console.log("4");
});
app.use(function* () { 
   // Here it would be last function downstream
   console.log("5");
   
   // Set response body
   this.body = "Hello Generators";

   // First event of upstream (from the last to first)
   console.log("6");
});

app.listen(3000);

उपरोक्त कोड चलाते समय और नेविगेट करने के लिए https://localhost:3000/ हम अपने कंसोल पर निम्न आउटपुट प्राप्त करते हैं।

1
3
5
6
4
2

यह अनिवार्य रूप से है कि Koa जनरेटर का उपयोग कैसे करता है। यह हमें इस संपत्ति का उपयोग करके कॉम्पैक्ट मिडलवेयर बनाने और अपस्ट्रीम और डाउनस्ट्रीम फंक्शंस दोनों के लिए कोड लिखने की अनुमति देता है, इस प्रकार हमें कॉलबैक से बचाता है।

वेब फ्रेमवर्क विभिन्न मार्गों पर HTML पृष्ठ, स्क्रिप्ट, चित्र आदि जैसे संसाधन प्रदान करते हैं। कोआ कोर मॉड्यूल में मार्गों का समर्थन नहीं करता है। हमें कोआ में आसानी से मार्ग बनाने के लिए कोआ-राउटर मॉड्यूल का उपयोग करने की आवश्यकता है। निम्न आदेश का उपयोग करके इस मॉड्यूल को स्थापित करें।

npm install --save koa-router

अब जब हमारे पास कोआ-राउटर स्थापित हो गया है, तो आइए एक सरल GET मार्ग उदाहरण देखें।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();              //Instantiate the router
_.get('/hello', getMessage);   // Define routes

function *getMessage() {
   this.body = "Hello world!";
};

app.use(_.routes());           //Use the routes defined using the router
app.listen(3000);

यदि हम अपना एप्लिकेशन चलाते हैं और लोकलहोस्ट: 3000 / हैलो पर जाते हैं, तो सर्वर को मार्ग "/ हैलो" पर अनुरोध प्राप्त होता है। हमारे Koa ऐप इस मार्ग से जुड़े कॉलबैक फ़ंक्शन को निष्पादित करता है और "हैलो वर्ल्ड!" प्रतिक्रिया के रूप में।

हमारे पास एक ही मार्ग पर कई अलग-अलग तरीके हो सकते हैं। उदाहरण के लिए,

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router(); //Instantiate the router

_.get('/hello', getMessage);
_.post('/hello', postMessage);

function *getMessage() {
	this.body = "Hello world!";
};
function *postMessage() {
   this.body = "You just called the post method at '/hello'!\n";
};
app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

इस अनुरोध का परीक्षण करने के लिए, अपना टर्मिनल खोलें और निम्नलिखित अनुरोध को निष्पादित करने के लिए cURL का उपयोग करें

curl -X POST "https://localhost:3000/hello"

एक विशेष विधि, all, समान फ़ंक्शन का उपयोग करके किसी विशेष मार्ग पर सभी प्रकार के http तरीकों को संभालने के लिए एक्सप्रेस द्वारा प्रदान किया जाता है। इस विधि का उपयोग करने के लिए, निम्नलिखित प्रयास करें -

_.all('/test', allMessage);

function *allMessage(){
   this.body = "All HTTP calls regardless of the verb will get this response";
};

अब हम मार्गों को परिभाषित कर सकते हैं; वे या तो स्थिर हैं या स्थिर हैं। गतिशील मार्गों का उपयोग करने के लिए, हमें विभिन्न प्रकार के मार्ग उपलब्ध कराने होंगे। गतिशील मार्गों का उपयोग करने से हमें उनके आधार पर मापदंडों और प्रक्रिया को पारित करने की अनुमति मिलती है। निम्नलिखित एक गतिशील मार्ग का एक उदाहरण है।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/:id', sendID);

function *sendID() {
   this.body = 'The id you specified is ' + this.params.id;
}

app.use(_.routes());
app.listen(3000);

इसका परीक्षण करने के लिए https://localhost:3000/123। आपको निम्न प्रतिक्रिया मिलेगी।

आप URL में '123' को किसी अन्य चीज़ से बदल सकते हैं और यह प्रतिक्रिया में परिलक्षित होगा। निम्नलिखित उपरोक्त का एक जटिल उदाहरण है।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/things/:name/:id', sendIdAndName);

function *sendIdAndName(){
   this.body = 'id: ' + this.params.id + ' and name: ' + this.params.name;
};

app.use(_.routes());

app.listen(3000);

इसका परीक्षण करने के लिए https://localhost:3000/things/tutorialspoint/12345

आप उपयोग कर सकते हैं this.paramsURL में आपके द्वारा पास किए गए सभी मापदंडों तक पहुंचने के लिए ऑब्जेक्ट। ध्यान दें कि उपरोक्त दोनों के अलग-अलग रास्ते हैं। वे कभी भी ओवरलैप नहीं होंगे। इसके अलावा अगर आपको '/ चीजें' मिलने पर कोड निष्पादित करना है, तो आपको इसे अलग से परिभाषित करने की आवश्यकता है।

पैटर्न मिलान मार्गों

URL पैरामीटर मिलान को प्रतिबंधित करने के लिए आप regex का भी उपयोग कर सकते हैं। मान लीजिए कि आपको पांच अंकों की लंबी संख्या के लिए आईडी की आवश्यकता है। आप निम्न मार्ग परिभाषा का उपयोग कर सकते हैं।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/things/:id([0-9]{5})', sendID);

function *sendID(){
   this.body = 'id: ' + this.params.id;
}

app.use(_.routes());
app.listen(3000);

ध्यान दें कि यह होगा onlyउन अनुरोधों से मिलान करें जिनकी 5-अंकीय लंबी आईडी है। आप अपने मार्गों के मिलान / सत्यापन के लिए अधिक जटिल रीजेक्स का उपयोग कर सकते हैं। यदि आपका कोई भी मार्ग अनुरोध से मेल नहीं खाता है, तो आपको प्रतिक्रिया के रूप में एक नहीं मिला संदेश मिलेगा।

उदाहरण के लिए, यदि हम एक मान्य URL के साथ अनुरोध करने पर उपरोक्त मार्गों को परिभाषित करते हैं, तो हमें यह मिलता है -

HTTP विधि अनुरोध में आपूर्ति की जाती है और क्लाइंट द्वारा अनुरोधित ऑपरेशन को निर्दिष्ट करता है। निम्न तालिका सामान्यतः उपयोग की जाने वाली HTTP विधियों को संक्षेप में प्रस्तुत करती है।

अनु क्रमांक। विधि और विवरण
1

GET

GET विधि निर्दिष्ट संसाधन के प्रतिनिधित्व का अनुरोध करती है। GET का उपयोग करने वाले अनुरोधों को केवल डेटा पुनर्प्राप्त करना चाहिए और कोई अन्य प्रभाव नहीं होना चाहिए।

2

POST

POST विधि अनुरोध करती है कि सर्वर URI द्वारा पहचाने गए संसाधन के एक नए ऑब्जेक्ट / इकाई के रूप में अनुरोध में संलग्न डेटा को स्वीकार करता है।

3

PUT

PUT विधि अनुरोध करती है कि सर्वर URI द्वारा पहचान की गई मौजूदा वस्तु में संशोधन के रूप में अनुरोध में संलग्न डेटा को स्वीकार करता है। यदि यह मौजूद नहीं है, तो PUT विधि को एक बनाना चाहिए।

4

DELETE

DELETE विधि अनुरोध करती है कि सर्वर निर्दिष्ट संसाधन को हटा दें।

ये सबसे सामान्य HTTP तरीके हैं। उनके बारे में अधिक जानने के लिए, पर जाएँhttps://www.tutorialspoint.com/http/http_methods.htm।

कोया अनुरोध ऑब्जेक्ट नोड के वेनिला अनुरोध ऑब्जेक्ट के शीर्ष पर एक अमूर्तता है, जो अतिरिक्त कार्यक्षमता प्रदान करता है जो हर रोज़ HTTP सर्वर विकास के लिए उपयोगी है। Koa अनुरोध ऑब्जेक्ट संदर्भ ऑब्जेक्ट में एम्बेडेड है,this। जब भी हमें कोई अनुरोध मिलता है, हम अनुरोध ऑब्जेक्ट को लॉग आउट करते हैं।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/hello', getMessage);

function *getMessage(){
   console.log(this.request);
   this.body = 'Your request has been logged.';
}
app.use(_.routes());
app.listen(3000);

जब आप इस कोड को चलाते हैं और नेविगेट करते हैं https://localhost:3000/hello, तो आपको निम्न प्रतिक्रिया प्राप्त होगी।

अपने कंसोल पर, आपको अनुरोध की गई वस्तु लॉग आउट हो जाएगी।

{ 
   method: 'GET',
   url: '/hello/',
   header: 
   { 
      host: 'localhost:3000',
      connection: 'keep-alive',
      'upgrade-insecure-requests': '1',
      'user-agent': 'Mozilla/5.0 (X11; Linux x86_64) 
         AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.116 Safari/537.36',
      accept: 'text/html,application/xhtml+xml,
         application/xml;q = 0.9,image/webp,*/*;q = 0.8',
      dnt: '1',
      'accept-encoding': 'gzip, deflate, sdch',
      'accept-language': 'en-US,en;q = 0.8' 
   }
}

हमारे पास इस ऑब्जेक्ट का उपयोग करके अनुरोध के कई उपयोगी गुणों तक पहुंच है। आइए हम कुछ उदाहरणों पर गौर करें।

request.header

सभी अनुरोध हेडर प्रदान करता है।

request.method

अनुरोध विधि प्रदान करता है (GET, POST, आदि)

request.href

पूर्ण अनुरोध URL प्रदान करता है।

request.path

अनुरोध का मार्ग प्रदान करता है। बिना क्वेरी स्ट्रिंग और बेस url के।

request.query

पार्स किए गए क्वेरी स्ट्रिंग देता है। उदाहरण के लिए, यदि हम इस तरह के अनुरोध पर इसे लॉग करते हैंhttps://localhost:3000/hello/?name=Ayush&age=20&country=India, तो हम निम्नलिखित वस्तु प्राप्त करेंगे।

{
   name: 'Ayush',
   age: '20',
   country: 'India'
}

request.accepts (प्रकार)

यह फ़ंक्शन सही या गलत के आधार पर रिटर्न देता है कि क्या अनुरोधित संसाधन दिए गए अनुरोध प्रकार को स्वीकार करते हैं।

आपको कम से के बारे में डॉक्स में अनुरोध वस्तु अधिक पढ़ सकते हैं अनुरोध ।

कोया रिस्पांस ऑब्जेक्ट नोड के वेनिला प्रतिक्रिया ऑब्जेक्ट के शीर्ष पर एक अमूर्तता है, जो अतिरिक्त कार्यक्षमता प्रदान करता है जो हर रोज़ HTTP सर्वर विकास के लिए उपयोगी है। कोआ प्रतिक्रिया वस्तु संदर्भ वस्तु में अंतर्निहित है,this। जब भी हमें कोई अनुरोध मिलता है, हम प्रतिक्रिया ऑब्जेक्ट को लॉग आउट करते हैं।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/hello', getMessage);

function *getMessage(){
   this.body = 'Your request has been logged.';
   console.log(this.response);
}

app.use(_.routes());
app.listen(3000);

जब आप इस कोड को चलाते हैं और नेविगेट करते हैं https://localhost:3000/hello तब आपको निम्न प्रतिक्रिया प्राप्त होगी।

अपने कंसोल पर, आपको अनुरोध की गई वस्तु लॉग आउट हो जाएगी।

{ 
   status: 200,
   message: 'OK',
   header: 
   {
      'content-type': 'text/plain; charset=utf-8',
      'content-length': '12' 
   },
   body: 'Your request has been logged.' 
}

स्थिति और संदेश कोआ द्वारा स्वचालित रूप से सेट किए जाते हैं लेकिन हमारे द्वारा संशोधित किए जा सकते हैं। यदि हम प्रतिक्रिया निकाय सेट नहीं करते हैं, तो स्थिति कोड 404 पर सेट होता है। एक बार जब हम प्रतिक्रिया निकाय सेट करते हैं, तो स्थिति डिफ़ॉल्ट रूप से 200 पर सेट होती है। हम स्पष्ट रूप से इस व्यवहार को ओवरराइड कर सकते हैं।

हमारे पास इस ऑब्जेक्ट का उपयोग करके प्रतिक्रिया के कई उपयोगी गुणों तक पहुंच है। आइए कुछ उदाहरण देखें -

response.header

सभी प्रतिक्रिया हेडर प्रदान करता है।

response.status

प्रतिक्रिया की स्थिति (200, 404, 500, आदि) प्रदान करता है। इस संपत्ति का उपयोग प्रतिक्रिया की स्थिति निर्धारित करने के लिए भी किया जाता है।

response.message

प्रतिक्रिया संदेश प्रदान करता है। इस संपत्ति का उपयोग प्रतिक्रियाओं के साथ कस्टम संदेश सेट करने के लिए भी किया जाता है। यह response.status के साथ जुड़ा हुआ है।

response.body

प्रतिक्रिया निकाय प्राप्त करें या सेट करें। आमतौर पर, हम इसे संदर्भ ऑब्जेक्ट का उपयोग करके एक्सेस करते हैं। इसे एक्सेस करने का यह एक और तरीका है। शरीर प्रकार का हो सकता है: स्ट्रिंग, बफर, स्ट्रीम, ऑब्जेक्ट या नल।

response.type

वर्तमान प्रतिक्रिया की सामग्री प्रकार प्राप्त करें या सेट करें।

response.get (क्षेत्र)

इस फ़ंक्शन का उपयोग केस असंवेदनशील मान क्षेत्र के साथ हेडर के मूल्यों को प्राप्त करने के लिए किया जाता है।

response.set (फ़ील्ड, मान)

इस फ़ंक्शन का उपयोग फ़ील्ड और वैल्यू पेयर का उपयोग करके प्रतिक्रिया पर हेडर सेट करने के लिए किया जाता है।

response.remove (क्षेत्र)

इस फ़ंक्शन का उपयोग फ़ील्ड नाम का उपयोग करके प्रतिक्रिया पर हेडर को अनसेट करने के लिए किया जाता है।

आपको कम से डॉक्स में प्रतिक्रिया वस्तु के बारे में और अधिक पढ़ सकते रिस्पांस ।

वेबसाइट बनाते समय पुनर्निर्देशन बहुत महत्वपूर्ण है। यदि एक विकृत URL का अनुरोध किया गया है या आपके सर्वर पर कुछ त्रुटियां हैं, तो आपको उन्हें संबंधित त्रुटि पृष्ठों पर पुनः निर्देशित करना चाहिए। रीडायरेक्ट का उपयोग लोगों को आपकी वेबसाइट के प्रतिबंधित क्षेत्रों से बाहर रखने के लिए भी किया जा सकता है।

जब भी कोई विकृत URL का अनुरोध करता है, तो हम एक त्रुटि पृष्ठ बनाते हैं और उस पृष्ठ पर पुनर्निर्देशित करते हैं।

var koa = require('koa');
var router = require('koa-router');
var app = koa();
var _ = router();

_.get('/not_found', printErrorMessage);
_.get('/hello', printHelloMessage);

app.use(_.routes());
app.use(handle404Errors);

function *printErrorMessage() {
   this.status = 404;
   this.body = "Sorry we do not have this resource.";
}
function *printHelloMessage() {
   this.status = 200;
   this.body = "Hey there!";
}
function *handle404Errors(next) {
   if (404 != this.status) return;
   this.redirect('/not_found');
}
app.listen(3000);

जब हम इस कोड को चलाते हैं और / hello के अलावा किसी भी मार्ग पर जाते हैं, तो हम / not_found पर पुनर्निर्देशित होंगे। हमने मिडलवेयर को अंत में रखा है (इस मिडलवेयर को app.use फ़ंक्शन कॉल)। यह सुनिश्चित करता है कि हम अंत में मिडलवेयर तक पहुंचें और संबंधित प्रतिक्रिया भेजें। निम्नलिखित परिणाम हम देखते हैं जब हम उपरोक्त कोड चलाते हैं।

जब हम नेविगेट करते हैं https://localhost:3000/hello, हमें मिलता है -

यदि हम किसी अन्य मार्ग पर जाते हैं, तो हमें मिलता है -

वेब एप्लिकेशन बनाने में एरर हैंडलिंग एक महत्वपूर्ण भूमिका निभाता है। कोआ इस उद्देश्य के लिए भी मिडलवेयर का उपयोग करता है।

कोआ में, आप एक मिडलवेयर जोड़ते हैं जो करता है try { yield next }पहले मिडलवेयर में से एक के रूप में। यदि हम नीचे की ओर किसी भी त्रुटि का सामना करते हैं, तो हम संबंधित कैच क्लॉज पर लौटते हैं और यहां त्रुटि को संभालते हैं। उदाहरण के लिए -

var koa = require('koa');
var app = koa();

//Error handling middleware
app.use(function *(next) {
   try {
      yield next;
   } catch (err) {
      this.status = err.status || 500;
      this.body = err.message;
      this.app.emit('error', err, this);
   }
});

//Create an error in the next middleware
//Set the error message and status code and throw it using context object

app.use(function *(next) {
   //This will set status and message
   this.throw('Error Message', 500);
});

app.listen(3000);

हमने उपरोक्त कोड में जानबूझकर एक त्रुटि बनाई है और हमारे पहले मिडलवेयर के कैच ब्लॉक में त्रुटि को संभाल रहे हैं। यह तब हमारे कंसोल के लिए उत्सर्जित होता है और साथ ही हमारे क्लाइंट को प्रतिक्रिया के लिए भेजा जाता है। निम्नलिखित त्रुटि संदेश हमें तब मिलता है जब हम इस त्रुटि को ट्रिगर करते हैं।

InternalServerError: Error Message
   at Object.module.exports.throw 
      (/home/ayushgp/learning/koa.js/node_modules/koa/lib/context.js:91:23)
   at Object.<anonymous> (/home/ayushgp/learning/koa.js/error.js:18:13)
   at next (native)
   at onFulfilled (/home/ayushgp/learning/koa.js/node_modules/co/index.js:65:19)
   at /home/ayushgp/learning/koa.js/node_modules/co/index.js:54:5
   at Object.co (/home/ayushgp/learning/koa.js/node_modules/co/index.js:50:10)
   at Object.toPromise (/home/ayushgp/learning/koa.js/node_modules/co/index.js:118:63)
   at next (/home/ayushgp/learning/koa.js/node_modules/co/index.js:99:29)
   at onFulfilled (/home/ayushgp/learning/koa.js/node_modules/co/index.js:69:7)
   at /home/ayushgp/learning/koa.js/node_modules/co/index.js:54:5

अभी सर्वर पर भेजे गए किसी भी अनुरोध के परिणामस्वरूप यह त्रुटि होगी।

मिडलवेयर फ़ंक्शंस ऐसे फ़ंक्शंस हैं जिनकी एक्सेस है context objectऔर अनुप्रयोग के अनुरोध-प्रतिक्रिया चक्र में अगले मिडलवेयर फ़ंक्शन। इन कार्यों का उपयोग अनुरोधों और प्रतिक्रिया ऑब्जेक्ट्स को संशोधित करने के लिए किया जाता है जैसे अनुरोध निकायों को पार्स करना, प्रतिक्रिया हेडर जोड़ना, आदि कोए उपज से एक कदम आगे जाते हैं।'downstream', तो नियंत्रण वापस बह रहा है 'upstream'। इस प्रभाव को कहा जाता हैcascading

कार्रवाई में एक मिडलवेयर फ़ंक्शन का एक सरल उदाहरण निम्नलिखित है।

var koa = require('koa');
var app = koa();
var _ = router();

//Simple request time logger
app.use(function* (next) {
   console.log("A new request received at " + Date.now());
   
   //This function call is very important. It tells that more processing is 
   //required for the current request and is in the next middleware function/route handler.
   yield next;
});

app.listen(3000);

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

A new request received at 1467267512545

इसे एक विशिष्ट मार्ग (और इसके सभी उपखंडों) तक सीमित रखने के लिए, हमें बस उन मार्गों को बनाने की आवश्यकता है जैसे हमने रूट करने के लिए किया था। वास्तव में इसके ये मिडिलवेयर ही हमारे अनुरोध को संभालते हैं।

उदाहरण के लिए,

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

//Simple request time logger
_.get('/request/*', function* (next) {
   console.log("A new request received at " + Date.now());
   yield next;
});

app.use(_.routes());
app.listen(3000);

अब जब भी आप 'अनुरोध' के किसी भी उप-अनुरोध का अनुरोध करते हैं, तभी यह समय लॉग करेगा।

मिडिलवेयर कॉल का क्रम

Koa में मिडलवेयर के बारे में सबसे महत्वपूर्ण चीजों में से एक यह है कि जिस क्रम में उन्हें आपकी फ़ाइल में लिखा / शामिल किया जाता है, वह वह क्रम है जिसमें उन्हें डाउनस्ट्रीम निष्पादित किया जाता है। जैसे ही हम एक मिडलवेयर में यील्ड स्टेटमेंट मारते हैं, यह तब तक अगले मिडलवेयर पर स्विच हो जाता है, जब तक हम आखिरी तक नहीं पहुंच जाते। फिर हम फिर से आगे बढ़ना शुरू करते हैं और उपज कथनों से कार्यों को फिर से शुरू करते हैं।

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

var koa = require('koa');
var app = koa();

//Order of middlewares
app.use(first);
app.use(second);
app.use(third);

function *first(next) {
   console.log("I'll be logged first. ");
   
   //Now we yield to the next middleware
   yield next;
   
   //We'll come back here at the end after all other middlewares have ended
   console.log("I'll be logged last. ");
};

function *second(next) {
   console.log("I'll be logged second. ");
   yield next;
   console.log("I'll be logged fifth. ");
};

function *third(next) {
   console.log("I'll be logged third. ");
   yield next;
   console.log("I'll be logged fourth. ");
};

app.listen(3000);

जब हम इस कोड को चलाने के बाद '/' पर जाते हैं, तो हमारे कंसोल पर हमें मिलेगा -

I'll be logged first. 
I'll be logged second. 
I'll be logged third. 
I'll be logged fourth. 
I'll be logged fifth. 
I'll be logged last.

निम्नलिखित चित्र संक्षेप में बताता है कि उपरोक्त उदाहरण में वास्तव में क्या हो रहा है।

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

थर्ड पार्टी मिडिलवेयर

एक्सप्रेस के लिए तीसरे पक्ष के मिडलवेयर की एक सूची यहां उपलब्ध है। निम्नलिखित सबसे आम तौर पर इस्तेमाल किए जाने वाले मिडलवेयर में से कुछ हैं -

  • koa-bodyparser
  • koa-router
  • koa-static
  • koa-compress

हम बाद के अध्यायों में कई मिडलवेयर पर चर्चा करेंगे।

पग एक टेम्प्लेटिंग इंजन है। HTML के साथ हमारे सर्वर कोड की अव्यवस्था को हटाने के लिए टेंपलेटिंग इंजन का उपयोग किया जाता है, मौजूदा HTML टेम्प्लेट में बेतहाशा तार को घुसाया जाता है। पग एक बहुत शक्तिशाली टेम्प्लटिंग इंजन है, जिसमें विभिन्न प्रकार की विशेषताएं हैं जैसे किfilters, includes, inheritance, interpolation, आदि इस पर कवर करने के लिए बहुत जमीन है।

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

$ npm install --save pug koa-pug

एक बार पग स्थापित होने के बाद, इसे अपने ऐप के लिए टेम्प्लेटिंग इंजन के रूप में सेट करें। निम्न कोड को अपने app.js फ़ाइल में जोड़ें।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app //Equivalent to app.use(pug)
});

var _ = router(); //Instantiate the router

app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

अब, एक नई निर्देशिका बनाएं जिसे दृश्य कहा जाता है। निर्देशिका के अंदर, First_view.pug नाम की एक फ़ाइल बनाएं, और उसमें निम्न डेटा दर्ज करें।

doctype html
html
   head
      title = "Hello Pug"
   body
      p.greetings#people Hello Views!

इस पृष्ठ को चलाने के लिए, अपने ऐप में निम्न मार्ग जोड़ें।

_.get('/hello', getMessage); // Define routes

function *getMessage(){
   this.render('first_view');
};

आपको आउटपुट प्राप्त होगा -

पग क्या करता है, यह HTML के लिए यह बहुत ही सरल दिखने वाला मार्कअप है। हमें अपने टैग बंद करने की आवश्यकता नहीं है, कक्षा और आईडी कीवर्ड का उपयोग करने की आवश्यकता नहीं है, बल्कि 'का उपयोग करें।' और '#' उन्हें परिभाषित करने के लिए। उपरोक्त कोड पहले परिवर्तित हो जाता है

<!DOCTYPE html>
<html>
   <head>
      <title>Hello Pug</title>
   </head>
    
   <body>
      <p class = "greetings" id = "people">Hello Views!</p>
   </body>
</html>

पग HTML मार्कअप को सरल बनाने की तुलना में बहुत अधिक करने में सक्षम है। आइए पग की इन विशेषताओं में से कुछ का पता लगाएं।

सरल टैग

टैग उनके इंडेंटेशन के अनुसार नेस्टेड हैं। उपरोक्त उदाहरण की तरह,<title> भीतर इंडेंट किया गया था <head>टैग, तो यह उसके अंदर था। हालांकि<body> टैग उसी इंडेंटेशन पर था, इस प्रकार यह एक भाई-बहन था <head> टैग।

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

टैग के अंदर टेक्स्ट डालने के तीन तरीके हैं -

  • अंतरिक्ष अलग -
h1 Welcome to Pug
  • पाइप्ड पाठ -
div
   | To insert multiline text, 
   | You can use the pipe operator.
  • पाठ का ब्लॉक -
div.
   But that gets tedious if you have a lot of text. 
   You can use "." at the end of tag to denote block of text. 
   To put tags inside this block, simply enter tag in a new line and 
   indent it accordingly.

टिप्पणियाँ

पग टिप्पणी बनाने के लिए जावास्क्रिप्ट (//) के रूप में एक ही वाक्यविन्यास का उपयोग करता है। इन टिप्पणियों को HTML टिप्पणियों (<- टिप्पणी ->) में बदल दिया जाता है। उदाहरण के लिए,

//This is a Pug comment

इस टिप्पणी में परिवर्तित हो जाता है -

<!--This is a Pug comment-->

गुण

विशेषताओं को परिभाषित करने के लिए, हम कोष्ठक में, अल्पविराम द्वारा अलग की गई विशेषताओं की सूची का उपयोग करते हैं। क्लास और आईडी विशेषताओं का विशेष प्रतिनिधित्व है। कोड की निम्नलिखित पंक्ति एक निर्दिष्ट HTML टैग के लिए परिभाषित करने की विशेषताओं, कक्षाओं और आईडी को शामिल करती है।

div.container.column.main#division(width = "100",height = "100")

कोड की यह लाइन, में परिवर्तित हो जाती है -

<div class = "container column main" id = "division" width = "100" height = "100"></div>

टेंपरेचर पर वैल्यूज पास करना

जब हम एक पग टेम्पलेट प्रदान करते हैं, तो हम वास्तव में इसे हमारे मार्ग हैंडलर से एक मान दे सकते हैं, जिसे हम बाद में अपने टेम्पलेट में उपयोग कर सकते हैं। निम्नलिखित कोड के साथ एक नया मार्ग हैंडलर बनाएं।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app // equals to pug.use(app) and app.use(pug.middleware)
});

var _ = router(); //Instantiate the router

_.get('//dynamic_view', dynamicMessage); // Define routes

function *dynamicMessage(){
   this.render('dynamic', {
      name: "TutorialsPoint", 
      url:"https://www.tutorialspoint.com"
   });
};

app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

फिर, निम्नलिखित कोड का उपयोग करके, डाइनेमिक.पग नामक विचार निर्देशिका में एक नई दृश्य फ़ाइल बनाएं।

html
   head
      title = name
   body
      h1 = name
      a(href = url) URL

खुला हुआ localhost:3000/dynamicआपके ब्राउज़र में और निम्न आउटपुट होना चाहिए। -

हम पाठ के भीतर इन पारित चर का भी उपयोग कर सकते हैं। किसी टैग के पाठ के बीच में पारित चर डालने के लिए, हम # {variableName} वाक्य रचना का उपयोग करते हैं। उदाहरण के लिए, उपरोक्त उदाहरण में, यदि हम TutorialsPoint से अभिवादन सम्मिलित करना चाहते हैं, तो हमें निम्नलिखित कोड का उपयोग करना होगा।

html
   head
      title = name
   body
      h1 Greetings from #{name}
      a(href = url) URL

मूल्यों का उपयोग करने की इस विधि को प्रक्षेप कहा जाता है।

सशर्त,

हम सशर्त विवरण और लूपिंग निर्माण का भी उपयोग कर सकते हैं। इस व्यावहारिक उदाहरण पर विचार करें, यदि कोई उपयोगकर्ता लॉग इन है, तो हम "हाय, यूजर" प्रदर्शित करना चाहेंगे और यदि नहीं, तो हम उसे "लॉगिन / साइन अप" लिंक दिखाना चाहेंगे। इसे प्राप्त करने के लिए, हम एक सरल टेम्पलेट को परिभाषित कर सकते हैं जैसे कि -

html
   head
      title Simple template
   body
      if(user)
         h1 Hi, #{user.name}
      else
         a(href = "/sign_up") Sign Up

जब हम अपने मार्गों का उपयोग करके इसे प्रस्तुत करते हैं, और यदि हम किसी वस्तु को पास करते हैं जैसे -

this.render('/dynamic',{user: 
   {name: "Ayush", age: "20"}
});

यह हाय, आयुष को प्रदर्शित करने वाला संदेश देगा। हालाँकि, यदि हम कोई ऑब्जेक्ट पास नहीं करते हैं या किसी भी उपयोगकर्ता कुंजी के साथ पास नहीं करते हैं, तो हमें एक साइन अप लिंक मिलेगा।

शामिल करें और घटक

पग एक वेब पेज के लिए घटक बनाने के लिए एक बहुत ही सहज तरीका प्रदान करता है। उदाहरण के लिए, यदि आप एक समाचार वेबसाइट देखते हैं, तो लोगो और श्रेणियों के साथ शीर्ष लेख हमेशा तय होता है। हर दृष्टि से इसकी नकल करने के बजाय, हम एक शामिल का उपयोग कर सकते हैं। निम्नलिखित उदाहरण से पता चलता है कि हम एक का उपयोग कैसे कर सकते हैं -

निम्नलिखित कोड के साथ तीन दृश्य बनाएं -

header.pug

div.header.
   I'm the header for this website.

content.pug

html
   head
      title Simple template
   body
      include ./header.pug
      h3 I'm the main content
      include ./footer.pug

footer.pug

div.footer.
   I'm the footer for this website.

इसके लिए एक मार्ग बनाएँ।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app //Equivalent to app.use(pug)
});

var _ = router(); //Instantiate the router

_.get('/components', getComponents);

function *getComponents(){
   this.render('content.pug');
}

app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

के लिए जाओ localhost:3000/components, आपको निम्न आउटपुट मिलना चाहिए।

include प्लेनटेक्स्ट, सीएसएस और जावास्क्रिप्ट को शामिल करने के लिए भी इस्तेमाल किया जा सकता है।

पग की कई अन्य विशेषताएं हैं। हालाँकि, वे इस ट्यूटोरियल के दायरे से बाहर हैं। आप आगे पग में पग का पता लगा सकते हैं ।

प्रपत्र वेब का एक अभिन्न अंग हैं। हमारे द्वारा देखी जाने वाली लगभग हर वेबसाइट हमें ऐसे फ़ॉर्म प्रदान करती है जो हमारे लिए कुछ जानकारी जमा करते हैं या लाते हैं। रूपों के साथ आरंभ करने के लिए, हम पहले कोआ-बॉडी को स्थापित करेंगे। इसे स्थापित करने के लिए, अपने टर्मिनल पर जाएं और उपयोग करें -

$ npm install --save koa-body

निम्नलिखित कोड के साथ अपने app.js फ़ाइल सामग्री बदलें।

var koa = require('koa');
var router = require('koa-router');
var bodyParser = require('koa-body');
var app = koa();

//Set up Pug
var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app //Equivalent to app.use(pug)
});

//Set up body parsing middleware
app.use(bodyParser({
   formidable:{uploadDir: './uploads'},
   multipart: true,
   urlencoded: true
}));

_.get('/', renderForm);
_.post('/', handleForm);

function * renderForm(){
   this.render('form');
}
function *handleForm(){
   console.log(this.request.body);
   console.log(this.req.body);
   this.body = this.request.body; //This is where the parsed request is stored
}

app.use(_.routes()); 
app.listen(3000);

हम यहां जो नई चीजें कर रहे हैं, वह बॉडी पार्सर और मल्टर का आयात कर रही है। हम पार्सिंग जोंस और x-www-form-urlencoded हैडर अनुरोधों को पार्स करने के लिए बॉडी पार्सर का उपयोग कर रहे हैं, जबकि हम मल्टीपार्ट / फॉर्म-डेटा पार्स करने के लिए मुलर का उपयोग करते हैं।

आइए हम इसका परीक्षण करने के लिए HTML फॉर्म बनाते हैं! निम्न कोड के साथ form.pug नाम का एक नया दृश्य बनाएं।

html
   head
      title Form Tester
   body
      form(action = "/", method = "POST")
         div
            label(for = "say") Say: 
            input(name = "say" value = "Hi")
         br
         div
            label(for = "to") To: 
            input(name = "to" value = "Koa form")
         br
         button(type = "submit") Send my greetings

अपना सर्वर चलाएं -

nodemon index.js

अब लोकलहोस्ट पर जाएं: 3000 / और जैसा चाहें वैसा फॉर्म भरें और सबमिट करें। आपको प्रतिक्रिया इस प्रकार मिलेगी -

अपने कंसोल पर एक नज़र डालें, यह आपको जावास्क्रिप्ट ऑब्जेक्ट के रूप में आपके अनुरोध का निकाय दिखाएगा। उदाहरण के लिए -

this.request.bodyऑब्जेक्ट में आपका पार्स किया गया अनुरोध निकाय है। उस ऑब्जेक्ट से फ़ील्ड्स का उपयोग करने के लिए, उन्हें सामान्य JS ऑब्जेक्ट्स के रूप में उपयोग करें।

यह अनुरोध भेजने का सिर्फ एक तरीका है। कई अन्य तरीके हैं, लेकिन वे यहां कवर करने के लिए अप्रासंगिक हैं, क्योंकि हमारा कोया ऐप उन सभी अनुरोधों को उसी तरह से संभाल लेगा। अनुरोध करने के विभिन्न तरीकों के बारे में अधिक पढ़ने के लिए, इस पृष्ठ पर एक नज़र डालें ।

वेब एप्लिकेशन को फ़ाइल अपलोड की अनुमति देने के लिए कार्यक्षमता प्रदान करने की आवश्यकता है। आइए देखें कि हम ग्राहकों से कैसे फाइल प्राप्त कर सकते हैं और उन्हें अपने सर्वर पर स्टोर कर सकते हैं।

हमने पार्सिंग अनुरोधों के लिए कोआ-बॉडी मिडलवेयर का उपयोग पहले ही कर लिया है। इस मिडलवेयर का उपयोग फ़ाइल अपलोड को संभालने के लिए भी किया जाता है। आइए एक ऐसा फ़ॉर्म बनाएं जो हमें फ़ाइलों को अपलोड करने की अनुमति देता है और फिर Koa का उपयोग करके इन फ़ाइलों को सहेज सकता है। सबसे पहले नाम से एक टेम्पलेट बनाएंfile_upload.pug निम्नलिखित सामग्री के साथ।

html
   head
      title File uploads
   body
      form(action = "/upload" method = "POST" enctype = "multipart/form-data")
         div
            input(type = "text" name = "name" placeholder = "Name")
         
         div
            input(type = "file" name = "image")
         
         div
            input(type = "submit")

ध्यान दें कि आपको अपने फ़ॉर्म में ऊपर की तरह ही एन्कोडिंग प्रकार देने की आवश्यकता है। अब हम अपने सर्वर पर इस डेटा को संभालते हैं।

var koa = require('koa');
var router = require('koa-router');
var bodyParser = require('koa-body');
var app = koa();

//Set up Pug
var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app 
});

//Set up body parsing middleware
app.use(bodyParser({
   formidable:{uploadDir: './uploads'},    //This is where the files would come
   multipart: true,
   urlencoded: true
}));

var _ = router(); //Instantiate the router

_.get('/files', renderForm);
_.post('/upload', handleForm);

function * renderForm(){
   this.render('file_upload');
}

function *handleForm(){
   console.log("Files: ", this.request.body.files);
   console.log("Fields: ", this.request.body.fields);
   this.body = "Received your data!"; //This is where the parsed request is stored
}

app.use(_.routes()); 
app.listen(3000);

जब आप इसे चलाते हैं, तो आपको निम्न फ़ॉर्म मिलते हैं।

जब आप इसे सबमिट करते हैं, तो आपका कंसोल निम्न आउटपुट का उत्पादन करेगा।

जो फ़ाइलें अपलोड की गई थीं, वे उपरोक्त आउटपुट में पथ में संग्रहीत हैं। आप का उपयोग कर अनुरोध में फ़ाइलों तक पहुँच सकते हैंthis.request.body.files और उस अनुरोध के क्षेत्र this.request.body.fields

स्टेटिक फाइलें वे फाइलें होती हैं जो क्लाइंट सर्वर से डाउनलोड करते हैं। एक नई निर्देशिका बनाएँ,public। एक्सप्रेस, डिफ़ॉल्ट रूप से आपको स्थिर फ़ाइलों की सेवा करने की अनुमति नहीं देता है।

हमें इस उद्देश्य की पूर्ति के लिए एक मिडलवेयर की आवश्यकता है। आगे बढ़ो और स्थापित करेंkoa-serve -

$ npm install --save koa-static

अब हमें जरूरत है useयह मिडिलवेयर। इससे पहले कि सार्वजनिक नामक एक निर्देशिका बनाएँ। हम अपनी सभी स्टैटिक फाइल्स यहाँ स्टोर करेंगे। यह हमें हमारे सर्वर कोड को सुरक्षित रखने की अनुमति देता है क्योंकि इस सार्वजनिक फ़ोल्डर के ऊपर कुछ भी ग्राहकों के लिए सुलभ नहीं होगा। सार्वजनिक निर्देशिका बनाने के बाद, नाम की फ़ाइल बनाएँhello.txtकिसी भी सामग्री के साथ आप इसे पसंद करते हैं। अब अपने app.js. में निम्नलिखित जोड़ें।

var serve = require('koa-static');
var koa = require('koa');
var app = koa();

app.use(serve('./public'));

app.listen(3000);

Note- Koa स्थिर निर्देशिका के सापेक्ष फ़ाइलों को देखता है, इसलिए स्थैतिक निर्देशिका का नाम URL का हिस्सा नहीं है। रूट रूट अब आपके सार्वजनिक dir पर सेट है, इसलिए आपके द्वारा लोड की जाने वाली सभी स्थिर फाइलें सार्वजनिक रूप से रूट के रूप में विचार करेंगी। यह परीक्षण करने के लिए कि यह ठीक काम कर रहा है, अपना ऐप चलाएं और जाएँhttps://localhost:3000/hello.txt

आपको निम्न आउटपुट मिलना चाहिए। ध्यान दें कि यह एक HTML दस्तावेज़ या पग दृश्य नहीं है, बल्कि यह एक साधारण txt फ़ाइल है।

एकाधिक स्थैतिक डायर

हम कई स्थैतिक संपत्ति निर्देशिकाओं का उपयोग करके भी सेट कर सकते हैं -

var serve = require('koa-static');
var koa = require('koa');
var app = koa();

app.use(serve('./public'));
app.use(serve('./images'));

app.listen(3000);

अब जब हम एक फ़ाइल का अनुरोध करते हैं, तो Koa इन निर्देशिकाओं को खोजेगा और हमें मिलान फ़ाइल भेजेगा।

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

  • सत्र प्रबंधन
  • निजीकरण (सिफारिश प्रणाली)
  • उपयोगकर्ता ट्रैकिंग

Koa के साथ कुकीज़ का उपयोग करने के लिए, हमारे पास कार्य हैं: ctx.cookies.set() तथा ctx.cookies.get()। एक नया कुकी सेट करने के लिए, आइए हमारे Koa ऐप में एक नया मार्ग निर्धारित करें।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

_.get('/', setACookie);

function *setACookie() {
   this.cookies.set('foo', 'bar', {httpOnly: false});
}

var _ = router();

app.use(_.routes());
app.listen(3000);

कुकी सेट है या नहीं, यह जांचने के लिए, बस अपने ब्राउज़र पर जाएं, कंसोल को फायर करें, और दर्ज करें -

console.log(document.cookie);

यह निम्नलिखित आउटपुट का उत्पादन करेगा (आपके ब्राउज़र में एक्सटेंशन के कारण आपके पास शायद अधिक कुकीज़ सेट हो सकती हैं)।

"foo = bar"

यहाँ ऊपर का एक उदाहरण है।

हर बार जब यह सर्वर से सवाल करता है तो ब्राउज़र भी कुकीज़ वापस भेज देता है। अपने सर्वर पर किसी रूट में सर्वर कंसोल पर कुकी देखने के लिए, उस रूट में निम्न कोड जोड़ें।

console.log('Cookies: foo = ', this.cookies.get('foo'));

अगली बार जब आप इस मार्ग पर अनुरोध भेजेंगे, तो आपको निम्न आउटपुट मिलेगा।

Cookies: foo = bar

समाप्ति समय के साथ कुकीज़ जोड़ना

आप कुकीज़ जोड़ सकते हैं जो समाप्त हो जाती हैं। एक कुकी जोड़ने के लिए, जो समाप्त हो रही है, बस एक वस्तु को उस समय समाप्त होने वाली संपत्ति 'समय सीमा' के साथ पास करें जब आप इसे समाप्त करना चाहते हैं। उदाहरण के लिए,

var koa = require('koa');
var router = require('koa-router');
var app = koa();

_.get('/', setACookie);

function *setACookie(){
   //Expires after 360000 ms from the time it is set.
	this.cookies.set('name', 'value', { 
      httpOnly: false, expires: 360000 + Date.now() });
}

var _ = router();

app.use(_.routes());
app.listen(3000);

मौजूदा कुकीज़ हटाना

कुकी को अनसेट करने के लिए, बस कुकी को खाली स्ट्रिंग पर सेट करें। उदाहरण के लिए, यदि आपको नामित कुकी को साफ़ करने की आवश्यकता हैfoo, निम्न कोड का उपयोग करें।

var koa = require('koa');
var router = require('koa-router');
var app = koa();

_.get('/', setACookie);

function *setACookie(){
   //Expires after 360000 ms from the time it is set.
   this.cookies.set('name', '');
}

var _ = router();

app.use(_.routes());
app.listen(3000);

इससे उक्त कुकी को परेशान किया जाएगा। ध्यान दें कि आपको छोड़ देना चाहिएHttpOnly क्लाइंट साइड कोड में कुकी का उपयोग न करने पर विकल्प सही हो।

HTTP स्टेटलेस है, इसलिए किसी अन्य अनुरोध के लिए अनुरोध को संबद्ध करने के लिए, आपको HTTP अनुरोधों के बीच उपयोगकर्ता डेटा को संग्रहीत करने के लिए एक तरीका चाहिए। कुकीज़ और URL पैरामीटर क्लाइंट और सर्वर के बीच डेटा परिवहन के लिए उपयुक्त तरीके हैं। हालांकि, वे दोनों ग्राहक पक्ष में पठनीय हैं। सत्र वास्तव में इस समस्या को हल करते हैं। आप क्लाइंट को एक आईडी प्रदान करते हैं और यह उस आईडी का उपयोग करते हुए आगे के सभी अनुरोध करता है। क्लाइंट से जुड़ी जानकारी इस आईडी से जुड़े सर्वर पर संग्रहीत होती है।

हमें कोआ-सत्र की आवश्यकता होगी, इस प्रकार इसका उपयोग करके स्थापित करें -

npm install --save koa-session

हम डाल देंगे koa-sessionजगह में बीचवाला। इस उदाहरण में, हम सत्रों को संग्रहीत करने के लिए RAM का उपयोग करेंगे। उत्पादन वातावरण में इसका उपयोग कभी न करें। सत्र मिडलवेयर सब कुछ संभालता है, अर्थात सत्र बनाना, सत्र कुकी की स्थापना, और सत्र वस्तु को संदर्भ वस्तु में बनाना।

जब भी हम फिर से उसी क्लाइंट से एक अनुरोध करते हैं, तो हमारे पास उनके सत्र की जानकारी हमारे पास संग्रहीत होगी (यह देखते हुए कि सर्वर को पुनरारंभ नहीं किया गया था)। हम इस सत्र ऑब्जेक्ट में अधिक गुण जोड़ सकते हैं। निम्नलिखित उदाहरण में, हम एक ग्राहक के लिए एक दृश्य काउंटर बनाएंगे।

var session = require('koa-session');
var koa = require('koa');
var app = koa();

app.keys = ['Shh, its a secret!'];
app.use(session(app));  // Include the session middleware

app.use(function *(){
   var n = this.session.views || 0;
   this.session.views = ++n;
   
   if(n === 1)
      this.body = 'Welcome here for the first time!';
   else
      this.body = "You've visited this page " + n + " times!";
})

app.listen(3000);

उपरोक्त कोड क्या है, जब कोई उपयोगकर्ता साइट पर जाता है, तो यह उपयोगकर्ता के लिए एक नया सत्र बनाता है और कुकी प्रदान करता है। अगली बार जब उपयोगकर्ता आता है, तो कुकी की जाँच की जाती है और उसके अनुसार पेज_व्यू सत्र चर अपडेट किया जाता है।

अब अगर आप ऐप चलाते हैं और जाते हैं localhost:3000, आपको निम्न प्रतिक्रिया मिलेगी।

यदि आप पृष्ठ को फिर से देखते हैं, तो पृष्ठ काउंटर बढ़ जाएगा। इस स्थिति में, पृष्ठ को 12 बार ताज़ा किया गया था।

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

हम एक बहुत ही मूल प्रमाणीकरण प्रणाली बनाएंगे जिसका उपयोग करेंगे Basic HTTP Authentication। यह अभिगम नियंत्रण को लागू करने का सबसे सरल संभव तरीका है क्योंकि इसके लिए कुकीज़, सत्र या किसी अन्य चीज़ की आवश्यकता नहीं होती है। इसका उपयोग करने के लिए, ग्राहक को प्रत्येक अनुरोध के साथ प्राधिकरण शीर्षलेख भेजना होगा। उपयोगकर्ता नाम और पासवर्ड एन्क्रिप्ट नहीं किए गए हैं, लेकिन निम्नलिखित की तरह एक ही स्ट्रिंग में संक्षिप्त हैं।

username:password

यह स्ट्रिंग Base64 के साथ एन्कोडेड है, और बेसिक शब्द को इस मान से पहले रखा गया है। उदाहरण के लिए, यदि आपका उपयोगकर्ता नाम आयुष और पासवर्ड भारत है, तो स्ट्रिंग"Ayush:India" प्राधिकरण शीर्षलेख में एन्कोडेड के रूप में भेजा जाएगा।

Authorization: Basic QXl1c2g6SW5kaWE=

अपने कोए ऐप में इसे लागू करने के लिए, आपको कोआ-बेसिक-नॉर्थवेयर मिडलवेयर की आवश्यकता होगी। इसका उपयोग कर स्थापित करें -

$ npm install --save koa-basic-auth

अब अपनी app.js फ़ाइल खोलें और उसमें निम्न कोड डालें।

//This is what the authentication would be checked against
var credentials = { name: 'Ayush', pass: 'India' }

var koa = require('koa');
var auth = require('koa-basic-auth');
var _ = require('koa-router')();

var app = koa();

//Error handling middleware
app.use(function *(next){
   try {
      yield next;
   } catch (err) {
      if (401 == err.status) {
         this.status = 401;
         this.set('WWW-Authenticate', 'Basic');
         this.body = 'You have no access here';
      } else {
         throw err;
      }
   }
});

// Set up authentication here as first middleware. 
// This returns an error if user is not authenticated.
_.get('/protected', auth(credentials), function *(){
   this.body = 'You have access to the protected area.';
   yield next;
});

// No authentication middleware present here.
_.get('/unprotected', function*(next){
   this.body = "Anyone can access this area";
   yield next;
});

app.use(_.routes());
app.listen(3000);

हमने प्रमाणीकरण संबंधी सभी त्रुटियों को संभालने के लिए मिडिलवेयर को संभालने में त्रुटि पैदा की है। फिर, हमने 2 मार्ग बनाए हैं -

  • /protected- यह मार्ग केवल तभी एक्सेस किया जा सकता है जब उपयोगकर्ता सही प्रमाणीकरण हेडर भेजता है। अन्य सभी के लिए, यह एक त्रुटि देगा।

  • /unprotected - यह मार्ग प्रमाणीकरण के साथ या बिना किसी के भी द्वारा पहुँचा जा सकता है।

अब यदि आप प्रमाणीकरण हेडर या गलत क्रेडेंशियल्स के बिना / संरक्षित करने के लिए अनुरोध भेजते हैं, तो आपको एक त्रुटि मिलेगी। उदाहरण के लिए,

$ curl https://localhost:3000/protected

आपको प्रतिक्रिया इस प्रकार मिलेगी -

HTTP/1.1 401 Unauthorized
WWW-Authenticate: Basic
Content-Type: text/plain; charset=utf-8
Content-Length: 28
Date: Sat, 17 Sep 2016 19:05:56 GMT
Connection: keep-alive

Please authenticate yourself

हालाँकि, सही क्रेडेंशियल्स के साथ, आपको अपेक्षित प्रतिक्रिया मिलेगी। उदाहरण के लिए,

$ curl -H "Authorization: basic QXl1c2g6SW5kaWE=" https://localhost:3000/protected -i

आपको प्रतिक्रिया इस प्रकार मिलेगी -

HTTP/1.1 200 OK
Content-Type: text/plain; charset=utf-8
Content-Length: 38
Date: Sat, 17 Sep 2016 19:07:33 GMT
Connection: keep-alive

You have access to the protected area.

/ असुरक्षित मार्ग अभी भी सभी के लिए सुलभ है।

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

सर्वर से प्रतिक्रियाएं भेजते समय, यदि संपीड़न का उपयोग किया जाता है, तो यह लोड समय में काफी सुधार कर सकता है। हम नामक एक मिडलवेयर का उपयोग करेंगेkoa-compress उचित हेडर सेट करने के साथ-साथ फाइलों के संपीड़न की देखभाल करना।

आगे बढ़ो और उपयोग कर मिडलवेयर स्थापित करें -

$ npm install --save koa-compress

अब आपकी app.js फ़ाइल में, निम्न कोड जोड़ें -

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app //Equivalent to app.use(pug)
});

app.use(compress({
   filter: function (content_type) {
      return /text/i.test(content_type)
   },
   threshold: 2048,
   flush: require('zlib').Z_SYNC_FLUSH
}));

var _ = router(); //Instantiate the router

_.get('/', getRoot);

function *getRoot(next){
   this.render('index');
}

app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

यह हमारे संपीड़न मिडिलवेयर को जगह देता है। फ़िल्टर विकल्प एक फ़ंक्शन है जो प्रतिक्रिया सामग्री प्रकार की जांच करता है कि यह तय किया जाए कि क्या संपीड़ित करना है। थ्रेसहोल्ड विकल्प सेक करने के लिए बाइट्स में न्यूनतम प्रतिक्रिया आकार है। यह सुनिश्चित करता है कि हम हर छोटी प्रतिक्रिया को संकुचित न करें।

निम्नलिखित संपीड़न के बिना एक प्रतिक्रिया है।

निम्नलिखित संपीड़न के साथ इसी तरह की प्रतिक्रिया है।

यदि आप नीचे के आकार के टैब को देखते हैं, तो आप दोनों के बीच अंतर को बहुत अच्छी तरह से देख सकते हैं। जब हम फ़ाइलों को संपीड़ित करते हैं, तो 150% से अधिक सुधार होता है।

कैशिंग पुन: प्रयोज्य प्रतिक्रियाओं को संग्रहीत करने के लिए शब्द है, ताकि बाद में अनुरोध तेजी से हो सकें। हर ब्राउज़र एक HTTP कैश के कार्यान्वयन के साथ जहाज करता है। हमें केवल यह सुनिश्चित करना है कि प्रत्येक सर्वर प्रतिक्रिया ब्राउज़र को निर्देश देने के लिए सही HTTP हेडर निर्देश प्रदान करती है कि कब और कितनी देर तक ब्राउज़र द्वारा प्रतिक्रिया को कैश किया जा सकता है।

अपने वेब ऐप्स में कैशिंग शामिल करने के कुछ लाभ निम्नलिखित हैं -

  • आपके नेटवर्क की लागत कम हो जाती है। यदि आपकी सामग्री कैश की गई है, तो आपको प्रत्येक बाद के अनुरोध के लिए इसे कम भेजना होगा।

  • आपकी वेबसाइट की गति और प्रदर्शन बढ़ जाता है।

  • यदि आपका ग्राहक ऑफ़लाइन है तो भी आपकी सामग्री उपलब्ध कराई जा सकती है।

हम अपने ऐप में कैशिंग लागू करने के लिए कोआ-स्टेटिक-कैश मिडलवेयर का उपयोग करेंगे। इन मिडलवेयर का उपयोग करके स्थापित करें -

$ npm install --save koa-static-cache

अपनी app.js फ़ाइल पर जाएं और इसमें निम्न कोड जोड़ें।

var koa = require('koa');
var app = koa();

var path = require('path');
var staticCache = require('koa-static-cache');

app.use(staticCache(path.join(__dirname, 'public'), {
   maxAge: 365 * 24 * 60 * 60  //Add these files to caches for a year
}))

app.listen(3000);

koa-static-cacheमिडलवेयर का उपयोग क्लाइंट साइड पर सर्वर प्रतिक्रियाओं को कैश करने के लिए किया जाता है। cache-controlहेडर कैश ऑब्जेक्ट को इनिशियलाइज़ करते समय हमारे द्वारा उपलब्ध कराए गए विकल्पों के अनुसार सेट किया जाता है। हमने इस कैश्ड रिस्पांस का समय 1 वर्ष निर्धारित किया है। फ़ाइल के कैश होने से पहले और बाद में हमने जो अनुरोध भेजा है उसकी तुलना निम्नलिखित है।

इस फ़ाइल को कैश करने से पहले, लौटा हुआ स्थिति कोड 200 था, जो ठीक है। प्रतिक्रिया शीर्षकों में सामग्री को कैश किए जाने के संबंध में कई जानकारी थी और ए भी दी थीETag सामग्री के लिए।

अगली बार जब अनुरोध भेजा गया, तो इसे ETtag के साथ भेजा गया। चूँकि हमारी सामग्री सर्वर पर नहीं बदली गई थी, इसलिए इसकी संगत ETag भी वही रही और ग्राहक को बताया गया कि इसकी जो प्रति है वह स्थानीय स्तर पर अद्यतित है, जो सर्वर प्रदान करेगा और अनुरोध के बजाय स्थानीय का उपयोग करना चाहिए। फिर।

Note- किसी भी कैश्ड फ़ाइल को अमान्य करने के लिए, आपको बस उसका फ़ाइल नाम बदलने और उसके संदर्भ को अपडेट करने की आवश्यकता है। यह सुनिश्चित करेगा कि आपके पास क्लाइंट को भेजने के लिए एक नई फाइल है और क्लाइंट इसे कैश से वापस लोड नहीं कर सकता है।

हम अनुरोध प्राप्त कर रहे हैं, लेकिन उन्हें कहीं भी संग्रहीत नहीं कर रहे हैं। डेटा स्टोर करने के लिए हमें एक डेटाबेस की आवश्यकता होती है। हम एक प्रसिद्ध NoSQL डेटाबेस का उपयोग करेंगेMongoDB। Mongo के बारे में स्थापित करने और पढ़ने के लिए, इस लिंक पर जाएं।

कोआ के साथ मोंगो का उपयोग करने के लिए, हमें नोड के लिए एक क्लाइंट एपीआई की आवश्यकता है। वहाँ हमारे लिए कई विकल्प हैं, हालांकि इस ट्यूटोरियल हम करने के लिए रह सकते हैं के लिए कर रहे हैं नेवला । Mongoose का उपयोग किया जाता हैdocument modelingMongoDB के लिए नोड में। दस्तावेज़ मॉडलिंग का मतलब है कि, हम एक निर्माण करेंगेModel (ज्यादा पसंद है class दस्तावेज़-उन्मुख प्रोग्रामिंग में), और फिर हम उत्पादन करेंगे documents इस मॉडल का उपयोग करना (जैसे हम बनाते हैं documents of a classOOP में)। हमारे सभी प्रसंस्करण इन "दस्तावेजों" पर किए जाएंगे, फिर अंत में, हम इन दस्तावेजों को अपने डेटाबेस में लिखेंगे।

मानगो की स्थापना

अब जब हमने Mongo को स्थापित किया है, तो हम mongoose स्थापित करते हैं, उसी तरह हम अपने अन्य नोड पैकेजों को स्थापित कर रहे हैं।

$ npm install --save mongoose

इससे पहले कि हम आम का उपयोग करना शुरू करें, हमें मोंगो शेल का उपयोग करके एक डेटाबेस बनाना होगा। एक नया डेटाबेस बनाने के लिए, अपना टर्मिनल खोलें और "मोंगो" डालें। एक मैंगो शेल शुरू होगा, निम्नलिखित दर्ज करें।

use my_db

आपके लिए एक नया डेटाबेस बनाया जाएगा। जब भी आप मैंगो खोल खोलते हैं, तो यह "परीक्षण" डीबी के लिए डिफ़ॉल्ट होगा और आपको ऊपर के समान कमांड का उपयोग करके अपने डेटाबेस में बदलना होगा।

Mongoose का उपयोग करने के लिए, हमें अपनी app.js फ़ाइल में इसकी आवश्यकता होगी और फिर mongodb पर चलने वाली mongod सेवा से कनेक्ट करें: // localhost

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

app.use(_.routes());
app.listen(3000);

अब हमारा ऐप हमारे डेटाबेस से जुड़ा हुआ है, चलो एक नया मॉडल बनाते हैं। यह मॉडल हमारे डेटाबेस में एक संग्रह के रूप में कार्य करेगा। एक नया मॉडल बनाने के लिए, किसी भी मार्ग को परिभाषित करने से पहले, निम्न कोड का उपयोग करें।

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

app.use(_.routes());
app.listen(3000);

उपरोक्त कोड एक व्यक्ति के लिए स्कीमा को परिभाषित करता है और इसका उपयोग एक मॉडल बनाने के लिए किया जाता है Person

सेविंग डॉक्यूमेंट्स

अब हम एक नया html फॉर्म बनाएंगे, जिसमें किसी व्यक्ति का विवरण होगा और उसे हमारे डेटाबेस में सेव किया जाएगा। फ़ॉर्म बनाने के लिए, निम्नलिखित सामग्री के साथ व्यू डायरेक्टरी में person.pug नामक एक नई व्यू फ़ाइल बनाएँ।

html
   head
      title Person
   body
      form(action = "/person", method = "POST")
         div
            label(for = "name") Name: 
            input(name = "name")
         br
         div
            label(for = "age") Age: 
            input(name = "age")
         br
         div
            label(for = "nationality") Nationality: 
            input(name = "nationality")
         br
         button(type = "submit") Create new person

इस दस्तावेज़ को रेंडर करने के लिए index.js में एक नया प्राप्त मार्ग भी जोड़ें।

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.get('/person', getPerson);

function *getPerson(next){
   this.render('person');
   yield next;
}

app.use(_.routes());
app.listen(3000);

लोकलहोस्ट पर जाएं: 3000 / व्यक्ति यह जांचने के लिए कि क्या हमारा फॉर्म सही प्रदर्शित हो रहा है। ध्यान दें कि यह सिर्फ UI है, यह अभी तक काम नहीं कर रहा है। इसी से हमारा रूप दिखता है।

अब हम '/ व्यक्ति' पर एक पोस्ट रूट हैंडलर को परिभाषित करेंगे जो इस अनुरोध को संभाल लेगा।

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.post('/person', createPerson);

function *createPerson(next){
   var self = this;
   var personInfo = self.request.body; //Get the parsed information
   
   if(!personInfo.name || !personInfo.age || !personInfo.nationality){
      self.render(
         'show_message', {message: "Sorry, you provided wrong info", type: "error"});
   } else {
      var newPerson = new Person({
         name: personInfo.name,
         age: personInfo.age,
         nationality: personInfo.nationality
      });
      yield newPerson.save(function(err, res) {
         if(err)
            self.render('show_message', 
               {message: "Database error", type: "error"});
         else
            self.render('show_message', 
               {message: "New person added", type: "success", person: personInfo});
      });
   }
}

app.use(_.routes());
app.listen(3000);

उपरोक्त कोड में, यदि हमें कोई खाली फ़ील्ड मिलती है या कोई फ़ील्ड नहीं मिलती है, तो हम एक त्रुटि प्रतिक्रिया भेजेंगे। हालाँकि, यदि हमें एक अच्छी तरह से निर्मित दस्तावेज़ प्राप्त होता है, तो हम एक व्यक्तिगत दस्तावेज़ मॉडल से बनाते हैं और इसे अपने डीबी के उपयोग से बचाते हैंnewPerson.save()समारोह। यह मानस में परिभाषित किया गया है और एक कॉलबैक को तर्क के रूप में स्वीकार करता है। इस कॉलबैक में दो तर्क हैं,error तथा response। यह show_message दृश्य प्रदान करेगा, इसलिए हमें इसे भी बनाने की आवश्यकता है।

इस मार्ग से प्रतिक्रिया दिखाने के लिए, हमें एक बनाने की भी आवश्यकता होगी show_messageराय। निम्नलिखित कोड के साथ एक नया दृश्य बनाएं।

html
   head
      title Person
   body
      if(type = "error")
         h3(style = "color:red") #{message}
      else
         h3 New person, name: 
            #{person.name}, age: 
            #{person.age} and nationality: 
            #{person.nationality} added!

निम्नलिखित प्रतिक्रिया हमें फॉर्म (show_message.pug) को सफलतापूर्वक सबमिट करने पर प्राप्त होती है।

अब हमारे पास व्यक्तियों को बनाने के लिए एक इंटरफ़ेस है!

पुनः प्राप्त करने के दस्तावेज

दस्तावेज़ प्राप्त करने के लिए मोंगोज़ बहुत सारे कार्य प्रदान करता है, हम उनमें से तीन पर ध्यान केंद्रित करेंगे। ये सभी फ़ंक्शन अंतिम पैरामीटर के रूप में कॉलबैक भी लेते हैं, और फ़ंक्शन को बचाने की तरह, उनके तर्क त्रुटि और प्रतिक्रिया हैं।

तीन कार्य हैं -

Model.find (स्थितियां, कॉलबैक)

यह फ़ंक्शन सभी ऑब्जेक्ट्स को ऑब्जेक्ट ऑब्जेक्ट में फ़ील्ड से मेल खाता है। मानगो में इस्तेमाल किए जाने वाले समान ऑपरेटर भी आम में काम करते हैं। उदाहरण के लिए, यह सभी दस्तावेजों को व्यक्तियों के संग्रह से प्राप्त करेगा।

Person.find(function(err, response){
   console.log(response);
});

यह उन सभी दस्तावेज़ों को प्राप्त करेगा जहाँ फ़ील्ड का नाम "आयुष" है और उम्र 20 है।

Person.find({name: "Ayush", age: 20}, 
   function(err, response){
      console.log(response);
   });

हम अपनी जरूरत के हिसाब से अपनी जरूरत के मुताबिक प्रक्षेपण भी दे सकते हैं। उदाहरण के लिए, यदि हम केवल चाहते हैंnames लोगों की nationalityहै "भारतीय" , हम का उपयोग करें -

Person.find({nationality: "Indian"}, 
   "name", function(err, response) {
      console.log(response);
   });

Model.findOne (स्थितियां, कॉलबैक)

यह कार्य हमेशा एक एकल, सबसे अधिक प्रासंगिक दस्तावेज़ प्राप्त करता है। इसमें Model.find () के समान सटीक तर्क हैं।

Model.findById (आईडी, कॉलबैक)

यह फ़ंक्शन लेता है _id(प्रथम द्वारा परिभाषित) पहले तर्क के रूप में, एक वैकल्पिक प्रक्षेपण स्ट्रिंग और प्रतिक्रिया को संभालने के लिए एक कॉलबैक। उदाहरण के लिए,

Person.findById("507f1f77bcf86cd799439011", 
   function(err, response){
      console.log(response);
   });

सभी लोगों के रिकॉर्ड देखने के लिए एक मार्ग बनाएं।

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.get('/people', getPeople);
function *getPeople(next){
   var self = this;
   
   yield Person.find(function(err, response){
      self.body = response;
   });
}
app.use(_.routes());
app.listen(3000);

अद्यतन दस्तावेज़

दस्तावेज़ अद्यतन करने के लिए Mongoose तीन कार्य प्रदान करता है।

Model.update (स्थिति, अपडेट, कॉलबैक)

यह फ़ंक्शन एक शर्त लेता है और ऑब्जेक्ट को इनपुट के रूप में अपडेट करता है और संग्रह में शर्तों से मेल खाने वाले सभी दस्तावेजों में परिवर्तन लागू करता है। उदाहरण के लिए, निम्नलिखित कोड राष्ट्रीयता "अमेरिकी" रखने के लिए सभी व्यक्ति दस्तावेजों को अपडेट करेगा।

Person.update({age: 25},
   {nationality: "American"}, 
   function(err, response){
      console.log(response);
   });

Model.findOneAndUpdate (स्थिति, अपडेट, कॉलबैक)

जैसा कहता है वैसा ही करता है। क्वेरी के आधार पर एक दस्तावेज़ पाता है और दूसरे तर्क के अनुसार अपडेट करता है। यह अंतिम तर्क के रूप में कॉलबैक भी लेता है। उदाहरण के लिए,

Person.findOneAndUpdate({name: "Ayush"}, 
   {age: 40}, 
   function(err, response){
      console.log(response);
   });

Model.findByIdAndUpdate (आईडी, अपडेट, कॉलबैक)

यह फ़ंक्शन अपनी आईडी द्वारा पहचाने गए एकल दस्तावेज़ को अपडेट करता है। उदाहरण के लिए,

Person.findByIdAndUpdate("507f1f77bcf86cd799439011", 
   {name: "James"}, 
   function(err, response){
      console.log(response);
   });

लोगों को अपडेट करने के लिए एक मार्ग बनाते हैं। यह आईडी के साथ PUT रूट होगा जो पेलोड में पैरामीटर और विवरण के रूप में होगा।

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();
var mongoose = require('mongoose');

mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.put('/people/:id', updatePerson);

function *updatePerson() {
   var self = this;
   yield Person.findByIdAndUpdate(self.params.id, 
      {$set: {self.request.body}}, function(err, response){
      
      if(err) {
         self.body = {
            message: "Error in updating person with id " + self.params.id};
      } else {
         self.body = response;
      }
   });
}

app.use(_.routes());
app.listen(3000);

इस मार्ग का परीक्षण करने के लिए, अपने टर्मिनल में निम्नलिखित दर्ज करें (आईडी को अपने बनाए गए लोगों से आईडी के साथ बदलें)।

curl -X PUT --data "name = James&age = 20&nationality = American" https://localhost:3000/people/507f1f77bcf86cd799439011

यह उपरोक्त विवरण के साथ मार्ग में प्रदान किए गए आईडी से जुड़े दस्तावेज़ को अपडेट करेगा।

दस्तावेज़ हटाना

हमने कवर किया है Create, Read और Update, अब हम देखेंगे कि दस्तावेज़ों को हटाने के लिए मैंगोज़ का उपयोग कैसे किया जा सकता है। यहां तीन फ़ंक्शन हैं, बिल्कुल अपडेट की तरह।

Model.remove (स्थिति, [कॉलबैक])

यह फ़ंक्शन इनपुट के रूप में एक शर्त वस्तु लेता है और शर्तों से मेल खाते सभी दस्तावेजों को हटा देता है। उदाहरण के लिए, यदि हमें 20 वर्ष की आयु के सभी लोगों को हटाने की आवश्यकता है,

Person.remove({age:20});

Model.findOneAndRemove (स्थिति, [कॉलबैक])

यह कार्य एक हटाता है single, शर्तों वस्तु के अनुसार सबसे प्रासंगिक दस्तावेज़। उदाहरण के लिए,

Person.findOneAndRemove({name: "Ayush"});

Model.findByIdAndRemove (आईडी, [कॉलबैक])

यह फ़ंक्शन अपनी आईडी द्वारा पहचाने गए एकल दस्तावेज़ को हटा देता है। उदाहरण के लिए,

Person.findByIdAndRemove("507f1f77bcf86cd799439011");

अब अपने डेटाबेस से लोगों को हटाने के लिए एक मार्ग बनाते हैं।

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.delete('/people/:id', deletePerson);
function *deletePerson(next){
   var self = this;
   yield Person.findByIdAndRemove(self.params.id, function(err, response){
      if(err) {
         self.body = {message: "Error in deleting record id " + self.params.id};
      } else {
         self.body = {message: "Person with id " + self.params.id + " removed."};
      }
   });
}

app.use(_.routes());
app.listen(3000);

इसका परीक्षण करने के लिए, निम्नलिखित कर्ल कमांड का उपयोग करें -

curl -X DELETE https://localhost:3000/people/507f1f77bcf86cd799439011

यह दिए गए संदेश के साथ दिए गए आईडी से व्यक्ति को हटा देगा। -

{message: "Person with id 507f1f77bcf86cd799439011 removed."}

यह बताता है कि हम MongoDB, mongoose और Koa का उपयोग करके सरल CRUD एप्लिकेशन कैसे बना सकते हैं। आगे मानगो का पता लगाने के लिए, एपीआई डॉक्स पढ़ें ।

मोबाइल एप्लिकेशन, सिंगल पेज एप्लिकेशन बनाने के लिए, AJAX कॉल का उपयोग करें और ग्राहकों को डेटा प्रदान करें, आपको एपीआई की आवश्यकता होगी। इन APIs और समापन बिंदुओं की संरचना और नाम कैसे करें की एक लोकप्रिय स्थापत्य शैली कहा जाता हैREST(Representational Transfer State)। HTTP 1.1 को REST सिद्धांतों को ध्यान में रखते हुए डिजाइन किया गया था। द्वारा शुरू किया गया थाRoy Fielding 2000 में अपने पेपर फील्डिंग शोध प्रबंध में।

RESTful URI और विधियाँ हमें लगभग सभी जानकारी प्रदान करती हैं जिन्हें हमें अनुरोध करने की आवश्यकता होती है। निम्न तालिका संक्षेप में बताती है कि विभिन्न क्रियाओं का उपयोग कैसे किया जाना चाहिए और URI का नाम कैसे होना चाहिए। हम अंत में एक मूवी एपीआई बना रहे हैं, तो आइए चर्चा करें कि यह कैसे संरचित होगा।

तरीका यूआरआई विवरण समारोह
प्राप्त /चलचित्र सुरक्षित, कछुआ सभी फिल्मों की सूची और उनका विवरण प्राप्त करता है
प्राप्त / फिल्मों / 1234 सुरक्षित, कछुआ मूवी आईडी 1234 का विवरण मिलता है
पद /चलचित्र एन / ए विवरण के साथ एक नई फिल्म बनाता है। प्रतिक्रिया में इस नए बनाए गए संसाधन के लिए URI शामिल है।
डाल / फिल्मों / 1234 idempotent मूवी आईडी 1234 को संशोधित करता है (यदि यह पहले से मौजूद नहीं है तो एक बनाता है)। प्रतिक्रिया में इस नए बनाए गए संसाधन के लिए URI शामिल है।
हटाएँ / फिल्मों / 1234 idempotent मूवी आईडी 1234 को हटा दिया जाना चाहिए, अगर यह मौजूद है। प्रतिक्रिया में अनुरोध की स्थिति होनी चाहिए।
DELETE या PUT /चलचित्र अमान्य अमान्य होना चाहिए। DELETE और PUT को निर्दिष्ट करना चाहिए कि वे किस संसाधन पर काम कर रहे हैं।

अब कोआ में इस API को बनाते है। हम JSON का उपयोग हमारे परिवहन डेटा प्रारूप के रूप में करेंगे क्योंकि जावास्क्रिप्ट में काम करना आसान है और इसमें अन्य लाभों का भार है। अपनी index.js फ़ाइल को निम्न के साथ बदलें -

INDEX.JS

var koa = require('koa');
var router = require('koa-router');
var bodyParser = require('koa-body');

var app = koa();

//Set up body parsing middleware
app.use(bodyParser({
   formidable:{uploadDir: './uploads'},
   multipart: true,
   urlencoded: true
}));

//Require the Router we defined in movies.js
var movies = require('./movies.js');

//Use the Router on the sub route /movies
app.use(movies.routes());

app.listen(3000);

अब हमारे पास अपना एप्लिकेशन सेट अप हो गया है, आइए हम एपीआई बनाने पर ध्यान केंद्रित करें। सबसे पहले Movies.js फ़ाइल सेट करें। हम फिल्मों को संग्रहीत करने के लिए डेटाबेस का उपयोग नहीं कर रहे हैं, लेकिन उन्हें मेमोरी में स्टोर कर रहे हैं, इसलिए हर बार जब सर्वर हमारे द्वारा जोड़ी गई फिल्मों को फिर से चालू करता है तो वह गायब हो जाएगा। यह आसानी से डेटाबेस या फ़ाइल (नोड एफएस मॉड्यूल का उपयोग करके) का उपयोग करके नकल की जा सकती है।

कोआ-राउटर आयात करें, एक राउटर बनाएं और मॉड्यूल.एक्सपोर्ट का उपयोग करके इसे निर्यात करें।

var Router = require('koa-router');
var router = Router({
  prefix: '/movies'
});  //Prefixed all routes with /movies

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('/', sendMovies);
function *sendMovies(next){
   this.body = movies;
   yield next;
}

बस। यह जांचने के लिए कि क्या यह ठीक काम कर रहा है, अपना ऐप चलाएं, फिर अपना टर्मिनल खोलें और दर्ज करें -

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,})', sendMovieWithId);

function *sendMovieWithId(next){
   var ctx = this;
   var currMovie = movies.filter(function(movie){
      if(movie.id == ctx.params.id){
         return true;
      }
   });
   if(currMovie.length == 1){
      this.body = currMovie[0];
   } else {
      this.response.status = 404;//Set status to 404 as movie was not found
      this.body = {message: "Not Found"};
   }
   yield next;
}

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

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}

यदि आप एक अमान्य मार्ग पर जाते हैं, तो यह एक GET त्रुटि उत्पन्न नहीं कर सकता है, जबकि यदि आप किसी मान्य मार्ग पर जाते हैं, जिसमें कोई id नहीं है, तो यह 404 त्रुटि उत्पन्न करेगा।

हमें GET मार्गों के साथ किया जाता है। अब, हम POST मार्ग पर चलते हैं।

पोस्ट रूट

POSTed डेटा को संभालने के लिए निम्न मार्ग का उपयोग करें।

router.post('/', addNewMovie);

function *addNewMovie(next){
   //Check if all fields are provided and are valid:
   if(!this.request.body.name || 
      !this.request.body.year.toString().match(/^[0-9]{4}$/g) || 
      !this.request.body.rating.toString().match(/^[0-9]\.[0-9]$/g)){
      
      this.response.status = 400;
      this.body = {message: "Bad Request"};
   } else {
      var newId = movies[movies.length-1].id+1;
      
      movies.push({
         id: newId,
         name: this.request.body.name,
         year: this.request.body.year,
         rating: this.request.body.rating
      });
      this.body = {message: "New movie created.", location: "/movies/" + newId};
   }
   yield next;
}

यह एक नई फिल्म बनाएगा और इसे मूवी चर में संग्रहीत करेगा। इस मार्ग का परीक्षण करने के लिए, अपने टर्मिनल में निम्नलिखित दर्ज करें -

curl -X POST --data "name = Toy%20story&year = 1995&rating = 8.5" 
https://localhost:3000/movies

आपको निम्न प्रतिक्रिया मिलेगी -

{"message":"New movie created.","location":"/movies/105"}

यह जाँचने के लिए कि क्या यह फ़िल्म ऑब्जेक्ट में जोड़ा गया है, फिर से / फिल्मों / 105 के लिए अनुरोध प्राप्त करें। आपको निम्न प्रतिक्रिया मिलेगी -

{"id":105,"name":"Toy story","year":"1995","rating":"8.5"}

PUT और DELETE रूट बनाने के लिए आगे बढ़ते हैं।

रूट रूट

PUT मार्ग लगभग POST मार्ग के समान है। हम उस वस्तु के लिए आईडी निर्दिष्ट करेंगे जो अपडेट / बनाई जाएगी। निम्नलिखित तरीके से मार्ग बनाएँ -

router.put('/:id', updateMovieWithId);

function *updateMovieWithId(next){
   //Check if all fields are provided and are valid:
   if(!this.request.body.name || 
      !this.request.body.year.toString().match(/^[0-9]{4}$/g) || 
      !this.request.body.rating.toString().match(/^[0-9]\.[0-9]$/g) ||
      !this.params.id.toString().match(/^[0-9]{3,}$/g)){
      
      this.response.status = 400;
      this.body = {message: "Bad Request"};
   } else {
      //Gets us the index of movie with given id.
      var updateIndex = movies.map(function(movie){
         return movie.id;
      }).indexOf(parseInt(this.params.id));
      
      if(updateIndex === -1){
         //Movie not found, create new movies.push({
            id: this.params.id,
            name: this.request.body.name,
            year: this.request.body.year,
            rating: this.request.body.rating
         });
         this.body = {message: "New movie created.", location: "/movies/" + this.params.id};    
      } else {
         //Update existing movie
         movies[updateIndex] = {
            id: this.params.id,
            name: this.request.body.name,
            year: this.request.body.year,
            rating: this.request.body.rating
         };
         this.body = {message: "Movie id " + this.params.id + " updated.", location: "/movies/" + this.params.id};
      }
   }
}

यह मार्ग उपरोक्त तालिका में निर्दिष्ट कार्य करेगा। यदि यह मौजूद है तो यह नए विवरण के साथ ऑब्जेक्ट को अपडेट करेगा। यदि यह मौजूद नहीं है, तो यह एक नई वस्तु बनाएगा। इस मार्ग का परीक्षण करने के लिए, निम्नलिखित कर्ल कमांड का उपयोग करें। यह एक मौजूदा फिल्म को अपडेट करेगा। एक नई मूवी बनाने के लिए, बस आईडी को गैर-मौजूदा आईडी में बदलें।

curl -X PUT --data "name = Toy%20story&year = 1995&rating = 8.5" 
https://localhost:3000/movies/101

प्रतिक्रिया

{"message":"Movie id 101 updated.","location":"/movies/101"}

DELETE मार्ग

डिलीट रूट बनाने के लिए निम्न कोड का उपयोग करें।

router.delete('/:id', deleteMovieWithId);

function *deleteMovieWithId(next){
   var removeIndex = movies.map(function(movie){
      return movie.id;
   }).indexOf(this.params.id); //Gets us the index of movie with given id.
   
   if(removeIndex === -1){
      this.body = {message: "Not found"};
   } else {
      movies.splice(removeIndex, 1);
      this.body = {message: "Movie id " + this.params.id + " removed."};
   }
}

उसी तरह से मार्ग का परीक्षण करें जैसा हमने दूसरों के लिए किया है। सफल विलोपन पर (उदाहरण के लिए आईडी 105), आपको मिलेगा -

{message: "Movie id 105 removed."}

अंत में, हमारी फिल्में। Js फाइल दिखती हैं -

var Router = require('koa-router');
var router = Router({
   prefix: '/movies'
});  //Prefixed all routes with /movies
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
router.get('/', sendMovies);
router.get('/:id([0-9]{3,})', sendMovieWithId);
router.post('/', addNewMovie);
router.put('/:id', updateMovieWithId);
router.delete('/:id', deleteMovieWithId);

function *deleteMovieWithId(next){
   var removeIndex = movies.map(function(movie){
      return movie.id;
   }).indexOf(this.params.id); //Gets us the index of movie with given id.
   
   if(removeIndex === -1){
      this.body = {message: "Not found"};
   } else {
      movies.splice(removeIndex, 1);
      this.body = {message: "Movie id " + this.params.id + " removed."};
   }
}

function *updateMovieWithId(next) {
   //Check if all fields are provided and are valid:
   if(!this.request.body.name ||
      !this.request.body.year.toString().match(/^[0-9]{4}$/g) ||
      !this.request.body.rating.toString().match(/^[0-9]\.[0-9]$/g) ||
      !this.params.id.toString().match(/^[0-9]{3,}$/g)){
      
      this.response.status = 400;
      this.body = {message: "Bad Request"};
   } else {
      //Gets us the index of movie with given id.
      var updateIndex = movies.map(function(movie){
         return movie.id;
      }).indexOf(parseInt(this.params.id));
      
      if(updateIndex === -1){
         //Movie not found, create new
         movies.push({
            id: this.params.id,
            name: this.request.body.name,
            year: this.request.body.year,
            rating: this.request.body.rating
         });
         this.body = {message: "New movie created.", location: "/movies/" + this.params.id};
      } else {
         //Update existing movie
            movies[updateIndex] = {
            id: this.params.id,
            name: this.request.body.name,
            year: this.request.body.year,
            rating: this.request.body.rating
         };
         this.body = {message: "Movie id " + this.params.id + " updated.", 
            location: "/movies/" + this.params.id};
      }
   }
}

function *addNewMovie(next){
   //Check if all fields are provided and are valid:
   if(!this.request.body.name ||
      !this.request.body.year.toString().match(/^[0-9]{4}$/g) ||
      !this.request.body.rating.toString().match(/^[0-9]\.[0-9]$/g)){
      
      this.response.status = 400;
      this.body = {message: "Bad Request"};
   } else {
      var newId = movies[movies.length-1].id+1;
      
      movies.push({
         id: newId,
         name: this.request.body.name,
         year: this.request.body.year,
         rating: this.request.body.rating
      });
      this.body = {message: "New movie created.", location: "/movies/" + newId};
   }
   yield next;
}
function *sendMovies(next){
   this.body = movies;
   yield next;
}
function *sendMovieWithId(next){
   var ctx = this
   
   var currMovie = movies.filter(function(movie){
      if(movie.id == ctx.params.id){
         return true;
      }
   });
   if(currMovie.length == 1){
      this.body = currMovie[0];
   } else {
      this.response.status = 404;//Set status to 404 as movie was not found
      this.body = {message: "Not Found"};
   }
   yield next;
}
module.exports = router;

यह हमारे REST API को पूरा करता है। अब आप इस सरल वास्तुशिल्प शैली और Koa का उपयोग करके अधिक जटिल अनुप्रयोग बना सकते हैं।

वेब एप्लिकेशन बनाते समय लॉगिंग काफी उपयोगी है क्योंकि वे हमें बताते हैं कि वास्तव में चीजें कहां गलत हुईं। हम उन चीजों के लिए भी संदर्भ प्राप्त करते हैं जो गलत हो गईं और उसी के लिए संभव समाधानों के साथ आ सकते हैं।

कोआ में लॉगिंग को सक्षम करने के लिए, हमें मिडलवेयर की आवश्यकता है, koa-logger। निम्न कमांड का उपयोग करके इसे स्थापित करें।

$ npm install --save-dev koa-logger

अब आपके आवेदन में, लॉगिंग को सक्षम करने के लिए निम्न कोड जोड़ें।

var logger = require('koa-logger')
var koa = require('koa')

var app = koa()
app.use(logger())

app.use(function*(){
   this.body = "Hello Logger";
})

app.listen(3000)

इस सर्वर को चलाएँ और सर्वर पर किसी भी मार्ग पर जाएँ। आपको लॉग देखना चाहिए -

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

मचान हमें आसानी से एक बनाने की अनुमति देता है skeleton for a web application। हमने मैन्युअल रूप से अपनी सार्वजनिक निर्देशिका बनाई, मिडलवेयर को जोड़ा, अलग-अलग रूट फाइलें बनाईं, आदि एक मचान उपकरण हमारे लिए इन सभी चीजों को सेट करता है ताकि हम सीधे अपने आवेदन के निर्माण के साथ शुरू कर सकें।

हम जिस स्कैफ़ोल्डर का उपयोग करेंगे उसे कहा जाता है Yeoman। यह एक मचान उपकरण है जो Node.js के लिए बनाया गया है, लेकिन इसमें कई अन्य चौखटे (जैसे फ्लास्क, रेल, django, आदि) के जनरेटर भी हैं। तुर्क को स्थापित करने के लिए, अपने टर्मिनल में निम्न कमांड दर्ज करें।

$ npm install -g yeoman

Yeoman अनुप्रयोगों को मचान करने के लिए जनरेटर का उपयोग करता है। Npm पर उपलब्ध जनरेटर की जांच करने के लिए, यहाँ पर सिर के साथ । इस ट्यूटोरियल के उद्देश्य के लिए, हम 'जनरेटर-कोआ' का उपयोग करेंगे। इस जनरेटर को स्थापित करने के लिए, अपने टर्मिनल में निम्न कमांड दर्ज करें।

$ npm install -g generator-koa

इस जनरेटर का उपयोग करने के लिए, -

yo koa

फिर यह एक निर्देशिका संरचना बनाएगा और आपके लिए निम्न फ़ाइलें बनाएगा। यह आपके लिए आवश्यक एनपीएम मॉड्यूल और बोवर घटक भी स्थापित करेगा।

create package.json
create test/routeSpec.js
create views/layout.html
create views/list.html
create public/styles/main.css
create public/scripts/.gitkeep
create controllers/messages.js
create app.js
create .editorconfig
create .jshintrc

I'm all done. Running npm install & bower install for you to install 
the required dependencies. 
If this fails, try running the command yourself.

यह जनरेटर हमारे लिए एक बहुत ही सरल संरचना बनाता है।

.
├── controllers
│   └── messages.js
├── public
|   ├── scripts
|   └── styles
|       └── main.css    
├── test
|   └── routeSpec.js
├── views
|   ├── layout.html
|   └── list.html
├── .editorconfig
├── .jshintrc
├── app.js
└── package.json

कोआ के लिए उपलब्ध कई जनरेटर का अन्वेषण करें और जो आपको सही लगे उसे चुनें। सभी जनरेटर के साथ काम करने के चरण समान हैं। आपको एक जनरेटर स्थापित करने की आवश्यकता होगी, इसे तुर्क का उपयोग करके चलाएं, यह आपसे कुछ प्रश्न पूछेगा और फिर आपके उत्तरों के आधार पर आपके आवेदन के लिए एक कंकाल तैयार करेगा।

इस ट्यूटोरियल को विकसित करते समय हमने उन संसाधनों की एक सूची दी है, जिनका हमने उपयोग किया है -

  • Koajs.com

  • Koajs - उदाहरण समुदाय द्वारा बनाए गए उदाहरणों की एक सूची

  • आधिकारिक और 3 rd पार्टी के मध्यवर्ग की सूची।

  • एक CRUD एपीआई koa.js का उपयोग करते हुए - कोआज में एक CRUD एपीआई बनाने के माध्यम से जाता है जो एक छोटा पेचकश है।

  • Koa.js क्विकस्टार्ट स्क्रेंकास्ट

  • Koa.js और जनरेटर का परिचय