सीओईपी का इस्तेमाल करने वाले डेवलपर, अब तीसरे पक्ष के ऐसे iframe एम्बेड कर सकते हैं जो सीओईपी का इस्तेमाल नहीं करते.
Chrome के 110 वर्शन से, क्रेडेंशियल के बिना iframe इस्तेमाल करने की सुविधा डिफ़ॉल्ट रूप से चालू होती है. इससे, क्रॉस-ऑरिजिन-एम्बेडर-पॉलिसी (सीओईपी) के साथ काम करने वाले डेवलपर की सबसे आम शिकायत हल हो जाती है: ऐसे तीसरे पक्ष के iframe को एम्बेड करना जो सीओईपी सेट नहीं करते.
हमें सीओईपी की ज़रूरत क्यों है
कुछ वेब एपीआई, Spectre जैसे साइड-चैनल हमलों का खतरा बढ़ाते हैं. इस जोखिम को कम करने के लिए, ब्राउज़र में ऑप्ट-इन पर आधारित आइसोलेटेड एनवायरमेंट उपलब्ध कराया जाता है. इसे क्रॉस-ऑरिजिन आइसोलेशन कहा जाता है. इसके लिए, सीओईपी को डिप्लॉय करना ज़रूरी है. क्रॉस-ऑरिजिन आइसोलेशन की मदद से, वेबसाइटें SharedArrayBuffer
, performance.measureUserAgentSpecificMemory()
, और बेहतर रिज़ॉल्यूशन वाले सटीक टाइमर जैसी खास सुविधाओं का इस्तेमाल कर सकती हैं.
क्रॉस-ऑरिजिन आइसोलेशन की सुविधा चालू करने के लिए, वेबसाइटों को ये एचटीटीपी हेडर भेजने होंगे:
Cross-Origin-Embedder-Policy: require-corp
Cross-Origin-Opener-Policy: same-origin
require-corp
के विकल्प के तौर पर, COEP:credentialless का भी इस्तेमाल किया जा सकता है. ज़्यादा जानकारी के लिए, दस्तावेज़ देखें.
सीओईपी चालू करने से जुड़ी चुनौतियां
क्रॉस-ऑरिजिन आइसोलेशन की मदद से, वेबपेजों को बेहतर सुरक्षा मिलती है. साथ ही, इसमें बेहतर सुविधाएं चालू करने की सुविधा भी मिलती है. हालांकि, सीओईपी को डिप्लॉय करना मुश्किल हो सकता है. सबसे बड़ी चुनौती यह है कि सभी क्रॉस-ऑरिजिन iframes को COEP और CORP डिप्लॉय करना होगा. उन हेडर के बिना, ब्राउज़र iframes को लोड नहीं करेगा.
क्रेडेंशियल के बिना काम करने वाला iframe
हम <iframe credentialless>
सुविधा लॉन्च कर रहे हैं. इससे, ऐसे तीसरे पक्ष के iframe को एम्बेड करने में मदद मिलेगी जो सीओईपी सेट नहीं करते. <iframe>
एलिमेंट में credentialless
एट्रिब्यूट जोड़ने से, iframe किसी दूसरे खाली कॉन्टेक्स्ट से लोड होता है. खास तौर पर, यह कुकी के बिना लोड होता है. इससे सीओईपी से जुड़ी पाबंदी हटाई जा सकती है.
उदाहरण:
<iframe credentialless src="https://example.com">
यह iframe, नए इफ़ेमरल कॉन्टेक्स्ट में बनाया जाता है. साथ ही, इसका टॉप लेवल वेबसाइट से जुड़ी किसी भी कुकी का ऐक्सेस नहीं होता. इसके बजाय, यह खाली कुकी के साथ शुरू होता है. इसी तरह, LocalStorage, CacheStorage, IndexedDB वगैरह जैसे स्टोरेज एपीआई, नए इफ़ेमरल पार्टीशन में डेटा लोड और सेव करते हैं. यह पार्टीशन, मौजूदा टॉप-लेवल दस्तावेज़ और iframe के ऑरिजिन, दोनों के दायरे में आता है. टॉप-लेवल दस्तावेज़ को अनलोड करने के बाद, यह पूरा स्टोरेज खाली हो जाता है.
क्रेडेंशियल के बिना इस्तेमाल होने वाले iframe, सीओईपी के एम्बेड करने के नियमों के दायरे में नहीं आते. वे अब भी सुरक्षित हैं: हर बार नए खाली कॉन्टेक्स्ट से लोड होने की वजह से, उनमें उपयोगकर्ता के हिसाब से बनाया गया डेटा नहीं होना चाहिए. यही डेटा, हमलावर हासिल करना चाहते हैं. अगर किसी iframe में सिर्फ़ सार्वजनिक डेटा है, तो वह हमलावर के लिए काम का नहीं है.
डेमो
बिना क्रेडेंशियल वाले iframe का डेमो देखें.
अक्सर पूछे जाने वाले सवाल
क्या इस सुविधा को दूसरे ब्राउज़र भी अपनाएंगे?
- Mozilla से पोज़िशन के लिए अनुरोध: मंज़ूरी बाकी है
- वेबवर्क के लिए पोज़िशन का अनुरोध: कोई सिग्नल नहीं
- W3C टैग पोज़िशन के लिए अनुरोध: पूरा हो गया
क्या <iframe>
, क्रेडेंशियल के बिना काम करने वाले <iframe credentialless>
के अंदर नेस्ट किया गया है?
हां. इसे इनहेरिट किया जाता है. अगर किसी iframe में क्रेडेंशियल नहीं हैं, तो यह पूरे सबट्री के सभी iframe पर लागू होता है. भले ही, उनमें credentialless
एट्रिब्यूट न हो.
क्या <iframe credentialless>
से बनाए गए पॉप-अप भी क्रेडेंशियल के बिना खुलते हैं?
पॉप-अप ऐसे खुलते हैं जैसे noopener
सेट किया गया हो. इन्हें नए सामान्य टॉप-लेवल कॉन्टेक्स्ट में बनाया जाता है और इनमें क्रेडेंशियल की ज़रूरत नहीं होती. वे क्रेडेंशियल-लेस iframe से संपर्क नहीं कर सकते.
यह कैसे पता लगाया जा सकता है कि दस्तावेज़ को क्रेडेंशियल के बिना iframe में एम्बेड किया गया है?
window.credentialless
, क्रेडेंशियल के बिना काम करने वाले iframe में 'सही' होता है और अन्य मामलों में 'गलत' होता है. <iframe credentialless>
के साथ काम न करने वाले वेब ब्राउज़र में, इसकी वैल्यू undefined
है.
संसाधन
- COOP और COEP का इस्तेमाल करके, अपनी वेबसाइट को "क्रॉस-ऑरिजिन आइसोलेटेड" बनाना
- बेहतर सुविधाओं के लिए, "अलग-अलग सोर्स से आने वाले अनुरोधों को अलग-अलग सेशन में रखना" सुविधा की ज़रूरत क्यों है
- क्रॉस-ऑरिजिन आइसोलेशन चालू करने के लिए गाइड
- Android के लिए Chrome 88 और डेस्कटॉप के लिए Chrome 92 में SharedArrayBuffer से जुड़े अपडेट
COEP: credentialless
का इस्तेमाल करके, सीओआरपी हेडर के बिना क्रॉस-ऑरिजिन रिसॉर्स लोड करना- बिना क्रेडेंशियल वाला iFrame - वेब सुरक्षा | MDN