⊗jsSpAXCP 258 of 294 menu

जावास्क्रिप्ट में AJAX रिक्वेस्ट्स में CORS पॉलिसी

AJAX के माध्यम से आप अन्य साइटों को रिक्वेस्ट्स (cross-origin requests) सीधे नहीं भेज सकते हैं। ऐसे रिक्वेस्ट्स CORS पॉलिसी द्वारा नियंत्रित होते हैं। संक्षेप में, इस पॉलिसी के अनुसार वह साइट, जिसे आप रिक्वेस्ट भेज रहे हैं, को उसका जवाब देने के लिए सहमत होना चाहिए। इसके लिए उसे संबंधित HTTP हैडर्स देना होगा।

चलिए व्यवहार में कोशिश करते हैं। चलिए दो टेस्ट सर्वर अलग-अलग पोर्ट्स पर चलाते हैं। पहला 3001 पर, और दूसरा 3002 पर। चलिए दूसरी साइट से पहली साइट पर एक AJAX रिक्वेस्ट भेजने की कोशिश करते हैं।

मान लीजिए कि पहली साइट निम्नलिखित रिक्वेस्ट्स प्राप्त करने के लिए तैयार है:

export default { '/handler/': function({ body }) { console.log(body); return 'success'; } }

चलिए दूसरी साइट से पहली साइट पर एक रिक्वेस्ट भेजते हैं:

button.addEventListener('click', function() { let promise = fetch('http://localhost:3001/handler/', { method: 'post', body: JSON.stringify([1, 2, 3, 4, 5]), headers: { 'Content-Type': 'application/json', }, }); });

परिणामस्वरूप रिक्वेस्ट निष्पादित नहीं होगी, और ब्राउज़र कंसोल में हम CORS पॉलिसी से संबंधित एक त्रुटि देखेंगे।

रिक्वेस्ट के निष्पादित होने के लिए, पहले सर्वर को विशेष HTTP हैडर्स देना होगा। चलिए उन्हें निर्दिष्ट करते हैं - और दूसरी साइट से रिक्वेस्ट पहली साइट पर जाने लगेगी:

export default { '/handler/': function({ body, resp }) { resp.setHeader('Access-Control-Allow-Origin', '*'); resp.setHeader('Access-Control-Allow-Headers', '*'); console.log(body); return 'success'; } }
हिन्दी
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
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें