OWASP कैटगरी: MASVS-CODE: कोड क्वालिटी
खास जानकारी
वेबव्यू, Android ऐप्लिकेशन में एम्बेड किया गया ब्राउज़र कॉम्पोनेंट है. इसकी मदद से, ऐप्लिकेशन में वेब कॉन्टेंट दिखाया जा सकता है. यह ऐप्लिकेशन के यूज़र इंटरफ़ेस में एचटीएमएल, सीएसएस, और JavaScript को रेंडर करता है.
क्रॉस-ऐप्लिकेशन स्क्रिप्टिंग, आम तौर पर किसी टारगेट किए गए ऐप्लिकेशन के संदर्भ में नुकसान पहुंचाने वाले कोड को चलाने से जुड़ी होती है. इस दस्तावेज़ के मकसद के लिए, विषय को खास तौर पर, नुकसान पहुंचाने वाले JavaScript कोड को कमजोर वेबव्यू में इंजेक्ट करने तक सीमित किया जाएगा.
जब कोई ऐप्लिकेशन, वेबव्यू में नुकसान पहुंचाने वाले JavaScript को बिना पुष्टि या साफ़ किए स्वीकार करता है, तो ऐप्लिकेशन को क्रॉस-ऐप्लिकेशन स्क्रिप्टिंग का खतरा हो सकता है.
असर
हमलावर के कंट्रोल होने पर, क्रॉस-ऐप्लिकेशन स्क्रिप्टिंग के जोखिमों का फ़ायदा उठाया जा सकता है JavaScript कॉन्टेंट को जोखिम की आशंका वाले ऐप्लिकेशन के वेबव्यू में बिना पुष्टि की गई या साफ़-सफ़ाई की गई है. इस वजह से, हमलावर का दिया गया JavaScript कोड, टारगेट किए गए ऐप्लिकेशन के वेबव्यू के संदर्भ में लागू किया जाता है. इसके बाद, नुकसान पहुंचाने वाला JavaScript कोड, टारगेट किए गए ऐप्लिकेशन की अनुमतियों का इस्तेमाल कर सकता है. इससे, उपयोगकर्ता का संवेदनशील डेटा चोरी हो सकता है और खाता हाइजैक हो सकता है.
जोखिम कम करने के तरीके
JavaScript बंद करना
अगर आपके ऐप्लिकेशन के लिए JavaScript की ज़रूरत नहीं है, तो इसे बंद करने से यह पक्का किया जा सकेगा कि यह आपके ऐप्लिकेशन के लिए खतरा न बन जाए:
Kotlin
// Get the WebView Object
val webView = findViewById<WebView>(R.id.webView)
val webSettings = webView.settings
// Disable JavaScript
webSettings.javaScriptEnabled = false
Java
// Get the WebView Object
WebView webView = (WebView) findViewById(R.id.webView);
WebSettings webSettings = webView.getSettings();
// Disable JavaScript for the WebView
webSettings.setJavaScriptEnabled(false);
अगर आपके ऐप्लिकेशन को JavaScript की ज़रूरत है, तो पक्का करें कि आपके पास किसी JavaScript को वेबव्यू को भेजा गया. वेबव्यू को आर्बिट्रेरी एक्ज़ीक्यूट करने की अनुमति न दें JavaScript के बारे में निर्देश पाने के लिए, अगले सेक्शन में दिशा-निर्देश देखें.
पक्का करें कि वेबव्यू में सिर्फ़ उम्मीद के मुताबिक कॉन्टेंट लोड किया गया हो
shouldOverrideUrlLoading(), loadUrl() या
evaluateJavascript(), जैसे तरीकों का इस्तेमाल करते समय, पक्का करें कि उनमें भेजे गए सभी यूआरएल की जांच की गई हो. जैसा कि पहले बताया गया है, वेबव्यू को पास किया गया कोई भी JavaScript सिर्फ़
उम्मीद के मुताबिक डोमेन से आते हैं, इसलिए यह पुष्टि करना ज़रूरी है कि क्या लोड किया जा रहा है.
अच्छी सलाह और उदाहरणों के लिए, वेबव्यू के लिए OWASP का इनपुट की पुष्टि करने वाला दस्तावेज़ और Android की सुरक्षा से जुड़ी यह चेकलिस्ट देखें.
वेबव्यू के लिए फ़ाइल का सुरक्षित ऐक्सेस सेटिंग सेट करें
यह पक्का करना कि फ़ाइलें ऐक्सेस नहीं की जा सकतीं, आर्बिट्रेरी JavaScript को
वेबव्यू के अंदर एक्ज़ीक्यूट किया जा रहा है.नीचे दिया गया WebSettings
फ़ाइल का ऐक्सेस हासिल करते समय इन बातों पर ध्यान दिया जाता है:
- फ़ाइल का ऐक्सेस बंद करें. एपीआई लेवल 29 और उससे पहले के वर्शन में,
setAllowFileAccessडिफ़ॉल्ट रूप सेTrueपर सेट होता है. इससे लोकल फ़ाइलों को ऐक्सेस करने की अनुमति मिलती है. एपीआई लेवल 30 और उसके बाद के वर्शन में, डिफ़ॉल्ट तौर परFalseका इस्तेमाल किया जाता है. यह पक्का करने के लिए कि फ़ाइल का ऐक्सेस नहीं दिया गया है,setAllowFileAccessकोFalseपर सेट करें कॉन्टेंट का ऐक्सेस बंद करें.
setAllowContentAccessकी डिफ़ॉल्ट सेटिंगTrueहै. कॉन्टेंट के यूआरएल का ऐक्सेस, वेबव्यू को सिस्टम में इंस्टॉल किए गए कॉन्टेंट प्रोवाइडर से कॉन्टेंट लोड करने की अनुमति देता है. अगर आपके ऐप्लिकेशन को कॉन्टेंट ऐक्सेस करने की ज़रूरत नहीं है, तोsetAllowContentAccessकोFalseपर सेट करें. इससे, क्रॉस-ऐप्लिकेशन स्क्रिप्टिंग अटैक के मामले में, संभावित गलत इस्तेमाल को रोका जा सकता है.कोटलिन
kotlin webView.settings.javaScriptEnabled = false webView.settings.domStorageEnabled = true webView.settings.allowFileAccess = false webView.settings.allowContentAccess = falseअभी तक किसी भी व्यक्ति ने चेक इन नहीं किया हैJava
java webView.getSettings().setJavaScriptEnabled(false); webView.getSettings().setDomStorageEnabled(true); webView.getSettings().setAllowFileAccess(false); webView.getSettings().setAllowContentAccess(false);अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
सुरक्षित ब्राउज़िंग की सुविधा चालू करना
AndroidManifest.xml में सुरक्षित ब्राउज़िंग की सुविधा चालू करें, ताकि वेबव्यू में भेजे गए यूआरएल को फ़िशिंग या नुकसान पहुंचाने वाले डोमेन के लिए स्कैन किया जा सके.:
<meta-data android:name="android.webkit.WebView.EnableSafeBrowsing"
android:value="true" />
संसाधन
- सुरक्षित ब्राउज़िंग से जुड़ा दस्तावेज़
- वेबव्यू डेवलपर के लिए रेफ़रंस फ़ाइल
- WebView डेवलपर के लिए WebSettings का रेफ़रंस
- setAllowFileAccess डेवलपर दस्तावेज़
- setAllowContentAccess डेवलपर रेफ़रंस