<ऐप्लिकेशन>

सिंटैक्स:
<application android:allowTaskReparenting=["true" | "false"]
             android:allowBackup=["true" | "false"]
             android:allowClearUserData=["true" | "false"]
             android:allowNativeHeapPointerTagging=["true" | "false"]
             android:appCategory=["accessibility" | "audio" | "game" |
             "image" | "maps" | "news" | "productivity" | "social" | "video"]
             android:backupAgent="string"
             android:backupInForeground=["true" | "false"]
             android:banner="drawable resource"
             android:dataExtractionRules="string resource"
             android:debuggable=["true" | "false"]
             android:description="string resource"
             android:enabled=["true" | "false"]
             android:enableOnBackInvokedCallback=["true" | "false"]
             android:extractNativeLibs=["true" | "false"]
             android:fullBackupContent="string"
             android:fullBackupOnly=["true" | "false"]
             android:gwpAsanMode=["always" | "never"]
             android:hasCode=["true" | "false"]
             android:hasFragileUserData=["true" | "false"]
             android:hardwareAccelerated=["true" | "false"]
             android:icon="drawable resource"
             android:isGame=["true" | "false"]
             android:isMonitoringTool=["parental_control" | "enterprise_management" |
             "other"]
             android:killAfterRestore=["true" | "false"]
             android:largeHeap=["true" | "false"]
             android:label="string resource"
             android:logo="drawable resource"
             android:manageSpaceActivity="string"
             android:name="string"
             android:networkSecurityConfig="xml resource"
             android:permission="string"
             android:persistent=["true" | "false"]
             android:process="string"
             android:restoreAnyVersion=["true" | "false"]
             android:requestLegacyExternalStorage=["true" | "false"]
             android:requiredAccountType="string"
             android:resizeableActivity=["true" | "false"]
             android:restrictedAccountType="string"
             android:supportsRtl=["true" | "false"]
             android:taskAffinity="string"
             android:testOnly=["true" | "false"]
             android:theme="resource or theme"
             android:uiOptions=["none" | "splitActionBarWhenNarrow"]
             android:usesCleartextTraffic=["true" | "false"]
             android:vmSafeMode=["true" | "false"] >
    . . .
</application>
इसमें शामिल है:
<manifest>
इसमें ये शामिल हो सकते हैं:
<activity>
<activity-alias>
<meta-data>
<service>
<receiver>
<profileable>
<provider>
<uses-library>
<uses-native-library>
विवरण:

ऐप्लिकेशन का एलान. इस एलिमेंट में ऐसे सब-एलिमेंट होते हैं जो ऐप्लिकेशन के हर कॉम्पोनेंट के बारे में बताते हैं. साथ ही, इसमें ऐसे एट्रिब्यूट होते हैं जो सभी कॉम्पोनेंट पर असर डाल सकते हैं.

इनमें से कई एट्रिब्यूट, जैसे कि icon, label, permission, process, taskAffinity, और allowTaskReparenting, कॉम्पोनेंट एलिमेंट के संबंधित एट्रिब्यूट के लिए डिफ़ॉल्ट वैल्यू सेट करते हैं. debuggable, enabled, description, और allowClearUserData जैसी अन्य प्रॉपर्टी, पूरे ऐप्लिकेशन के लिए वैल्यू सेट करती हैं. साथ ही, इन्हें कॉम्पोनेंट से बदला नहीं जा सकता.

एट्रिब्यूट
android:allowTaskReparenting
क्या ऐप्लिकेशन की ओर से तय की गई गतिविधियां, उन्हें शुरू करने वाले टास्क से उस टास्क पर जा सकती हैं जिसके साथ उनका अफ़िनिटी स्कोर ज़्यादा है. ऐसा तब होता है, जब उस टास्क को अगली बार सबसे ऊपर लाया जाता है. अगर उन्हें टास्क के दौरान घूमने-फिरने की अनुमति है, तो "true" चुनें. अगर उन्हें टास्क के दौरान एक ही जगह पर रहना है, तो "false" चुनें. डिफ़ॉल्ट वैल्यू "false" है.

<activity> एलिमेंट में अपना allowTaskReparenting एट्रिब्यूट होता है. यह एट्रिब्यूट, यहां सेट की गई वैल्यू को बदल सकता है.

android:allowBackup

ऐप्लिकेशन को बैकअप लेने और डेटा वापस लाने की सुविधा में शामिल होने की अनुमति देनी है या नहीं. अगर इस एट्रिब्यूट को "false" पर सेट किया जाता है, तो ऐप्लिकेशन का बैकअप कभी नहीं लिया जाता और न ही उसे कभी वापस लाया जाता है. ऐसा तब भी होता है, जब पूरे सिस्टम का बैकअप लिया जाता है. इस तरह के बैकअप से, ऐप्लिकेशन का पूरा डेटा adb का इस्तेमाल करके सेव हो जाता है. इस एट्रिब्यूट की डिफ़ॉल्ट वैल्यू "true" है.

ध्यान दें: Android 12 (एपीआई लेवल 31) या इसके बाद के वर्शन को टारगेट करने वाले ऐप्लिकेशन के लिए, यह तरीका अलग-अलग होता है. डिवाइस बनाने वाली कुछ कंपनियों के डिवाइसों पर, ऐप्लिकेशन की फ़ाइलों को एक डिवाइस से दूसरे डिवाइस पर माइग्रेट करने की सुविधा बंद नहीं की जा सकती.

हालांकि, इस एट्रिब्यूट को "false" पर सेट करके, अपने ऐप्लिकेशन की फ़ाइलों के क्लाउड-आधारित बैकअप और रीस्टोर करने की सुविधा बंद की जा सकती है. भले ही, आपका ऐप्लिकेशन Android 12 (एपीआई लेवल 31) या इसके बाद के वर्शन को टारगेट करता हो.

ज़्यादा जानकारी के लिए, Android 12 (एपीआई लेवल 31) या इसके बाद के वर्शन को टारगेट करने वाले ऐप्लिकेशन के व्यवहार में हुए बदलावों के बारे में जानकारी देने वाले पेज पर, बैकअप और वापस लाना सेक्शन देखें.

android:allowClearUserData

ऐप्लिकेशन को उपयोगकर्ता डेटा रीसेट करने की अनुमति देनी है या नहीं. इस डेटा में फ़्लैग शामिल होते हैं. जैसे, उपयोगकर्ता ने टूलटिप देखी हैं या नहीं. साथ ही, इसमें उपयोगकर्ता की पसंद के मुताबिक बनाई जा सकने वाली सेटिंग और प्राथमिकताएं भी शामिल होती हैं. इस एट्रिब्यूट की डिफ़ॉल्ट वैल्यू "true" है.

ध्यान दें: सिर्फ़ सिस्टम इमेज का हिस्सा होने वाले ऐप्लिकेशन, इस एट्रिब्यूट की वैल्यू साफ़ तौर पर बता सकते हैं. तीसरे पक्ष के ऐप्लिकेशन, अपनी मेनिफ़ेस्ट फ़ाइलों में इस एट्रिब्यूट को शामिल नहीं कर सकते.

ज़्यादा जानकारी के लिए, डेटा बैकअप की खास जानकारी देखें.

android:allowNativeHeapPointerTagging

इससे पता चलता है कि ऐप्लिकेशन, हीप पॉइंटर टैगिंग की सुविधा चालू करता है या नहीं. इस एट्रिब्यूट की डिफ़ॉल्ट वैल्यू "true" है.

ध्यान दें: इस सुविधा को बंद करने से, कोड की क्वालिटी से जुड़ी समस्या ठीक नहीं होती है. ऐसा हो सकता है कि आने वाले समय में हार्डवेयर डिवाइसों पर, यह मेनिफ़ेस्ट टैग काम न करे.

ज़्यादा जानकारी के लिए, टैग किए गए पॉइंटर देखें.

android:appCategory

इस ऐप्लिकेशन की कैटगरी के बारे में बताता है. कैटगरी का इस्तेमाल, कई ऐप्लिकेशन को एक साथ काम के ग्रुप में क्लस्टर करने के लिए किया जाता है. जैसे, बैटरी, नेटवर्क या डिस्क के इस्तेमाल की खास जानकारी देते समय. इस वैल्यू को सिर्फ़ उन ऐप्लिकेशन के लिए तय करें जो किसी खास कैटगरी में आते हैं.

यह इनमें से कोई एक कॉन्स्टेंट वैल्यू होनी चाहिए.

मानब्यौरा
accessibilityऐसे ऐप्लिकेशन जो मुख्य तौर पर सुलभता ऐप्लिकेशन होते हैं. जैसे, स्क्रीन रीडर.
audioऐसे ऐप्लिकेशन जो मुख्य तौर पर ऑडियो या संगीत के साथ काम करते हैं. जैसे, संगीत प्लेयर.
gameऐसे ऐप्लिकेशन जो मुख्य रूप से गेम हैं.
imageऐसे ऐप्लिकेशन जो मुख्य रूप से इमेज या फ़ोटो के साथ काम करते हैं. जैसे, कैमरा या गैलरी ऐप्लिकेशन.
mapsऐसे ऐप्लिकेशन जो मुख्य रूप से मैप ऐप्लिकेशन हैं. जैसे, नेविगेशन ऐप्लिकेशन.
newsऐसे ऐप्लिकेशन जो मुख्य रूप से समाचार ऐप्लिकेशन हैं. जैसे, अख़बार, मैगज़ीन या खेल-कूद से जुड़े ऐप्लिकेशन.
productivityऐसे ऐप्लिकेशन जो मुख्य रूप से प्रॉडक्टिविटी ऐप्लिकेशन हैं. जैसे, क्लाउड स्टोरेज या ऑफ़िस के काम से जुड़े ऐप्लिकेशन.
socialऐसे ऐप्लिकेशन जो मुख्य तौर पर सोशल ऐप्लिकेशन होते हैं. जैसे, मैसेजिंग, कम्यूनिकेशन, ईमेल या सोशल नेटवर्क ऐप्लिकेशन.
videoऐसे ऐप्लिकेशन जो मुख्य रूप से वीडियो या फ़िल्मों के साथ काम करते हैं. जैसे, वीडियो स्ट्रीमिंग वाले ऐप्लिकेशन.

android:backupAgent
ऐप्लिकेशन के बैकअप एजेंट को लागू करने वाली क्लास का नाम. यह BackupAgent की सबक्लास है. एट्रिब्यूट की वैल्यू, पूरी तरह क्वालिफ़ाइड क्लास का नाम होती है. जैसे, "com.example.project.MyBackupAgent". हालांकि, अगर नाम का पहला वर्ण अवधि है, तो इसे शॉर्टहैंड के तौर पर इस्तेमाल किया जा सकता है. उदाहरण के लिए, ".MyBackupAgent". इसे <manifest> एलिमेंट में दिए गए पैकेज के नाम के साथ जोड़ा जाता है.

कोई डिफ़ॉल्ट वैल्यू नहीं है. नाम सटीक होना चाहिए.

android:backupInForeground
इससे पता चलता है कि अपने-आप बैकअप लेने की सुविधा इस ऐप्लिकेशन पर काम करती है. भले ही, ऐप्लिकेशन फ़ोरग्राउंड के बराबर स्थिति में हो. ऑटो बैकअप की प्रोसेस के दौरान, सिस्टम किसी ऐप्लिकेशन को बंद कर देता है. इसलिए, इस एट्रिब्यूट का इस्तेमाल सावधानी से करें. इस फ़्लैग को "true" पर सेट करने से, ऐप्लिकेशन के चालू होने पर उसके व्यवहार पर असर पड़ सकता है.

डिफ़ॉल्ट वैल्यू "false" होती है. इसका मतलब है कि ओएस, ऐप्लिकेशन के फ़ोरग्राउंड में चलने के दौरान उसका बैक अप लेने से बचता है. जैसे, कोई ऐसा संगीत ऐप्लिकेशन जो startForeground() स्थिति में किसी सेवा का इस्तेमाल करके संगीत चला रहा हो.

android:banner
ड्रॉ करने लायक संसाधन जो इससे जुड़े आइटम के लिए, बड़ा ग्राफ़िकल बैनर उपलब्ध कराता है. इसका इस्तेमाल <application> टैग के साथ किया जाता है, ताकि सभी ऐप्लिकेशन गतिविधियों के लिए डिफ़ॉल्ट बैनर दिया जा सके. इसके अलावा, इसका इस्तेमाल <activity> टैग के साथ किया जाता है, ताकि किसी खास गतिविधि के लिए बैनर दिया जा सके.

सिस्टम, Android TV की होम स्क्रीन पर किसी ऐप्लिकेशन को दिखाने के लिए बैनर का इस्तेमाल करता है. इसलिए, इस एट्रिब्यूट की वैल्यू सिर्फ़ उन ऐप्लिकेशन के लिए दें जिनमें CATEGORY_LEANBACK_LAUNCHER इंटेंट को हैंडल करने वाली गतिविधि मौजूद हो.

इस एट्रिब्यूट को, इमेज वाली ड्रॉएबल रिसॉर्स के रेफ़रंस के तौर पर सेट किया जाता है. उदाहरण के लिए, "@drawable/banner". कोई डिफ़ॉल्ट बैनर नहीं है.

ज़्यादा जानकारी के लिए, होम स्क्रीन पर बैनर दिखाना लेख पढ़ें.

android:dataExtractionRules

ऐप्लिकेशन, इस एट्रिब्यूट को किसी एक्सएमएल रिसॉर्स पर सेट कर सकते हैं. इसमें वे नियम तय करते हैं जिनसे यह तय होता है कि बैकअप या ट्रांसफ़र के दौरान, डिवाइस से कौनसी फ़ाइलें और डायरेक्ट्री कॉपी की जा सकती हैं.

एक्सएमएल फ़ाइल के फ़ॉर्मैट के बारे में जानकारी के लिए, बैकअप और रीस्टोर लेख पढ़ें.

android:debuggable
क्या ऐप्लिकेशन को डीबग किया जा सकता है. भले ही, वह उपयोगकर्ता मोड में किसी डिवाइस पर चल रहा हो. अगर ऐसा किया जा सकता है, तो "true" और अगर ऐसा नहीं किया जा सकता, तो "false" लिखें. डिफ़ॉल्ट वैल्यू "false" है.
android:description
ऐप्लिकेशन के बारे में ऐसा टेक्स्ट जिसे उपयोगकर्ता आसानी से पढ़ सकें. यह टेक्स्ट, ऐप्लिकेशन के लेबल से ज़्यादा लंबा और ज़्यादा जानकारी देने वाला होता है. वैल्यू को स्ट्रिंग संसाधन के रेफ़रंस के तौर पर सेट किया जाता है. लेबल के उलट, यह रॉ स्ट्रिंग नहीं हो सकता. इसकी कोई डिफ़ॉल्ट वैल्यू नहीं होती.
android:enabled
इससे पता चलता है कि Android सिस्टम, ऐप्लिकेशन के कॉम्पोनेंट को इंस्टैंशिएट कर सकता है या नहीं. अगर ऐसा किया जा सकता है, तो "true" और अगर नहीं किया जा सकता, तो "false". अगर वैल्यू "true" है, तो हर कॉम्पोनेंट के enabled एट्रिब्यूट से यह तय होता है कि वह कॉम्पोनेंट चालू है या नहीं. अगर वैल्यू "false" है, तो यह कॉम्पोनेंट के हिसाब से तय की गई वैल्यू को बदल देती है. साथ ही, सभी कॉम्पोनेंट बंद हो जाते हैं.

डिफ़ॉल्ट वैल्यू "true" है.

android:enableOnBackInvokedCallback

इस फ़्लैग की मदद से, ऐप्लिकेशन लेवल पर प्रिडिक्टिव सिस्टम ऐनिमेशन से ऑप्ट आउट किया जा सकता है.

ऐप्लिकेशन लेवल पर प्रिडिक्टिव बैक ऐनिमेशन बंद करने के लिए, android:enableOnBackInvokedCallback=false को सेट करें. साथ ही, सिस्टम को OnBackInvokedCallback प्लैटफ़ॉर्म एपीआई के कॉल को अनदेखा करने का निर्देश दें.

android:extractNativeLibs

AGP 4.2.0 से, डीएसएल विकल्प useLegacyPackaging, extractNativeLibs मेनिफ़ेस्ट एट्रिब्यूट की जगह लेता है. नेटिव लाइब्रेरी के कंप्रेस करने के तरीके को कॉन्फ़िगर करने के लिए, मेनिफ़ेस्ट फ़ाइल में extractNativeLibs के बजाय, अपने ऐप्लिकेशन की build.gradle फ़ाइल में useLegacyPackaging का इस्तेमाल करें. ज़्यादा जानकारी के लिए, रिलीज़ नोट कंप्रेस की गई नेटिव लाइब्रेरी को पैकेज करने के लिए डीएसएल का इस्तेमाल करना देखें.

इस एट्रिब्यूट से पता चलता है कि पैकेज इंस्टॉलर, फ़ाइल सिस्टम में एपीके से नेटिव लाइब्रेरी निकालता है या नहीं. अगर इसे "false" पर सेट किया जाता है, तो आपकी नेटिव लाइब्रेरी को APK में कंप्रेस किए बिना सेव किया जाता है. आपका APK बड़ा हो सकता है, लेकिन आपका ऐप्लिकेशन तेज़ी से लोड होता है. इसकी वजह यह है कि लाइब्रेरी, रनटाइम के दौरान सीधे APK से लोड होती हैं.

extractNativeLibs की डिफ़ॉल्ट वैल्यू, minSdkVersion और इस्तेमाल किए जा रहे AGP के वर्शन पर निर्भर करती है. ज़्यादातर मामलों में, डिफ़ॉल्ट व्यवहार आपकी ज़रूरत के मुताबिक होता है. इसलिए, आपको इस एट्रिब्यूट को साफ़ तौर पर सेट करने की ज़रूरत नहीं होती.

android:fullBackupContent
यह एट्रिब्यूट, ऐसी एक्सएमएल फ़ाइल की ओर ले जाता है जिसमें अपने-आप बैकअप लेने की सुविधा के लिए, बैकअप के पूरे नियम शामिल होते हैं. इन नियमों से यह तय होता है कि किन फ़ाइलों का बैक अप लिया जाएगा. ज़्यादा जानकारी के लिए, अपने-आप बैकअप लेने की सुविधा के लिए, एक्सएमएल कॉन्फ़िगरेशन सिंटैक्स देखें.

इस एट्रिब्यूट की वैल्यू देना ज़रूरी नहीं है. अगर इसे तय नहीं किया जाता है, तो डिफ़ॉल्ट रूप से, ऑटो बैकअप में आपके ऐप्लिकेशन की ज़्यादातर फ़ाइलें शामिल होती हैं. ज़्यादा जानकारी के लिए, बैक अप ली गई फ़ाइलें लेख पढ़ें.

android:fullBackupOnly
इस एट्रिब्यूट से पता चलता है कि जिन डिवाइसों पर अपने-आप बैकअप लेने की सुविधा उपलब्ध है उन पर इसका इस्तेमाल करना है या नहीं. अगर इसे "true" पर सेट किया जाता है, तो Android 6.0 (एपीआई लेवल 23) या इसके बाद के वर्शन वाले डिवाइस पर ऐप्लिकेशन इंस्टॉल होने पर, वह अपने-आप बैक अप ले लेता है. पुराने डिवाइसों पर, आपका ऐप्लिकेशन इस एट्रिब्यूट को अनदेखा करता है और कुंजी/वैल्यू के बैकअप लेता है.

डिफ़ॉल्ट वैल्यू "false" है.

android:gwpAsanMode
इस एट्रिब्यूट से पता चलता है कि GWP-ASan का इस्तेमाल करना है या नहीं. यह नेटिव मेमोरी ऐलोकेटर की सुविधा है. इससे फ़्री की गई मेमोरी को इस्तेमाल करने की गड़बड़ी और हीप-बफ़र-ओवरफ़्लो वाली गड़बड़ियों का पता लगाने में मदद मिलती है.

डिफ़ॉल्ट वैल्यू "never" है.

android:hasCode
क्या ऐप्लिकेशन में कोई DEX कोड है. इसका मतलब है कि क्या ऐप्लिकेशन में Kotlin या Java प्रोग्रामिंग लैंग्वेज का इस्तेमाल किया गया है. अगर ऐसा है, तो "true" और अगर ऐसा नहीं है, तो "false" डालें. जब वैल्यू "false" होती है, तो सिस्टम कॉम्पोनेंट लॉन्च करते समय किसी भी ऐप्लिकेशन कोड को लोड करने की कोशिश नहीं करता. डिफ़ॉल्ट वैल्यू "true" है.

अगर ऐप्लिकेशन में नेटिव (C/C++) कोड शामिल है, लेकिन कोई DEX कोड नहीं है, तो इसे "false" पर सेट किया जाना चाहिए. अगर APK में कोई DEX कोड नहीं है, तो "true" पर सेट होने पर ऐप्लिकेशन लोड नहीं हो सकता.

इस प्रॉपर्टी में, डिपेंडेंसी के ज़रिए ऐप्लिकेशन में शामिल किए गए कोड का हिसाब होना चाहिए. अगर ऐप्लिकेशन, Java/Kotlin कोड का इस्तेमाल करने वाले AAR या सीधे तौर पर JAR पर निर्भर करता है, तो app:hasCode को "true" पर सेट किया जाना चाहिए या इसे डिफ़ॉल्ट के तौर पर छोड़ दिया जाना चाहिए.

उदाहरण के लिए, हो सकता है कि आपका ऐप्लिकेशन Play Feature Delivery का इस्तेमाल करता हो और उसमें ऐसे फ़ीचर मॉड्यूल शामिल हों जो कोई DEX फ़ाइल जनरेट नहीं करते. DEX फ़ाइल, Android प्लैटफ़ॉर्म के लिए ऑप्टिमाइज़ किया गया बाइटकोड होता है. अगर ऐसा है, तो आपको इस प्रॉपर्टी को मॉड्यूल की मेनिफ़ेस्ट फ़ाइल में "false" पर सेट करना होगा, ताकि रनटाइम की गड़बड़ियों से बचा जा सके.

android:hasFragileUserData
यह तय करता है कि जब उपयोगकर्ता ऐप्लिकेशन को अनइंस्टॉल करे, तब उसे ऐप्लिकेशन का डेटा सेव रखने के लिए प्रॉम्प्ट दिखाना है या नहीं. डिफ़ॉल्ट वैल्यू "false" है.
android:hardwareAccelerated
इस ऐप्लिकेशन में सभी गतिविधियों और व्यू के लिए, हार्डवेयर की मदद से रेंडरिंग की सुविधा चालू है या नहीं. अगर यह सुविधा चालू है, तो "true" और अगर बंद है, तो "false" डालें. अगर आपने minSdkVersion या targetSdkVersion को "14" या इससे ज़्यादा पर सेट किया है, तो डिफ़ॉल्ट वैल्यू "true" होती है. इसके अलावा, यह "false" है.

Android 3.0 (एपीआई लेवल 11) से, हार्डवेयर की मदद से तेज़ी से काम करने वाला OpenGL रेंडरर, ऐप्लिकेशन के लिए उपलब्ध है. इससे कई सामान्य 2D ग्राफ़िक्स ऑपरेशन की परफ़ॉर्मेंस बेहतर होती है. हार्डवेयर-ऐक्सलरेटेड रेंडरर चालू होने पर, Canvas, Paint, Xfermode, ColorFilter, Shader, और Camera में ज़्यादातर कार्रवाइयां तेज़ी से होती हैं.

इससे ऐनिमेशन और स्क्रोलिंग बेहतर होती है. साथ ही, परफ़ॉर्मेंस भी बेहतर होती है. ऐसा उन ऐप्लिकेशन के लिए भी होता है जो फ़्रेमवर्क की OpenGL लाइब्रेरी का इस्तेमाल नहीं करते हैं.

OpenGL 2D की सभी कार्रवाइयों को तेज़ी से प्रोसेस नहीं किया जाता. अगर आपने हार्डवेयर-ऐक्सलरेटेड रेंडरर को चालू किया है, तो अपने ऐप्लिकेशन की जांच करें. इससे यह बिना किसी गड़बड़ी के रेंडरर का इस्तेमाल कर पाएगा.

ज़्यादा जानकारी के लिए, हार्डवेयर ऐक्सलरेशन गाइड पढ़ें.

android:icon
पूरे ऐप्लिकेशन के लिए आइकॉन और ऐप्लिकेशन के हर कॉम्पोनेंट के लिए डिफ़ॉल्ट आइकॉन. <activity>, <activity-alias>, <service>, <receiver>, और <provider> एलिमेंट के लिए, अलग-अलग icon एट्रिब्यूट देखें.

इस एट्रिब्यूट को, इमेज वाले ड्रॉएबल रिसॉर्स के रेफ़रंस के तौर पर सेट किया जाता है. जैसे, "@drawable/icon". कोई डिफ़ॉल्ट आइकॉन नहीं है.

android:isGame
यह ऐप्लिकेशन एक गेम है या नहीं. सिस्टम, गेम के तौर पर क्लासिफ़ाई किए गए ऐप्लिकेशन को एक साथ ग्रुप कर सकता है या उन्हें अन्य ऐप्लिकेशन से अलग दिखा सकता है. डिफ़ॉल्ट वैल्यू "false" है.
android:isMonitoringTool

इससे पता चलता है कि इस ऐप्लिकेशन को अन्य लोगों की निगरानी करने के लिए डिज़ाइन किया गया है.

ध्यान दें: अगर कोई ऐप्लिकेशन अपने मेनिफ़ेस्ट में इस एट्रिब्यूट का एलान करता है, तो डेवलपर को Google Play पर ऐप्लिकेशन पब्लिश करने के लिए, स्टॉकरवेयर से जुड़ी नीति का पालन करना होगा.

इसकी कोई डिफ़ॉल्ट वैल्यू नहीं होती. डेवलपर को इनमें से कोई एक वैल्यू तय करनी होगी:

मानब्यौरा
"parental_control"इस तरह के ऐप्लिकेशन में 'माता-पिता/अभिभावक का कंट्रोल' सुविधा उपलब्ध होती है. ये ऐप्लिकेशन खास तौर पर उन माता-पिता के लिए हैं जो नुकसान पहुंचाने वाले कॉन्टेंट से अपने बच्चों को बचाना चाहते हैं.
"enterprise_management"यह ऐप्लिकेशन उन कंपनियों के लिए है जो अपने कर्मचारियों को दिए गए डिवाइस मैनेज और ट्रैक करना चाहती हैं.
"other"ऐप्लिकेशन, इस्तेमाल के ऐसे उदाहरण के लिए बनाया गया है जिसके बारे में इस टेबल में नहीं बताया गया है.
android:killAfterRestore

इससे पता चलता है कि पूरे सिस्टम को वापस लाने की प्रोसेस के दौरान, ऐप्लिकेशन की सेटिंग वापस लाने के बाद, ऐप्लिकेशन बंद हो जाता है या नहीं. सिंगल-पैकेज को वापस लाने की कार्रवाइयों की वजह से, ऐप्लिकेशन कभी बंद नहीं होता. आम तौर पर, पूरे सिस्टम को रीस्टोर करने की प्रोसेस सिर्फ़ एक बार होती है. ऐसा तब होता है, जब फ़ोन को पहली बार सेट अप किया जाता है. आम तौर पर, तीसरे पक्ष के ऐप्लिकेशन को इस एट्रिब्यूट का इस्तेमाल करने की ज़रूरत नहीं होती.

डिफ़ॉल्ट वैल्यू "true" होती है. इसका मतलब है कि सिस्टम को पूरी तरह से रीस्टोर करने के दौरान, ऐप्लिकेशन के डेटा को प्रोसेस करने के बाद, यह बंद हो जाता है.

android:largeHeap

इससे पता चलता है कि ऐप्लिकेशन की प्रोसेस, बड़े Dalvik हीप के साथ बनाई गई हैं या नहीं. यह ऐप्लिकेशन के लिए बनाई गई सभी प्रोसेस पर लागू होता है. यह सिर्फ़ किसी प्रोसेस में लोड किए गए पहले ऐप्लिकेशन पर लागू होता है. अगर एक से ज़्यादा ऐप्लिकेशन को एक ही प्रोसेस का इस्तेमाल करने की अनुमति देने के लिए, शेयर किए गए उपयोगकर्ता आईडी का इस्तेमाल किया जा रहा है, तो उन सभी को इस विकल्प का लगातार इस्तेमाल करना होगा. ऐसा न करने पर, अनचाहे नतीजे मिल सकते हैं.

ज़्यादातर ऐप्लिकेशन को इसकी ज़रूरत नहीं होती. इसके बजाय, वे बेहतर परफ़ॉर्मेंस के लिए, मेमोरी के इस्तेमाल को कम करने पर फ़ोकस करते हैं. इसे चालू करने से भी, उपलब्ध मेमोरी में बढ़ोतरी की गारंटी नहीं मिलती. इसकी वजह यह है कि कुछ डिवाइसों में, कुल उपलब्ध मेमोरी सीमित होती है.

रनटाइम के दौरान उपलब्ध मेमोरी के साइज़ के बारे में क्वेरी करने के लिए, getMemoryClass() या getLargeMemoryClass() तरीकों का इस्तेमाल करें.

android:label
पूरे ऐप्लिकेशन के लिए, उपयोगकर्ता के पढ़ने लायक लेबल और ऐप्लिकेशन के हर कॉम्पोनेंट के लिए डिफ़ॉल्ट लेबल. <activity>, <activity-alias>, <service>, <receiver>, और <provider> एलिमेंट के लिए, अलग-अलग label एट्रिब्यूट देखें.

लेबल को स्ट्रिंग रिसॉर्स के रेफ़रंस के तौर पर सेट किया जाता है, ताकि इसे यूज़र इंटरफ़ेस में मौजूद अन्य स्ट्रिंग की तरह स्थानीय भाषा में बदला जा सके. हालांकि, ऐप्लिकेशन डेवलप करते समय इसे सुविधा के तौर पर रॉ स्ट्रिंग के तौर पर भी सेट किया जा सकता है.

android:logo
पूरे ऐप्लिकेशन के लिए एक लोगो और गतिविधियों के लिए डिफ़ॉल्ट लोगो. इस एट्रिब्यूट को, इमेज वाले ड्रॉएबल रिसॉर्स के रेफ़रंस के तौर पर सेट किया जाता है. जैसे, "@drawable/logo". कोई डिफ़ॉल्ट लोगो नहीं है.
android:manageSpaceActivity
यह Activity सबक्लास का पूरा नाम है. सिस्टम इसे लॉन्च करता है, ताकि उपयोगकर्ता डिवाइस पर ऐप्लिकेशन की ओर से इस्तेमाल की गई मेमोरी को मैनेज कर सकें. गतिविधि को <activity> एलिमेंट के साथ भी दिखाया जाता है.
android:name
ऐप्लिकेशन के लिए लागू की गई Application सबक्लास का पूरी तरह क्वालिफ़ाइड नाम. ऐप्लिकेशन प्रोसेस शुरू होने पर, इस क्लास को ऐप्लिकेशन के किसी भी कॉम्पोनेंट से पहले इंस्टैंशिएट किया जाता है.

सबक्लास ज़रूरी नहीं है. ज़्यादातर ऐप्लिकेशन के लिए इसकी ज़रूरत नहीं होती. सबक्लास के न होने पर, Android, बेस Application क्लास के इंस्टेंस का इस्तेमाल करता है.

android:networkSecurityConfig

इससे उस एक्सएमएल फ़ाइल का नाम पता चलता है जिसमें आपके ऐप्लिकेशन का नेटवर्क सुरक्षा कॉन्फ़िगरेशन होता है. यह वैल्यू, कॉन्फ़िगरेशन वाली एक्सएमएल रिसॉर्स फ़ाइल का रेफ़रंस होती है.

इस एट्रिब्यूट को एपीआई लेवल 24 में जोड़ा गया था.

android:permission
यह अनुमति का नाम है. क्लाइंट को ऐप्लिकेशन के साथ इंटरैक्ट करने के लिए, इस अनुमति की ज़रूरत होती है. इस एट्रिब्यूट की मदद से, आसानी से एक ऐसी अनुमति सेट की जा सकती है जो ऐप्लिकेशन के सभी कॉम्पोनेंट पर लागू होती है. अलग-अलग कॉम्पोनेंट के permission एट्रिब्यूट सेट करने पर, यह वैल्यू बदल जाती है.

अनुमतियों के बारे में ज़्यादा जानने के लिए, ऐप्लिकेशन मेनिफ़ेस्ट की खास जानकारी में मौजूद अनुमतियां सेक्शन और सुरक्षा से जुड़े सुझाव देखें.

android:persistent
इससे यह पता चलता है कि ऐप्लिकेशन हमेशा चालू रहता है या नहीं. अगर ऐसा होता है, तो "true" और अगर ऐसा नहीं होता है, तो "false". डिफ़ॉल्ट वैल्यू "false" है. आम तौर पर, ऐप्लिकेशन इस फ़्लैग को सेट नहीं करते. परसिस्टेंस मोड सिर्फ़ कुछ सिस्टम ऐप्लिकेशन के लिए होता है.
android:process
ऐसी प्रोसेस का नाम जिसमें ऐप्लिकेशन के सभी कॉम्पोनेंट चलते हैं. हर कॉम्पोनेंट के लिए, इस डिफ़ॉल्ट वैल्यू को बदला जा सकता है. इसके लिए, कॉम्पोनेंट का अपना process एट्रिब्यूट सेट करें.

डिफ़ॉल्ट रूप से, Android किसी ऐप्लिकेशन के लिए एक प्रोसेस बनाता है. ऐसा तब होता है, जब उसके किसी कॉम्पोनेंट को पहली बार चलाने की ज़रूरत होती है. इसके बाद, सभी कॉम्पोनेंट उस प्रोसेस में चलते हैं. डिफ़ॉल्ट प्रोसेस का नाम, <manifest> एलिमेंट से सेट किए गए पैकेज के नाम से मेल खाता है.

इस एट्रिब्यूट को किसी ऐसे प्रोसेस के नाम पर सेट किया जा सकता है जिसे किसी दूसरे ऐप्लिकेशन के साथ शेयर किया गया हो. इससे, दोनों ऐप्लिकेशन के कॉम्पोनेंट को एक ही प्रोसेस में चलाने की व्यवस्था की जा सकती है. हालांकि, ऐसा सिर्फ़ तब किया जा सकता है, जब दोनों ऐप्लिकेशन एक ही उपयोगकर्ता आईडी शेयर करते हों और उन्हें एक ही सर्टिफ़िकेट से साइन किया गया हो.

अगर इस एट्रिब्यूट को असाइन किया गया नाम कोलन (:) से शुरू होता है, तो ज़रूरत पड़ने पर एक नई प्रोसेस बनाई जाती है. यह प्रोसेस सिर्फ़ ऐप्लिकेशन के लिए होती है. अगर प्रोसेस का नाम छोटे अक्षर से शुरू होता है, तो उस नाम की ग्लोबल प्रोसेस बनाई जाती है. ग्लोबल प्रोसेस को अन्य ऐप्लिकेशन के साथ शेयर किया जा सकता है. इससे संसाधनों का इस्तेमाल कम होता है.

android:restoreAnyVersion
इससे पता चलता है कि ऐप्लिकेशन, बैक अप किए गए किसी भी डेटा सेट को वापस लाने के लिए तैयार है. भले ही, बैकअप को ऐप्लिकेशन के ऐसे नए वर्शन ने सेव किया हो जो फ़िलहाल डिवाइस पर इंस्टॉल किए गए वर्शन से नया हो. इस एट्रिब्यूट को "true" पर सेट करने से, बैकअप मैनेजर को
  • $1
  • डेटा को वापस लाने की कोशिश करें. भले ही, वर्शन के मेल न खाने से यह पता चलता हो कि डेटा काम नहीं करेगा. सावधानी से इस्तेमाल करें!

    इस एट्रिब्यूट की डिफ़ॉल्ट वैल्यू "false" है.

    android:requestLegacyExternalStorage

    इससे पता चलता है कि ऐप्लिकेशन, स्कोप किए गए स्टोरेज से ऑप्ट आउट करना चाहता है या नहीं.

    ध्यान दें: नीति या ऐप्लिकेशन की ज़रूरी शर्तें पूरी करने से जुड़े बदलावों के आधार पर, सिस्टम इस ऑप्ट-आउट अनुरोध को स्वीकार नहीं कर सकता.

    android:requiredAccountType
    यह बताता है कि ऐप्लिकेशन को काम करने के लिए किस तरह के खाते की ज़रूरत है. अगर आपके ऐप्लिकेशन के लिए Account की ज़रूरत है, तो इस एट्रिब्यूट की वैल्यू, आपके ऐप्लिकेशन में इस्तेमाल किए गए खाते के पुष्टि करने वाले टाइप से मेल खानी चाहिए. इसकी जानकारी AuthenticatorDescription में दी गई है. जैसे, "com.google".

    डिफ़ॉल्ट वैल्यू null होती है. इससे पता चलता है कि ऐप्लिकेशन, किसी भी खाते के बिना काम कर सकता है.

    प्रतिबंधित प्रोफ़ाइलें खाते नहीं जोड़ सकती हैं. इसलिए, इस एट्रिब्यूट की वैल्यू देने पर, प्रतिबंधित प्रोफ़ाइल से आपका ऐप्लिकेशन तब तक उपलब्ध नहीं होगा, जब तक कि android:restrictedAccountType एट्रिब्यूट की वैल्यू भी वही न हो.

    चेतावनी: अगर खाते के डेटा से व्यक्तिगत पहचान से जुड़ी जानकारी का पता चल सकता है, तो यह ज़रूरी है कि आप इस एट्रिब्यूट की वैल्यू दें और android:restrictedAccountType को शून्य पर सेट करें. इससे प्रतिबंधित प्रोफ़ाइलें, आपके ऐप्लिकेशन का इस्तेमाल करके मालिक के तौर पर इस्तेमाल किए जा रहे खाते की निजी जानकारी को ऐक्सेस नहीं कर पाएंगी.

    इस एट्रिब्यूट को एपीआई लेवल 18 में जोड़ा गया था.

    android:resizeableActivity

    इससे पता चलता है कि ऐप्लिकेशन, मल्टी-विंडो मोड के साथ काम करता है या नहीं.

    इस एट्रिब्यूट को <activity> या <application> एलिमेंट में सेट किया जा सकता है.

    इस एट्रिब्यूट को "true" पर सेट करने पर, उपयोगकर्ता स्प्लिट-स्क्रीन और फ़्री-फ़ॉर्म मोड में गतिविधि लॉन्च कर सकता है. इस एट्रिब्यूट को "false" पर सेट करने पर, ऐप्लिकेशन को मल्टी-विंडो एनवायरमेंट के लिए टेस्ट या ऑप्टिमाइज़ नहीं किया जा सकता. सिस्टम, कंपैटबिलिटी मोड लागू करके ऐक्टिविटी को मल्टी-विंडो मोड में अब भी रख सकता है.

    इस एट्रिब्यूट को "true" पर सेट करने से यह गारंटी नहीं मिलती कि स्क्रीन पर मल्टी-विंडो मोड में कोई दूसरा ऐप्लिकेशन नहीं दिखेगा. जैसे, पिक्चर-इन-पिक्चर या अन्य डिसप्ले पर. इसलिए, इस फ़्लैग को सेट करने का मतलब यह नहीं है कि आपके ऐप्लिकेशन के पास संसाधन का खास ऐक्सेस है.

    एपीआई लेवल 24 या उसके बाद के वर्शन को टारगेट करने वाले ऐप्लिकेशन के लिए, डिफ़ॉल्ट वैल्यू "true" होती है.

    अगर आपका ऐप्लिकेशन, एपीआई लेवल 31 या उसके बाद के लेवल को टारगेट करता है, तो यह एट्रिब्यूट छोटी और बड़ी स्क्रीन पर अलग-अलग तरीके से काम करता है:

    • बड़ी स्क्रीन (sw >= 600dp): सभी ऐप्लिकेशन, मल्टी-विंडो मोड के साथ काम करते हैं. इस एट्रिब्यूट से यह पता चलता है कि किसी ऐप्लिकेशन का साइज़ बदला जा सकता है या नहीं. इससे यह पता नहीं चलता कि ऐप्लिकेशन मल्टी-विंडो मोड के साथ काम करता है या नहीं. अगर resizeableActivity="false", डिसप्ले के डाइमेंशन के मुताबिक ऐप्लिकेशन को काम करने के लिए, उसे कंपैटिबिलिटी मोड में डाल दिया जाता है.
    • छोटी स्क्रीन (sw < 600dp): अगर resizeableActivity="true" और मुख्य गतिविधि की कम से कम चौड़ाई और कम से कम ऊंचाई, मल्टी-विंडो की ज़रूरी शर्तों के मुताबिक है, तो ऐप्लिकेशन मल्टी-विंडो मोड के साथ काम करता है. अगर resizeableActivity="false" है, तो ऐप्लिकेशन मल्टी-विंडो मोड के साथ काम नहीं करता. भले ही, गतिविधि की कम से कम चौड़ाई और ऊंचाई कुछ भी हो.

    किसी टास्क की रूट ऐक्टिविटी की वैल्यू, टास्क में लॉन्च की गई सभी अतिरिक्त ऐक्टिविटी पर लागू होती है. इसका मतलब है कि अगर किसी टास्क की रूट गतिविधि का साइज़ बदला जा सकता है, तो सिस्टम उस टास्क की अन्य सभी गतिविधियों को भी साइज़ बदलने की सुविधा के साथ उपलब्ध कराता है. अगर रूट गतिविधि का साइज़ नहीं बदला जा सकता, तो टास्क में मौजूद अन्य गतिविधियों का साइज़ भी नहीं बदला जा सकता.

    इस एट्रिब्यूट को एपीआई लेवल 24 में जोड़ा गया था.

    android:restrictedAccountType
    इससे पता चलता है कि इस ऐप्लिकेशन के लिए किस तरह के खाते की ज़रूरत है. इससे यह भी पता चलता है कि प्रतिबंधित प्रोफ़ाइलें, मालिक के उपयोगकर्ता खाते से जुड़े ऐसे खातों को ऐक्सेस कर सकती हैं. अगर आपके ऐप्लिकेशन को Account की ज़रूरत है और प्रतिबंधित प्रोफ़ाइलें, मुख्य उपयोगकर्ता के खातों को ऐक्सेस कर सकती हैं, तो इस एट्रिब्यूट की वैल्यू, आपके ऐप्लिकेशन के इस्तेमाल किए गए खाता पुष्टि करने वाले के टाइप से मेल खानी चाहिए. यह टाइप, AuthenticatorDescription के हिसाब से तय किया जाता है. जैसे, "com.google".

    डिफ़ॉल्ट वैल्यू null होती है. इसका मतलब है कि ऐप्लिकेशन, किसी भी खाते के बिना काम कर सकता है.

    चेतावनी: इस एट्रिब्यूट को सेट करने पर, प्रतिबंधित प्रोफ़ाइलें आपके ऐप्लिकेशन का इस्तेमाल, मालिक के खाते से कर सकती हैं. इससे व्यक्तिगत पहचान से जुड़ी जानकारी का पता चल सकता है. अगर खाते से निजी जानकारी का पता चल सकता है, तो इस एट्रिब्यूट का इस्तेमाल न करें. इसके बजाय, android:requiredAccountType एट्रिब्यूट की वैल्यू के तौर पर 'उपलब्ध नहीं है' सेट करें, ताकि प्रतिबंधित प्रोफ़ाइलों के लिए आपका ऐप्लिकेशन उपलब्ध न हो.

    इस एट्रिब्यूट को एपीआई लेवल 18 में जोड़ा गया था.

    android:supportsRtl

    इससे यह तय होता है कि आपका ऐप्लिकेशन, राइट-टु-लेफ़्ट (आरटीएल) लेआउट के साथ काम करेगा या नहीं.

    अगर इसे "true" पर सेट किया जाता है और targetSdkVersion को 17 या इससे ज़्यादा पर सेट किया जाता है, तो सिस्टम कई आरटीएल एपीआई चालू करता है और उनका इस्तेमाल करता है, ताकि आपका ऐप्लिकेशन आरटीएल लेआउट दिखा सके. अगर इसे "false" पर सेट किया जाता है या targetSdkVersion को 16 या इससे कम पर सेट किया जाता है, तो आरटीएल एपीआई को अनदेखा कर दिया जाता है या उनका कोई असर नहीं होता. साथ ही, आपके ऐप्लिकेशन का लेआउट, उपयोगकर्ता की चुनी गई स्थानीय भाषा से जुड़े लेआउट की दिशा के बावजूद एक जैसा रहता है. इसका मतलब है कि आपके लेआउट हमेशा बाईं से दाईं ओर होते हैं.

    इस एट्रिब्यूट की डिफ़ॉल्ट वैल्यू "false" है.

    इस एट्रिब्यूट को एपीआई लेवल 17 में जोड़ा गया था.

    android:taskAffinity
    ऐप्लिकेशन में मौजूद सभी गतिविधियों पर लागू होने वाला अफ़िनिटी नाम. हालांकि, यह उन गतिविधियों पर लागू नहीं होता जो अपने taskAffinity एट्रिब्यूट के साथ अलग अफ़िनिटी सेट करती हैं. ज़्यादा जानकारी के लिए, वह एट्रिब्यूट देखें.

    डिफ़ॉल्ट रूप से, किसी ऐप्लिकेशन में की गई सभी गतिविधियों की अफ़िनिटी एक जैसी होती है. उस अफ़िनिटी का नाम वही होता है जो <manifest> एलिमेंट से सेट किए गए पैकेज का नाम होता है.

    android:testOnly
    इससे पता चलता है कि यह ऐप्लिकेशन सिर्फ़ टेस्टिंग के लिए है या नहीं. उदाहरण के लिए, यह खुद से बाहर की किसी सुविधा या डेटा को सार्वजनिक कर सकता है. इससे सुरक्षा में कमी आ सकती है. हालांकि, यह टेस्टिंग के लिए फ़ायदेमंद हो सकता है. इस तरह का APK सिर्फ़ adb के ज़रिए इंस्टॉल होता है. इसे Google Play पर पब्लिश नहीं किया जा सकता.

    चलाएं पर क्लिक करने पर, Android Studio इस एट्रिब्यूट को अपने-आप जोड़ देता है.

    android:theme
    यह एक स्टाइल रिसॉर्स का रेफ़रंस है. यह ऐप्लिकेशन की सभी गतिविधियों के लिए, डिफ़ॉल्ट थीम तय करता है. अलग-अलग गतिविधियों के लिए, डिफ़ॉल्ट सेटिंग को बदला जा सकता है. इसके लिए, theme एट्रिब्यूट सेट करने होंगे. ज़्यादा जानकारी के लिए, स्टाइल और थीम देखें.
    android:uiOptions
    किसी गतिविधि के यूज़र इंटरफ़ेस (यूआई) के लिए अतिरिक्त विकल्प. यह इनमें से कोई एक वैल्यू होनी चाहिए:
    मानब्यौरा
    "none"कोई अतिरिक्त यूज़र इंटरफ़ेस विकल्प नहीं. यह डिफ़ॉल्ट विकल्प है.
    "splitActionBarWhenNarrow"यह कुकी, स्क्रीन पर सबसे नीचे एक बार जोड़ती है. इससे ऐप्लिकेशन बार में मौजूद कार्रवाई के आइटम दिखते हैं. इसे ऐक्शन बार भी कहा जाता है. ऐसा तब होता है, जब हॉरिज़ॉन्टल स्पेस सीमित होता है. जैसे, हैंडसेट पर पोर्ट्रेट मोड में होने पर. स्क्रीन पर सबसे ऊपर मौजूद ऐप्लिकेशन बार में, कार्रवाई के लिए कुछ आइटम दिखते हैं. हालांकि, अब ऐप्लिकेशन बार को दो हिस्सों में बांट दिया गया है. सबसे ऊपर मौजूद नेविगेशन सेक्शन और कार्रवाई के लिए सबसे नीचे मौजूद बार. इसका मतलब है कि ऐक्शन आइटम के लिए, नेविगेशन के लिए, और सबसे ऊपर मौजूद टाइटल एलिमेंट के लिए, ठीक-ठाक जगह उपलब्ध है. मेन्यू आइटम को दो बार में नहीं बांटा गया है. ये हमेशा साथ में दिखते हैं.

    ऐप्लिकेशन बार के बारे में ज़्यादा जानने के लिए, ऐप्लिकेशन बार जोड़ना लेख पढ़ें.

    इस एट्रिब्यूट को एपीआई लेवल 14 में जोड़ा गया था.

    android:usesCleartextTraffic
    इससे पता चलता है कि ऐप्लिकेशन, क्लियरटेक्स्ट नेटवर्क ट्रैफ़िक का इस्तेमाल करना चाहता है या नहीं. जैसे, क्लियरटेक्स्ट एचटीटीपी. एपीआई लेवल 27 या इससे पहले के लेवल को टारगेट करने वाले ऐप्लिकेशन के लिए, डिफ़ॉल्ट वैल्यू "true" होती है. एपीआई लेवल 28 या इससे ऊपर के वर्शन को टारगेट करने वाले ऐप्लिकेशन के लिए, डिफ़ॉल्ट रूप से "false" चालू होता है.

    ध्यान दें: इस एट्रिब्यूट का इस्तेमाल अब नहीं किया जा सकेगा. साथ ही, एपीआई लेवल 38 और इसके बाद के लेवल को टारगेट करने वाले ऐप्लिकेशन के लिए, इस एट्रिब्यूट को अनदेखा कर दिया जाएगा. एपीआई लेवल 24 और उसके बाद के लेवल के लिए, cleartext ट्रैफ़िक को कंट्रोल करने के लिए Network Security Configuration तय करें. अगर आपका ऐप्लिकेशन, एपीआई लेवल 23 और इससे पहले के लेवल को टारगेट करता है, तो आपको नेटवर्क सुरक्षा कॉन्फ़िगरेशन के साथ-साथ android:usesCleartextTraffic भी तय करना होगा.

    जब एट्रिब्यूट को "false" पर सेट किया जाता है, तो प्लैटफ़ॉर्म कॉम्पोनेंट, जैसे कि एचटीटीपी और एफ़टीपी स्टैक, DownloadManager, और MediaPlayer, ऐप्लिकेशन के अनुरोधों को अस्वीकार कर देते हैं.

    तीसरे पक्ष की लाइब्रेरी को भी इस सेटिंग का पालन करने के लिए कहा जाता है. क्लियरटेक्स्ट ट्रैफ़िक से बचने की मुख्य वजह यह है कि इसमें गोपनीयता, प्रमाणिकता, और छेड़छाड़ से सुरक्षा नहीं मिलती. नेटवर्क पर हमला करने वाला व्यक्ति, ट्रांसमिट किए गए डेटा को चोरी-छिपे देख सकता है. साथ ही, वह डेटा में बदलाव भी कर सकता है.

    इस फ़्लैग का पालन पूरी तरह से नहीं किया जा सकता. ऐसा इसलिए है, क्योंकि Android ऐप्लिकेशन को दिए गए ऐक्सेस लेवल को देखते हुए, सभी क्लियरटेक्स्ट ट्रैफ़िक को रोकना मुमकिन नहीं है. उदाहरण के लिए, Socket API से यह उम्मीद नहीं की जाती कि वह इस फ़्लैग का पालन करे. ऐसा इसलिए, क्योंकि यह पता नहीं लगा सकता कि इसका ट्रैफ़िक क्लियरटेक्स्ट में है या नहीं.

    हालांकि, ऐप्लिकेशन से आने वाले ज़्यादातर नेटवर्क ट्रैफ़िक को हायर-लेवल नेटवर्क स्टैक और कॉम्पोनेंट मैनेज करते हैं. ये इस फ़्लैग का पालन कर सकते हैं. इसके लिए, वे इसे ApplicationInfo.flags या NetworkSecurityPolicy.isCleartextTrafficPermitted() से पढ़ सकते हैं.

    ध्यान दें: WebView, एपीआई लेवल 26 और इसके बाद के वर्शन को टारगेट करने वाले ऐप्लिकेशन के लिए, इस एट्रिब्यूट का इस्तेमाल करता है.

    ऐप्लिकेशन डेवलपमेंट के दौरान, StrictMode का इस्तेमाल करके ऐप्लिकेशन से आने वाले किसी भी क्लियरटेक्स्ट ट्रैफ़िक की पहचान की जा सकती है. ज़्यादा जानकारी के लिए, StrictMode.VmPolicy.Builder.detectCleartextNetwork() देखें.

    इस एट्रिब्यूट को एपीआई लेवल 23 में जोड़ा गया था.

    अगर Android Network Security Config मौजूद है, तो Android 7.0 (एपीआई लेवल 24) और इसके बाद के वर्शन पर इस फ़्लैग को अनदेखा कर दिया जाता है.

    android:vmSafeMode
    इससे पता चलता है कि ऐप्लिकेशन को वर्चुअल मशीन (वीएम) को सुरक्षित मोड में चलाने की ज़रूरत है या नहीं. डिफ़ॉल्ट वैल्यू "false" है.

    इस एट्रिब्यूट को एपीआई लेवल 8 में जोड़ा गया था. इसमें "true" वैल्यू सेट करने पर, Dalvik just-in-time (JIT) कंपाइलर बंद हो जाता था.

    इस एट्रिब्यूट को एपीआई लेवल 22 में अडैप्ट किया गया था. इसमें "true" वैल्यू, ART के ऐंड्रॉयड रनटाइम (एआरटी) कंपाइलर को बंद कर देती है.

    पहली बार इसमें दिखाया गया:
    एपीआई लेवल 1
    यह भी देखें:
    <activity>
    <service>
    <receiver>
    <provider>