⊗jsrxPmATDS 53 of 57 menu

थंक द्वारा रेडक्स में भेजे गए POST अनुरोध को संसाधित करना

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

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

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

आइए हमारा उत्पादों वाला एप्लिकेशन खोलें, और उसमें server.js फ़ाइल खोलें। इसमें handlers सरणी ढूंढें और इसमें POST अनुरोध के लिए एक और हैंडलर जोड़ें। यहां हम अनुरोध का बॉडी भी स्वीकार करेंगे, इसलिए कॉलबैक में हमें request पास करना होगा:

http.post('/fakeServer/products', async ({ request }) => {})

अब कर्ली ब्रेसिज़ में हम अपने कॉलबैक का कोड लिखेंगे। शुरुआत के लिए, अनुरोध डेटा निकालें और त्रुटि की स्थिति में सर्वर से प्रतिक्रिया भेजें कि हम डेटा सहेजने में असमर्थ थे और स्टेटस 500:

http.post('/fakeServer/products', async ({ request }) => { const data = await request.json() if (data.content === 'error') { await delay(ARTIFICIAL_DELAY_MS) return new HttpResponse('server save error', { status: 500, headers: { 'Content-Type': 'application/json', }, }) } })

यदि डेटा ठीक है, तो हम डेटाबेस में उस विक्रेता को id के आधार पर ढूंढेंगे जो हमारे पास अनुरोध में आया था और उस विक्रेता को data में लिख देंगे (आखिरकार, विक्रेता का डेटा भी तो सर्वर पर संग्रहीत है ;) ):

const seller = db.seller.findFirst({ where: { id: { equals: data.seller } }, }) data.seller = seller

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

data.reactions = db.reaction.create() const product = db.product.create(data)

विलंब लगाएं और हमारे कॉलबैक के लिए कोड की अंतिम पंक्ति में उत्पाद के साथ प्रतिक्रिया वापस करें:

await delay(ARTIFICIAL_DELAY_MS) return HttpResponse.json(serializeProduct(product))

इस पर हमने सर्वर के साथ पूरी तरह से समाप्त कर दिया है और अब उस पर वापस नहीं आएंगे।

वैसे, एक और उपयोगी बात। export const worker = setupWorker(...handlers) लाइन के बाद आप निम्नलिखित कोड जोड़ सकते हैं:

worker.listHandlers().forEach((handler) => { console.log(handler.info.header) })

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

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

अपना छात्रों वाला एप्लिकेशन खोलें। इसमें server.js फ़ाइल खोलें। handlers सरणी में POST अनुरोध की प्रक्रिया जोड़ें। इस अनुरोध के बॉडी में आप नए जोड़े गए छात्र का डेटा प्राप्त करेंगे।

अपने http.post के लिए कॉलबैक के बॉडी में डेटा को अनपैक करें और त्रुटि की स्थिति में उचित प्रतिक्रिया भेजें।

यदि सब ठीक है, तो डेटाबेस में प्राप्त id के आधार पर शिक्षक को ढूंढें और उसे डेटा में लिखें। डेटा में, डेटाबेस के आधार पर बनाई गई votes ऑब्जेक्ट भी लिखें।

एकत्र किए गए डेटा के आधार पर नए छात्र के साथ एक student ऑब्जेक्ट बनाएं और सर्वर प्रतिक्रिया में इसे वापस भेजें।

हिन्दी
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें