मॅनिफेस्ट V3 विस्तारांमधील सामग्री सुरक्षा धोरण त्रुटींवर मात करणे
Chrome एक्स्टेंशन विकसित करणे हा एक रोमांचक प्रकल्प असू शकतो, परंतु तो अनेकदा अनन्य आव्हानांसह येतो—विशेषतः Manifest V3 मधील अलीकडील अद्यतनांसह. एक सामान्य अडथळा विकसक चेहरा कॉन्फिगर करत आहे सामग्री सुरक्षा धोरण (CSP) बरोबर. हे धोरण सुरक्षितता राखण्यासाठी आवश्यक आहे, तरीही ते अनपेक्षित त्रुटी देखील आणू शकते जे विस्ताराला हेतूनुसार कार्य करण्यापासून प्रतिबंधित करते. 🚧
केवळ अवैध CSP कॉन्फिगरेशनमुळे Chrome वेब स्टोअरद्वारे नाकारण्यात आलेला विस्तार परिपूर्ण करण्यात दिवस घालवण्याची कल्पना करा. तुमच्या एक्स्टेंशनला बाह्य API शी सुरक्षितपणे संवाद साधण्याची आवश्यकता असते तेव्हा ही समस्या विशेषतः निराशाजनक असू शकते, जसे की `api.example.com` येथे API एंडपॉइंट. अशा बाह्य प्रवेशास अनुमती देण्यासाठी CSP सेट करण्याचा प्रयत्न करणे कदाचित सरळ वाटू शकते, परंतु अलीकडील मॅनिफेस्ट V3 बदल हे सेटअप लक्षणीयरीत्या गुंतागुंतीत करू शकतात.
या पोस्टमध्ये, आम्ही मॅनिफेस्ट V3 मधील CSP प्रमाणीकरण त्रुटी सह विकसकाच्या प्रवासात जाऊ. चाचणी आणि त्रुटीद्वारे, तुम्हाला `सामग्री_सुरक्षा_पॉलिसी` फील्ड योग्यरित्या स्वरूपित करण्याचे विविध प्रयत्न दिसतील. प्रत्येक प्रयत्न सामान्य त्रुटी आणि अधिकृत दस्तऐवजीकरणांमधून काढलेल्या उपयुक्त अंतर्दृष्टीसह, समाधानाच्या जवळ एक पाऊल प्रतिबिंबित करतो.
तुम्ही AdBlocker, उत्पादकता साधन किंवा इतर कोणतेही विस्तार तयार करत असलात तरीही, हे मार्गदर्शक CSP आवश्यकता स्पष्ट करेल, तुम्हाला प्रमाणीकरण त्रुटींचे निवारण करण्यात मदत करेल आणि तुमचा विस्तार सुरक्षित आणि सुसंगत असल्याची खात्री करेल. चला या CSP अडथळ्यांवर मात करण्याच्या चकचकीत होऊ या!
आज्ञा | वापर आणि वर्णनाचे उदाहरण |
---|---|
host_permissions | Chrome एक्स्टेंशनला मॅनिफेस्ट V3 मधील विशिष्ट बाह्य डोमेनसाठी परवानग्यांची विनंती करण्याची अनुमती देते, उदा. "host_permissions": ["https://api.example.com/*"]. हे Chrome वेब स्टोअरच्या सुरक्षा आवश्यकतांचा आदर करत बाह्य संसाधनांमध्ये सुरक्षित प्रवेश सक्षम करते. |
content_security_policy | विस्तार लोड करू शकणारे संसाधने प्रतिबंधित करण्यासाठी मॅनिफेस्टमध्ये सुरक्षा नियम परिभाषित करते. मॅनिफेस्ट V3 मध्ये, यात अनेकदा विस्तारांसाठी सँडबॉक्स धोरण निर्दिष्ट करणे समाविष्ट असते, उदा., "content_security_policy": { "extension_pages": "script-src 'self'; object-src 'self';" }. |
fetch | HTTP विनंत्या करण्यासाठी JavaScript मध्ये वापरलेली पद्धत, विशेषत: API वरून डेटा पुनर्प्राप्त करण्यासाठी सेवा कर्मचाऱ्यांसाठी उपयुक्त. येथे, बाह्य URL वरून सुरक्षितपणे डेटा आणण्यासाठी याचा वापर केला जातो, उदा., fetch('https://api.example.com/data'). |
chrome.runtime.onInstalled.addListener | Registers an event that runs when the Chrome extension is installed, enabling developers to initialize settings or perform setup tasks, e.g., chrome.runtime.onInstalled.addListener(() =>Chrome एक्स्टेंशन इंस्टॉल केल्यावर चालणाऱ्या इव्हेंटची नोंदणी करते, विकासकांना सेटिंग्ज सुरू करण्यास किंवा सेटअप कार्ये करण्यास सक्षम करते, उदा., chrome.runtime.onInstalled.addListener(() => {...}). |
chrome.runtime.onMessage.addListener | विस्तारामधील संदेश ऐकते, विविध घटकांना (उदा. सेवा कर्मचारी आणि सामग्री स्क्रिप्ट्स) संवाद साधण्यासाठी सक्षम करते. येथे, ते API कॉल ट्रिगर करण्यासाठी "fetchData" कमांडवर प्रक्रिया करते. |
sendResponse | कॉलरला API डेटा परत करण्यासाठी येथे वापरल्या जाणाऱ्या Chrome एक्स्टेंशन मेसेज-पासिंग सिस्टीममध्ये संदेश पाठवणाऱ्याला प्रतिसाद पाठवते. संदेश-आधारित आर्किटेक्चरमध्ये असिंक्रोनस प्रतिसाद व्यवस्थापित करण्यासाठी हे महत्त्वपूर्ण आहे. |
fetchMock | युनिट चाचण्यांमध्ये विनंत्या आणण्यासाठी एक चाचणी लायब्ररी. हे तुम्हाला API वरून प्रतिसादांचे अनुकरण करण्यास अनुमती देते, मजबूत चाचणी परिस्थिती सक्षम करते, उदा., fetchMock.get('https://api.example.com/data', ...). |
expect | चाई ॲसर्टेशन लायब्ररीची कमांड चाचणी परिणाम प्रमाणित करण्यासाठी वापरली जाते. API कॉल्स अपेक्षित गुणधर्म परत करतात, चाचणी विश्वसनीयता वाढवतात, उदा., expect(data).to.have.property('key') याची पुष्टी करण्यासाठी हे येथे वापरले जाते. |
allow-scripts | सँडबॉक्स CSP निर्देशामध्ये परवानग्या परिभाषित करते, फक्त स्क्रिप्ट चालवण्यास अनुमती देते. उदाहरणार्थ, "sandbox": "sandbox allow-scripts;" विस्तारामधील सँडबॉक्स्ड iframe मध्ये नियंत्रित स्क्रिप्ट अंमलबजावणी सक्षम करते. |
return true | Chrome मेसेजिंगच्या संदर्भात, हे ॲसिंक्रोनस क्रियांसाठी संदेश प्रतिसाद चॅनेल उघडे ठेवते, ज्यामुळे श्रोत्याला विलंबानंतर प्रतिसाद पाठवता येतो. विस्तारांमध्ये API कॉल वेळ व्यवस्थापित करण्यासाठी आवश्यक. |
Chrome विस्तारांसाठी सामग्री सुरक्षा धोरण कॉन्फिगरेशनमधील प्रमुख घटक समजून घेणे
कॉन्फिगरिंगमधील सामान्य आव्हानावर मात करण्यासाठी प्रदान केलेल्या उदाहरण स्क्रिप्ट्सचा उद्देश आहे सामग्री सुरक्षा धोरण (CSP) Chrome विस्तारांसाठी सेटिंग्ज, विशेषतः मॅनिफेस्ट V3 मध्ये. मॅनिफेस्ट फाइलमधील प्रथम कॉन्फिगरेशन दृष्टीकोन वापरते host_permissions विशेषता ही कमांड बाह्य डोमेन निर्दिष्ट करते ज्यात विस्तार थेट प्रवेश करू शकतो, या प्रकरणात, “https://api.example.com/*.” हे मॅनिफेस्टमध्ये जोडून, आम्ही Chrome ला सूचित करतो की आमचा विस्तार बाह्य API सह सुरक्षितपणे संवाद साधण्याची योजना आखत आहे, बाह्य डेटा आणण्यावर अवलंबून असलेल्या वैशिष्ट्यांसाठी आवश्यक आहे. दुसरा आवश्यक घटक, द सामग्री_सुरक्षा_धोरण, विस्ताराला लोड करण्याची अनुमती असलेली संसाधने प्रतिबंधित करते. येथे, Chrome च्या कडक सुरक्षा आवश्यकतांचे पालन करताना, सँडबॉक्स्ड पृष्ठांसारख्या विशिष्ट विस्तार वातावरणात कोणत्या स्क्रिप्टला परवानगी आहे हे ते परिभाषित करते.
पार्श्वभूमी सेवा कार्यकर्ता स्क्रिप्ट, background.js मध्ये प्रदान केलेली उदाहरण स्क्रिप्ट बाह्य API ला कॉल करणाऱ्या फंक्शनचा लाभ घेते. हे फंक्शन असिंक्रोनस HTTP विनंत्या हाताळण्यासाठी JavaScript fetch कमांड वापरते, जे API मधून डेटा पुनर्प्राप्त करण्यासाठी आवश्यक आहेत. जेव्हा एपीआय विनंती आवश्यक असते, तेव्हा फंक्शन नियुक्त केलेल्या एंडपॉइंटशी कनेक्ट होते आणि डेटा परत करते. ही कार्यक्षमता चिंतेचे स्वच्छ पृथक्करण राखण्यात मदत करते, जिथे प्रत्येक फंक्शन एक क्रिया करते, कोड मॉड्यूलर आणि पुन्हा वापरण्यायोग्य बनवते. ही प्रक्रिया सुलभ करण्यासाठी, स्क्रिप्ट वापरते chrome.runtime.onMessage.addListener कोडबेसच्या विविध भागांमध्ये प्रभावी संप्रेषण सुनिश्चित करण्यासाठी, एक्सटेंशनच्या इतर घटकांमध्ये—“fetchData” सारख्या विशिष्ट आज्ञा ऐकण्यासाठी.
उदाहरणामध्ये आणखी एक महत्त्वपूर्ण पैलू देखील समाविष्ट आहे: त्रुटी हाताळणे. स्क्रिप्ट API कॉलला ट्राय-कॅच ब्लॉकमध्ये गुंडाळते, जे कोणत्याही नेटवर्क-आश्रित कार्यामध्ये महत्त्वपूर्ण असते. API विनंती अयशस्वी झाल्यास, संभाव्य समस्यांबद्दल, जसे की अवैध URL किंवा नेटवर्क समस्या, विकासकाला सूचित करण्यासाठी स्क्रिप्ट एक त्रुटी संदेश लॉग करते. अशा प्रकारे त्रुटी हाताळणे हे देखील सुनिश्चित करते की विस्तार मजबूत राहील आणि एक नेटवर्क विनंती अयशस्वी झाल्यास पूर्णपणे अयशस्वी होणार नाही. संपूर्ण विस्ताराच्या कार्यक्षमतेमध्ये व्यत्यय आणण्याऐवजी, त्रुटी वेगळ्या केल्या आणि कृपापूर्वक हाताळल्या गेल्याने हे एक नितळ वापरकर्ता अनुभव प्रदान करते.
शेवटी, कोडची गुणवत्ता सुनिश्चित करण्यासाठी, युनिट चाचण्यांचा संच या कॉन्फिगरेशनची अखंडता प्रमाणित करतो. चाचणी फ्रेमवर्क वापरून, युनिट चाचणी स्क्रिप्ट API प्रतिसादांचे अनुकरण करण्यासाठी fetchMock लायब्ररी लागू करते, अशा प्रकारे चाचणीसाठी नियंत्रित वातावरण प्रदान करते. या चाचण्या हे सत्यापित करतात की CSP नियम योग्यरित्या कॉन्फिगर केले आहेत, विस्तार बाह्य संसाधनांमध्ये सुरक्षितपणे आणि हेतूनुसार प्रवेश करू शकतो की नाही याची पुष्टी करतात. यापैकी प्रत्येक चाचण्या एकाहून अधिक परिस्थितींमध्ये विस्ताराचे वर्तन तपासण्यासाठी कार्य करते, हे सुनिश्चित करते की ते Chrome आवृत्त्यांवर कार्य करते आणि CSP नियम Chrome वेब स्टोअरच्या सुरक्षा धोरणांशी सुसंगत आहेत. हा चाचणी संच असल्याने, विकासक त्यांचा विस्तार आत्मविश्वासाने अपलोड करू शकतात, हे जाणून ते Chrome च्या सुरक्षा मानकांचे पालन करते आणि सामान्य "सामग्री_सुरक्षा_पॉलिसी' साठी अवैध मूल्य" त्रुटी टाळतात. 🛠️
उपाय १: Chrome विस्तारासाठी सामग्री सुरक्षा धोरण अद्यतनित करणे (मॅनिफेस्ट V3)
स्वतंत्र स्क्रिप्ट सुरक्षा धोरण सेटअपसह manifest.json साठी कॉन्फिगरेशन समाधान
{
"manifest_version": 3,
"name": "AdBlocker Upsia",
"version": "1.0",
"permissions": ["storage"],
"host_permissions": ["https://api.example.com/*"],
"content_security_policy": {
"extension_pages": "script-src 'self'; object-src 'self';",
"sandbox": "sandbox allow-scripts; script-src 'self' https://api.example.com;"
}
}
उपाय 2: बाह्य API कॉलसाठी पार्श्वभूमी सेवा कार्यकर्ता वापरणे
सर्व्हिस वर्करमध्ये सुरक्षित API कॉल करण्यासाठी मॉड्यूलर स्क्रिप्ट
१
उपाय 3: युनिट चाचणी प्रमाणीकरणासह CSP कॉन्फिगरेशनची चाचणी करणे
सामग्री सुरक्षा धोरण कार्यक्षमतेचे प्रमाणीकरण करण्यासाठी युनिट चाचण्या
// test/cspTest.js
const { expect } = require('chai');
const { describe, it } = require('mocha');
const fetchMock = require('fetch-mock');
describe("CSP Configuration Tests", () => {
it("should allow secure API call with valid CSP", async () => {
fetchMock.get('https://api.example.com/data', { status: 200, body: { key: "value" } });
const data = await fetchDataFromAPI();
expect(data).to.have.property('key');
});
it("should throw error on invalid API call attempt", async () => {
fetchMock.get('https://api.fake.com/data', 403);
try {
await fetchDataFromAPI();
} catch (error) {
expect(error).to.exist;
}
});
});
Chrome विस्तारांमध्ये बाह्य API एकत्रीकरणासाठी CSP कॉन्फिगर करणे
सह विकसित करताना Chrome विस्तार मॅनिफेस्ट V3, बाह्य APIs सुरक्षितपणे एकत्रित करण्यासाठी अद्यतनित सामग्री सुरक्षा धोरण (CSP) नियमांची स्पष्ट समज आवश्यक आहे. मॅनिफेस्ट V3 ने सुरक्षा वाढवण्यासाठी कठोर धोरणे आणली, परंतु या बदलांमुळे काही सेटअप अधिक आव्हानात्मक बनले आहेत, विशेषत: बाह्य API सह कनेक्ट करताना https://api.example.com. सुरक्षा आणि कार्यक्षमता दोन्ही संतुलित करून विस्तारांनी या नवीन मार्गदर्शक तत्त्वांचे पालन करणे आवश्यक आहे. योग्य कॉन्फिगरेशनशिवाय, एक्स्टेंशन सबमिशन दरम्यान त्रुटी ट्रिगर करू शकते, जसे की "'content_security_policy' साठी अवैध मूल्य," जे CSP वाक्यरचना किंवा परवानग्यांसह समस्या दर्शवते.
एक्स्टेंशन लोड करू शकणाऱ्या संसाधनांवर मर्यादा घालण्यात किंवा परवानगी देण्यामध्ये CSP ची भूमिका हा येथे महत्त्वाचा घटक आहे. डायनॅमिक सामग्री वापरणारे विस्तार, जसे की डेटासाठी बाह्य API कॉल करणे, थेट अनुमत डोमेन निर्दिष्ट करणे आवश्यक आहे host_permissions फील्ड ही एंट्री एक्सटेन्शनला नियुक्त URL ला सुरक्षितपणे कनेक्ट करण्यासाठी अधिकृत करते. याव्यतिरिक्त, CSP निर्देश वेगळे करणे—जसे की संवेदनशील स्क्रिप्टसाठी सँडबॉक्स केलेले वातावरण निर्दिष्ट करणे—मॅनिफेस्ट V3 च्या अपडेट केलेल्या धोरणांसह विस्ताराचे अनुपालन सुधारू शकते. अंमलबजावणी करत आहे १ आणि script-src धोरणे विकासकांना बाह्य स्त्रोतांकडून कोणत्या प्रकारची सामग्री लोड करू शकते हे परिभाषित करण्यास सक्षम करते.
आणखी एक आवश्यक पैलू समाविष्ट आहे background service workers. मॅनिफेस्ट V3 पार्श्वभूमी पृष्ठांना सेवा कर्मचाऱ्यांसह पुनर्स्थित करते, जे एक्स्टेंशनला सतत पार्श्वभूमी प्रवेशाची आवश्यकता न ठेवता API सह सुरक्षित, चालू संप्रेषण राखण्यास अनुमती देते. सर्व्हिस वर्कर वापरून, तुम्ही API कॉल असिंक्रोनस व्यवस्थापित करू शकता आणि प्रतिसाद प्रभावीपणे हाताळू शकता. हा दृष्टिकोन केवळ मॅनिफेस्ट V3 च्या सुरक्षा सुधारणांशी संरेखित करत नाही तर विस्ताराचे कार्यप्रदर्शन देखील अनुकूल करतो, कारण सेवा कर्मचारी कमी संसाधने वापरतात. या तंत्रांची अंमलबजावणी विकासकांना Chrome च्या नवीनतम मानकांचे पालन करणारे सुरक्षित आणि कार्यक्षम विस्तार तयार करण्यास अनुमती देते. 🌐
CSP आणि Chrome विस्तार मॅनिफेस्ट V3 वरील सामान्य प्रश्न
- उद्देश काय आहे host_permissions मॅनिफेस्ट V3 मध्ये?
- द host_permissions मॅनिफेस्ट V3 मधील फील्ड हे निर्दिष्ट करते की विस्तार कोणत्या डोमेनमध्ये प्रवेश करू शकतो. बाह्य API संप्रेषणासाठी हे आवश्यक आहे.
- मी "'content_security_policy' साठी अवैध मूल्य" त्रुटी कशी टाळू?
- खात्री करा आपल्या content_security_policy मॅनिफेस्ट V3 च्या CSP नियमांचे पालन करून, योग्यरित्या परिभाषित केले आहे आणि वापरा host_permissions बाह्य डोमेनसाठी.
- सेवा कर्मचारी काय आहेत आणि ते मॅनिफेस्ट V3 मध्ये महत्त्वाचे का आहेत?
- सर्व्हिस वर्कर्सचा वापर मॅनिफेस्ट V3 मध्ये पार्श्वभूमी कार्ये हाताळण्यासाठी केला जातो, जसे की API कॉल, सतत बॅकग्राउंडमध्ये न चालता. हे संसाधनांना अनुकूल करते आणि सुरक्षितता वाढवते.
- मी मॅनिफेस्ट V3 मध्ये बाह्य स्त्रोताकडून स्क्रिप्ट लोड करू शकतो का?
- बाह्य स्रोतावरून थेट स्क्रिप्ट लोड करण्याची परवानगी नाही. वापरा fetch त्याऐवजी डेटा पुनर्प्राप्त करण्यासाठी सेवा कर्मचाऱ्यांमध्ये आदेश.
- मी माझ्या मध्ये काय समाविष्ट करावे content_security_policy बाह्य API कॉलसाठी?
- व्याख्या करा script-src आणि १ मध्ये निर्देश content_security_policy, आणि मध्ये आवश्यक URL जोडा host_permissions.
- मॅनिफेस्ट V3 साठी मी माझ्या CSP सेटअपची चाचणी कशी करू शकतो?
- CSP हेतूनुसार कार्य करत आहे याची पडताळणी करण्यासाठी Chrome ची डेव्हलपर टूल वापरा आणि विकासादरम्यान उद्भवू शकणाऱ्या कोणत्याही त्रुटी डीबग करा.
- थेट Chrome मध्ये CSP त्रुटी डीबग करण्याचा मार्ग आहे का?
- होय, Chrome DevTools उघडा, कन्सोल टॅबवर जा आणि कोणती धोरणे चुकीच्या पद्धतीने कॉन्फिगर केली आहेत हे दर्शवणाऱ्या CSP त्रुटी तपासा.
- काय आहे sandbox निर्देश, आणि मी ते कधी वापरावे?
- द sandbox निर्देशाचा वापर सुरक्षित वातावरणात सामग्री अलग ठेवण्यासाठी केला जातो. डायनॅमिक सामग्रीच्या गरजा असलेल्या विस्तारांसाठी हे सहसा आवश्यक असते.
- मॅनिफेस्ट V3 इनलाइन स्क्रिप्टला अनुमती का देत नाही?
- मॅनिफेस्ट V3 सुरक्षा सुधारण्यासाठी इनलाइन स्क्रिप्टला परवानगी देत नाही, संभाव्य दुर्भावनापूर्ण स्क्रिप्ट्सना एक्स्टेंशनमध्ये कार्यान्वित होण्यापासून प्रतिबंधित करते.
- मॅनिफेस्ट V3 परवानग्या V2 पेक्षा वेगळ्या पद्धतीने कसे हाताळते?
- मॅनिफेस्ट V3 साठी विकसकांनी वापरणे आवश्यक आहे host_permissions आणि इतर CSP निर्देश स्पष्टपणे प्रवेश गरजा घोषित करण्यासाठी, वापरकर्ता सुरक्षा वाढवतात.
- कसे करते fetch मॅनिफेस्ट V3 मधील स्क्रिप्ट लोड करण्यापेक्षा वेगळे?
- द fetch मॅनिफेस्ट V3 मध्ये प्रतिबंधित असलेल्या बाह्य स्क्रिप्ट लोड करण्यापेक्षा, सेवा कामगारांमध्ये असिंक्रोनस डेटा पुनर्प्राप्त करण्यासाठी पद्धत वापरली जाते.
क्रोम एक्स्टेंशन CSP सेटअप वर अंतिम विचार
कॉन्फिगर करत आहे सामग्री सुरक्षा धोरण मॅनिफेस्ट V3 मध्ये नवीन सुरक्षा आवश्यकतांमुळे अचूकता आवश्यक आहे. CSP चे अनुसरण करून आणि host_permissions प्रोटोकॉल, तुम्ही APIs सुरक्षितपणे समाकलित करू शकता आणि सामान्य प्रमाणीकरण त्रुटी टाळू शकता. विचारपूर्वक दृष्टिकोन ठेवून, Chrome विस्तार विकसक अधिक सुरक्षित, अधिक प्रभावी साधने तयार करू शकतात. 😊
वाक्यरचना प्रमाणीकरणापासून ते वेगवेगळ्या आवृत्त्यांमधील चाचणीपर्यंत, प्रत्येक पायरी तुमच्या विस्ताराच्या अनुपालनावर विश्वास निर्माण करते. JSON प्रमाणित करणे, कॉन्फिगरेशनची चाचणी घेणे आणि Chrome च्या दस्तऐवजीकरणाचे पुनरावलोकन करणे लक्षात ठेवा. एका ठोस सेटअपसह, तुमचा विस्तार Chrome वेब स्टोअरसाठी तयार असेल, आजच्या सुरक्षा मानकांची अखंडपणे पूर्तता करेल. 🔒
Chrome विस्तार विकासासाठी संदर्भ आणि अतिरिक्त वाचन
- Chrome एक्स्टेंशन मॅनिफेस्ट V3 आणि CSP सेटअपवरील तपशीलवार मार्गदर्शक तत्त्वांसाठी, अधिकृत Chrome विकसक दस्तऐवजीकरण पहा Chrome विस्तार मॅनिफेस्ट V3 विहंगावलोकन .
- Chrome विस्तारांमधील CSP कॉन्फिगरेशन त्रुटींचे निराकरण करण्याच्या टिपांसाठी, हे मार्गदर्शक व्यावहारिक समस्यानिवारण सल्ला देते Chrome विस्तारांसाठी सामग्री सुरक्षा धोरण .
- मॅनिफेस्ट V3 मधील CSP समस्यांचे सामुदायिक अंतर्दृष्टी आणि सामायिक निराकरणे GitHub वर आढळू शकतात Google Chrome विकसक GitHub .
- स्टॅक ओव्हरफ्लोवर मॅनिफेस्ट V3 आणि CSP सह तांत्रिक चर्चा आणि विकासक अनुभव वास्तविक-जगातील समस्या-निराकरण पद्धती प्रदान करतात Chrome विस्तार स्टॅक ओव्हरफ्लो चर्चा .