ऐप्लिकेशन लिंक करने की सुविधा लागू करते समय, आपको लिंक करने की सुविधा की जांच करनी चाहिए. इससे यह पक्का किया जा सकेगा कि सिस्टम, आपके ऐप्लिकेशन को आपकी वेबसाइटों से जोड़ सके और आपकी उम्मीद के मुताबिक, यूआरएल के अनुरोधों को हैंडल कर सके.
मौजूदा स्टेटमेंट फ़ाइल की जांच करने के लिए, स्टेटमेंट लिस्ट जनरेटर और टेस्टर टूल का इस्तेमाल किया जा सकता है.
यहां दिए गए सेक्शन में, ऐप्लिकेशन लिंक की पुष्टि करने की सुविधा की मैन्युअल तरीके से जांच करने का तरीका बताया गया है. अगर चाहें, तो Play डीप लिंक टूल या Android Studio के ऐप्लिकेशन लिंक असिस्टेंट की मदद से, पुष्टि करने की सुविधा की जांच की जा सकती है.
पुष्टि करने के लिए, होस्ट की सूची की पुष्टि करना
जांच करते समय, आपको उन सभी होस्ट की सूची की पुष्टि करनी चाहिए जिन्हें सिस्टम को आपके ऐप्लिकेशन के लिए वेरिफ़ाई करना चाहिए. उन सभी यूआरएल की सूची बनाएं जिनके इंटेंट फ़िल्टर में ये एट्रिब्यूट और एलिमेंट शामिल हों:
android:schemeएट्रिब्यूट, जिसकी वैल्यूhttpयाhttpsहोandroid:hostएट्रिब्यूट, जिसमें डोमेन यूआरएल पैटर्न होandroid.intent.action.VIEWऐक्शन एलिमेंटandroid.intent.category.BROWSABLEकैटगरी एलिमेंट
इस सूची का इस्तेमाल करके, यह पक्का करें कि हर नाम वाले होस्ट और सबडोमेन पर, डिजिटल एसेट लिंक JSON फ़ाइल मौजूद हो.
डिजिटल एसेट लिंक फ़ाइलों की पुष्टि करना
हर वेबसाइट के लिए, डिजिटल एसेट लिंक एपीआई का इस्तेमाल करके, यह पक्का करें कि डिजिटल एसेट लिंक JSON फ़ाइल सही तरीके से होस्ट की गई हो और उसे सही तरीके से तय किया गया हो:
https://digitalassetlinks.googleapis.com/v1/statements:list?
source.web.site=https://<var>domain.name</var>:<var>optional_port</var>&
relation=delegate_permission/common.handle_all_urls
डाइनैमिक ऐप्लिकेशन लिंक के लिए, रिलेशन एक्सटेंशन की भी जांच की जा सकती है.
https://digitalassetlinks.googleapis.com/v1/statements:list?source.web.site=https://www.example.com&relation=delegate_permission/common.handle_all_urls&return_relation_extensions=true
लिंक से जुड़ी नीतियों की जांच करना
जांच की प्रोसेस के दौरान, लिंक हैंडलिंग के लिए मौजूदा सिस्टम सेटिंग की जांच की जा सकती है. कनेक्ट किए गए डिवाइस पर मौजूद सभी ऐप्लिकेशन के लिए, लिंक हैंडलिंग से जुड़ी मौजूदा नीतियों की सूची पाने के लिए, यह कमांड इस्तेमाल करें:
adb shell dumpsys package domain-preferred-apps
यह कमांड भी वही काम करता है:
adb shell dumpsys package d
कमांड, डिवाइस पर तय किए गए हर उपयोगकर्ता या प्रोफ़ाइल की सूची दिखाता है. इससे पहले, यह हेडर इस फ़ॉर्मैट में दिखता है:
App linkages for user 0:
इस हेडर के बाद, आउटपुट में उस उपयोगकर्ता के लिए लिंक हैंडलिंग सेटिंग की सूची दिखाने के लिए, इस फ़ॉर्मैट का इस्तेमाल किया जाता है:
Package: com.android.vending
Domains: play.google.com market.android.com
Status: always : 200000002
इस सूची से पता चलता है कि उस उपयोगकर्ता के लिए, कौनसे ऐप्लिकेशन किस डोमेन से जुड़े हैं:
Package- किसी ऐप्लिकेशन की पहचान उसके पैकेज के नाम से होती है. यह नाम, उसके मेनिफ़ेस्ट में बताया जाता है.Domains- उन सभी होस्ट की पूरी सूची दिखाता है जिनके वेब लिंक को यह ऐप्लिकेशन हैंडल करता है. इसमें, डेलिमिटर के तौर पर खाली जगहों का इस्तेमाल किया जाता है.Status- इस ऐप्लिकेशन के लिए, लिंक हैंडलिंग की मौजूदा सेटिंग दिखाता है. ऐसा ऐप्लिकेशन जिसकी पुष्टि हो चुकी है और जिसके मेनिफ़ेस्ट मेंandroid:autoVerify="true"शामिल है, उसकी स्थितिalwaysदिखती है. इस स्थिति के बाद दिखने वाला हेक्साडेसिमल नंबर, Android सिस्टम के उस रिकॉर्ड से जुड़ा होता है जिसमें उपयोगकर्ता की ऐप्लिकेशन लिंकिंग की प्राथमिकताओं की जानकारी होती है. इस वैल्यू से यह पता नहीं चलता कि पुष्टि की प्रोसेस पूरी हुई है या नहीं.
जांच का उदाहरण
ऐप्लिकेशन लिंक की पुष्टि की प्रोसेस पूरी होने के लिए, सिस्टम को आपके ऐप्लिकेशन की पुष्टि, उन सभी वेबसाइटों से करनी होगी जिन्हें आपने किसी ऐसे इंटेंट फ़िल्टर में तय किया है जो ऐप्लिकेशन लिंक की ज़रूरी शर्तों को पूरा करता है. यहां दिए गए उदाहरण में, कई ऐप्लिकेशन लिंक तय किए गए हैं. साथ ही, मेनिफ़ेस्ट का कॉन्फ़िगरेशन दिखाया गया है:
<activity android:name=”MainActivity”>
<intent-filter android:autoVerify="true">
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="https" />
<data android:scheme="https" />
<data android:host="www.example.com" />
<data android:host="mobile.example.com" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="https" />
<data android:host="www.example2.com" />
</intent-filter>
</activity>
<activity android:name=”SecondActivity”>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="https" />
<data android:host="account.example.com" />
</intent-filter>
</activity>
<activity android:name=”ThirdActivity”>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<data android:scheme="https" />
<data android:host="map.example.com" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="market" />
<data android:host="example.com" />
</intent-filter>
</activity>
</application>
ऊपर दिए गए मेनिफ़ेस्ट में, प्लैटफ़ॉर्म जिन होस्ट की पुष्टि करने की कोशिश करेगा उनकी सूची यहां दी गई है:
www.example.com
mobile.example.com
www.example2.com
account.example.com
ऊपर दिए गए मेनिफ़ेस्ट में, प्लैटफ़ॉर्म जिन होस्ट की पुष्टि करने की कोशिश नहीं करेगा उनकी सूची यहां दी गई है:
map.example.com (it does not have android.intent.category.BROWSABLE)
market://example.com (it does not have either an "http" or "https" scheme)
स्टेटमेंट लिस्ट के बारे में ज़्यादा जानने के लिए, स्टेटमेंट लिस्ट बनाना लेख पढ़ें