Android में, डीप लिंक एक ऐसा लिंक होता है जो आपको ऐप्लिकेशन में सीधे किसी डेस्टिनेशन पर ले जाता है.
नेविगेशन कॉम्पोनेंट की मदद से, दो तरह के डीप लिंक बनाए जा सकते हैं: एक्सप्लिसिट और इंप्लिसिट.
एक्सप्लिसिट डीप लिंक बनाना
साफ़ तौर पर दिखने वाला डीप लिंक, डीप लिंक का एक उदाहरण है. यह उपयोगकर्ताओं को आपके ऐप्लिकेशन के किसी खास हिस्से पर ले जाने के लिए, PendingIntent
का इस्तेमाल करता है. उदाहरण के लिए, किसी सूचना या ऐप्लिकेशन विजेट के हिस्से के तौर पर साफ़ तौर पर दिखने वाला डीप लिंक दिखाया जा सकता है.
जब कोई उपयोगकर्ता साफ़ तौर पर दिए गए डीप लिंक से आपका ऐप्लिकेशन खोलता है, तो टास्क बैक स्टैक को हटा दिया जाता है और उसे डीप लिंक डेस्टिनेशन से बदल दिया जाता है. ग्राफ़ को नेस्ट करते समय,
नेस्टिंग के हर लेवल से शुरुआती डेस्टिनेशन—यानी कि हैरारकी में हर <navigation>
एलिमेंट का शुरुआती डेस्टिनेशन भी स्टैक में जोड़ा जाता है.
इसका मतलब है कि जब कोई उपयोगकर्ता डीप लिंक डेस्टिनेशन से 'वापस जाएं' बटन दबाता है, तो वह नेविगेशन स्टैक पर वापस उसी तरह से जाता है जैसे कि वह आपके ऐप्लिकेशन में उसके एंट्री पॉइंट से आया हो.
जैसा कि नीचे उदाहरण में दिखाया गया है, PendingIntent
बनाने के लिए, NavDeepLinkBuilder
क्लास का इस्तेमाल किया जा सकता है. ध्यान दें कि अगर दिया गया कॉन्टेक्स्ट Activity
नहीं है, तो कंस्ट्रक्टर, डिफ़ॉल्ट गतिविधि के तौर पर PackageManager.getLaunchIntentForPackage()
का इस्तेमाल करता है. हालांकि, ऐसा तब ही होता है, जब PackageManager.getLaunchIntentForPackage()
उपलब्ध हो.
Kotlin
val pendingIntent = NavDeepLinkBuilder(context) .setGraph(R.navigation.nav_graph) .setDestination(R.id.android) .setArguments(args) .createPendingIntent()
Java
PendingIntent pendingIntent = new NavDeepLinkBuilder(context) .setGraph(R.navigation.nav_graph) .setDestination(R.id.android) .setArguments(args) .createPendingIntent();
डिफ़ॉल्ट रूप से, NavDeepLinkBuilder
आपके ऐप्लिकेशन के मेनिफ़ेस्ट में बताए गए डिफ़ॉल्ट लॉन्च Activity
में, साफ़ तौर पर बताए गए डीप लिंक को लॉन्च करता है. अगर आपका NavHost
किसी दूसरी गतिविधि में है, तो डीप लिंक बिल्डर बनाते समय आपको उसके कॉम्पोनेंट का नाम बताना होगा:
Kotlin
val pendingIntent = NavDeepLinkBuilder(context) .setGraph(R.navigation.nav_graph) .setDestination(R.id.android) .setArguments(args) .setComponentName(DestinationActivity::class.java) .createPendingIntent()
Java
PendingIntent pendingIntent = new NavDeepLinkBuilder(context) .setGraph(R.navigation.nav_graph) .setDestination(R.id.android) .setArguments(args) .setComponentName(DestinationActivity.class) .createPendingIntent();
अगर आपके पास ComponentName
है, तो इसे सीधे बिल्डर को भेजा जा सकता है:
Kotlin
val componentName = ... val pendingIntent = NavDeepLinkBuilder(context) .setGraph(R.navigation.nav_graph) .setDestination(R.id.android) .setArguments(args) .setComponentName(componentName) .createPendingIntent()
Java
ComponentName componentName = ...; PendingIntent pendingIntent = new NavDeepLinkBuilder(context) .setGraph(R.navigation.nav_graph) .setDestination(R.id.android) .setArguments(args) .setComponentName(componentName) .createPendingIntent();
अगर आपके पास कोई मौजूदा NavController
है, तो NavController.createDeepLink()
का इस्तेमाल करके भी डीप लिंक बनाया जा सकता है.
इंप्लिसिट डीप लिंक बनाना
इंप्लिसिट डीप लिंक, किसी ऐप्लिकेशन के किसी खास डेस्टिनेशन को दिखाता है. जब डीप लिंक को ट्रिगर किया जाता है, जैसे कि कोई उपयोगकर्ता किसी लिंक पर क्लिक करता है, तो Android आपके ऐप्लिकेशन को उस डेस्टिनेशन पर खोल सकता है.
डीप लिंक का मिलान यूआरआई, इंटेंट कार्रवाइयों, और MIME टाइप से किया जा सकता है. किसी एक डीप लिंक के लिए, कई मैच टाइप तय किए जा सकते हैं. हालांकि, ध्यान दें कि यूआरआई आर्ग्युमेंट मैचिंग को प्राथमिकता दी जाती है. इसके बाद, ऐक्शन और फिर एमआईएमई टाइप को प्राथमिकता दी जाती है.
यहां डीप लिंक का एक उदाहरण दिया गया है, जिसमें यूआरआई, ऐक्शन, और एमआईएम टाइप शामिल है:
<fragment android:id="@+id/a"
android:name="com.example.myapplication.FragmentA"
tools:layout="@layout/a">
<deepLink app:uri="www.example.com"
app:action="android.intent.action.MY_ACTION"
app:mimeType="type/subtype"/>
</fragment>
नेविगेशन एडिटर का इस्तेमाल करके, किसी डेस्टिनेशन के लिए इनपिमिट डीप लिंक भी बनाया जा सकता है. इसके लिए, यह तरीका अपनाएं:
- नेविगेशन एडिटर के डिज़ाइन टैब में, डीप लिंक के लिए डेस्टिनेशन चुनें.
- एट्रिब्यूट पैनल के डीप लिंक सेक्शन में, + पर क्लिक करें.
इसके बाद, डीप लिंक जोड़ें डायलॉग बॉक्स में, अपने डीप लिंक की जानकारी डालें.
यहां दी गई बातों का ध्यान रखें:
- बिना स्कीम वाले यूआरआई को http या https माना जाता है. उदाहरण के लिए,
www.google.com
,http://www.google.com
औरhttps://www.google.com
, दोनों से मेल खाता है. {placeholder_name}
के तौर पर मौजूद पाथ पैरामीटर प्लेसहोल्डर, एक या उससे ज़्यादा वर्णों से मैच करते हैं. उदाहरण के लिए,http://www.example.com/users/{id}
,http://www.example.com/users/4
से मैच होता है. नेविगेशन कॉम्पोनेंट, प्लेसहोल्डर के नामों को डीप लिंक डेस्टिनेशन के लिए तय किए गए आर्ग्युमेंट से मैच करके, प्लेसहोल्डर वैल्यू को सही टाइप में पार्स करने की कोशिश करता है. अगर एक ही नाम वाला कोई आर्ग्युमेंट तय नहीं किया गया है, तो आर्ग्युमेंट वैल्यू के लिए डिफ़ॉल्टString
टाइप का इस्तेमाल किया जाता है. शून्य या उससे ज़्यादा वर्णों से मैच करने के लिए, .* वाइल्डकार्ड का इस्तेमाल किया जा सकता है.- पाथ पैरामीटर के बजाय या उनके साथ क्वेरी पैरामीटर प्लेसहोल्डर का इस्तेमाल किया जा सकता है. उदाहरण के लिए,
http://www.example.com/users/{id}?myarg={myarg}
,http://www.example.com/users/4?myarg=28
से मैच होता है. - डिफ़ॉल्ट या वैल्यू न डालने की अनुमति वाले वैरिएबल के लिए, क्वेरी पैरामीटर प्लेसहोल्डर को मैच करने की ज़रूरत नहीं है. उदाहरण के लिए,
http://www.example.com/users/{id}?arg1={arg1}&arg2={arg2}
,http://www.example.com/users/4?arg2=28
याhttp://www.example.com/users/4?arg1=7
से मैच होता है. पाथ पैरामीटर के साथ ऐसा नहीं होता है. उदाहरण के लिए,http://www.example.com/users?arg1=7&arg2=28
ऊपर दिए गए पैटर्न से मेल नहीं खाता, क्योंकि ज़रूरी पाथ पैरामीटर नहीं दिया गया है. - अतिरिक्त क्वेरी पैरामीटर से, डीप लिंक यूआरआई के मैच होने पर कोई असर नहीं पड़ता. उदाहरण के लिए,
http://www.example.com/users/{id}
,http://www.example.com/users/4?extraneousParam=7
से मैच करता है, भले हीextraneousParam
को यूआरआई पैटर्न में तय न किया गया हो.
- बिना स्कीम वाले यूआरआई को http या https माना जाता है. उदाहरण के लिए,
(ज़रूरी नहीं) अपने-आप पुष्टि होने की सुविधा चुनें, ताकि Google यह पुष्टि कर सके कि आप यूआरआई के मालिक हैं. ज़्यादा जानकारी के लिए, Android ऐप्लिकेशन के लिंक की पुष्टि करना लेख पढ़ें.
जोड़ें पर क्लिक करें. चुने गए डेस्टिनेशन के ऊपर एक लिंक आइकॉन दिखता है. इससे पता चलता है कि डेस्टिनेशन में डीप लिंक है.
एक्सएमएल व्यू पर टॉगल करने के लिए, कोड टैब पर क्लिक करें. डेस्टिनेशन में नेस्ट किया गया
<deepLink>
एलिमेंट जोड़ा गया है:<deepLink app:uri="https://www.google.com" />
इंप्लिसिट डीप लिंकिंग की सुविधा चालू करने के लिए, आपको अपने ऐप्लिकेशन की
manifest.xml
फ़ाइल में भी बदलाव करने होंगे. किसी ऐसी ऐक्टिविटी में एक <nav-graph>
एलिमेंट जोड़ें जो किसी मौजूदा नेविगेशन ग्राफ़ पर ले जाता हो, जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.myapplication"> <application ... > <activity name=".MainActivity" ...> ... <nav-graph android:value="@navigation/nav_graph" /> ... </activity> </application> </manifest>
प्रोजेक्ट बनाते समय, नेविगेशन कॉम्पोनेंट, <nav-graph>
एलिमेंट को जनरेट किए गए <intent-filter>
एलिमेंट से बदल देता है, ताकि नेविगेशन ग्राफ़ में मौजूद सभी डीप लिंक से मैच किया जा सके.
इंप्लिसिट डीप लिंक को ट्रिगर करते समय, बैक स्टैक की स्थिति इस बात पर निर्भर करती है कि इंप्लिसिट Intent
को Intent.FLAG_ACTIVITY_NEW_TASK
फ़्लैग के साथ लॉन्च किया गया था या नहीं:
- अगर फ़्लैग सेट है, तो टास्क के बैक स्टैक को हटा दिया जाता है और उसे डीप लिंक डेस्टिनेशन से बदल दिया जाता है. साफ़ तौर पर डीप लिंकिंग की तरह, ग्राफ़ को नेस्ट करते समय, नेस्टिंग के हर लेवल से शुरुआती डेस्टिनेशन, यानी कि हैरारकी में हर
<navigation>
एलिमेंट का स्टार्ट डेस्टिनेशन भी स्टैक में जोड़ दिया जाता है. इसका मतलब है कि जब कोई उपयोगकर्ता डीप लिंक डेस्टिनेशन से 'वापस जाएं' बटन दबाता है, तो वह नेविगेशन स्टैक पर वापस उसी तरह से नेविगेट करता है जैसे कि वह आपके ऐप्लिकेशन में उसके एंट्री पॉइंट से आया हो. - अगर फ़्लैग सेट नहीं किया गया है, तो आप उस पिछले ऐप्लिकेशन के टास्क स्टैक पर बने रहेंगे जहां इंप्लिसिट डीप लिंक ट्रिगर हुआ था. इस मामले में, 'वापस जाएं' बटन आपको पिछले ऐप्लिकेशन पर ले जाता है. वहीं, 'अप' बटन, नेविगेशन ग्राफ़ में हैरारकी वाले पैरंट डेस्टिनेशन पर आपके ऐप्लिकेशन का टास्क शुरू करता है.
डीप लिंक मैनेज करना
हमारा सुझाव है कि नेविगेशन का इस्तेमाल करते समय, standard
के लिए हमेशा डिफ़ॉल्ट launchMode
का इस्तेमाल करें. standard
लॉन्च मोड का इस्तेमाल करते समय नेविगेशन, handleDeepLink()
को कॉल करके डीप लिंक को अपने-आप हैंडल करता है. ऐसा Intent
में किसी भी साफ़ तौर पर दिए गए या इंप्लिसिट डीप लिंक को प्रोसेस करने के लिए किया जाता है. हालांकि, अगर singleTop
जैसे किसी अन्य launchMode
का इस्तेमाल करते समय, Activity
का फिर से इस्तेमाल किया जाता है, तो यह अपने-आप नहीं होता. इस मामले में, handleDeepLink()
को onNewIntent()
में मैन्युअल तरीके से कॉल करना ज़रूरी है, जैसा कि इस उदाहरण में दिखाया गया है:
Kotlin
override fun onNewIntent(intent: Intent?) { super.onNewIntent(intent) navController.handleDeepLink(intent) }
Java
@Override protected void onNewIntent(Intent intent) { super.onNewIntent(intent); navController.handleDeepLink(intent); }
अन्य संसाधन
नेविगेशन के बारे में ज़्यादा जानने के लिए, यहां दिए गए लेख पढ़ें.