सामग्री सुरक्षा नीति गाइड

इस दस्तावेज़ में, Maps JavaScript API के लिए वेबसाइट की कॉन्टेंट सुरक्षा नीति (सीएसपी) को कॉन्फ़िगर करने का तरीका बताया गया है. आखिरी उपयोगकर्ता, अलग-अलग तरह के ब्राउज़र और वर्शन का इस्तेमाल करते हैं. इसलिए, डेवलपर को इस उदाहरण को रेफ़रंस के तौर पर इस्तेमाल करने का सुझाव दिया जाता है. साथ ही, उन्हें इस उदाहरण में तब तक बदलाव करते रहना चाहिए, जब तक सीएसपी के उल्लंघन की कोई और समस्या न आ जाए.

कॉन्टेंट की सुरक्षा से जुड़ी नीति के बारे में ज़्यादा जानें.

स्ट्रिक्ट सीएसपी

हमारा सुझाव है कि सुरक्षा से जुड़े हमलों की संभावना को कम करने के लिए, अनुमति वाली सूची वाले सीएसपी के बजाय स्ट्रिक्ट सीएसपी का इस्तेमाल करें. Maps JavaScript API, नॉन्स-आधारित सख्त सीएसपी का इस्तेमाल करता है. वेबसाइटों को script और style, दोनों एलिमेंट में नॉन्स वैल्यू डालनी होगी. Maps JavaScript API, इंटरनल तौर पर ऐसा पहला एलिमेंट ढूंढेगा और एपीआई स्क्रिप्ट से डाले गए स्टाइल या स्क्रिप्ट एलिमेंट में, नॉन्स वैल्यू को लागू करेगा.

उदाहरण

यहां दिए गए उदाहरण में, एक सैंपल सीएसपी के साथ-साथ वह एचटीएमएल पेज भी दिखाया गया है जहां इसे एम्बेड किया गया है:

कॉन्टेंट की सुरक्षा के बारे में नीति का सैंपल

script-src 'nonce-{script value}' 'strict-dynamic' https: 'unsafe-eval' blob:;
img-src 'self' https://*.googleapis.com https://*.gstatic.com *.google.com *.googleusercontent.com data:;
frame-src *.google.com;
connect-src 'self' https://*.googleapis.com *.google.com https://*.gstatic.com data: blob:;
font-src https://fonts.gstatic.com;
style-src 'nonce-{style value}' https://fonts.googleapis.com;
worker-src blob:;

एचटीएमएल पेज का सैंपल

<!DOCTYPE html>
<html>
  <head>
    <link rel="stylesheet" href="style.css" nonce="{style value}">
    <style nonce="{style value}">...</style>
    ...
  </head>
  <body>
    <div id="map"></div>
    <script src="https://maps.googleapis.com/maps/api/js?key=&callback=initMap" async nonce="{script value}"></script>
    <script nonce="{script value}"> function initMap() { ... } </script>
  </body>
</html>

सीएसपी को अनुमति वाली सूची में जोड़ना

अगर आपने अनुमति वाली सूची के लिए सीएसपी सेट अप किया है, तो कृपया Google Maps डोमेन की सूची देखें. हमारा सुझाव है कि अप-टू-डेट रहने के लिए, इस दस्तावेज़ और Maps JavaScript API के रिलीज़ नोट देखें. साथ ही, ज़रूरत पड़ने पर, सेवा के किसी नए डोमेन को अनुमति वाली सूची में शामिल करें.

जिन वेबसाइटों पर Maps JavaScript API को किसी लेगसी Google APIs डोमेन (उदाहरण के लिए, maps.google.com) या किसी देश/इलाके के हिसाब से बनाए गए डोमेन (उदाहरण के लिए, maps.google.fr) से लोड किया जाता है उन्हें अपनी सीएसपी script-src सेटिंग में इन डोमेन नेम को भी शामिल करना होगा. इस बारे में यहां दिए गए उदाहरण में बताया गया है:

script-src 'self' 'unsafe-inline' 'unsafe-eval' https://*.googleapis.com https://*.gstatic.com *.google.com https://*.ggpht.com *.googleusercontent.com blob:;
img-src 'self' https://*.googleapis.com https://*.gstatic.com *.google.com  *.googleusercontent.com data:;
frame-src *.google.com;
connect-src 'self' https://*.googleapis.com *.google.com https://*.gstatic.com  data: blob:;
font-src https://fonts.gstatic.com;
style-src 'self' 'unsafe-inline' https://fonts.googleapis.com;
worker-src blob:;