page.link
सबडोमेन के बजाय, अपने डोमेन का इस्तेमाल करके, Dynamic Links के ब्रैंडिंग पर ज़्यादा कंट्रोल किया जा सकता है. कस्टम डोमेन की मदद से, Dynamic Links को इन उदाहरणों की तरह बनाया जा सकता है:
https://example.com/link-suffix https://example.com/links/promos/link-suffix https://links.example.com/link-suffix https://ex.amp.le/link-suffix
link-suffix से पहले के यूआरएल के हिस्से को यूआरएल प्रीफ़िक्स कहा जाता है. इसमें आपका कस्टम Dynamic Link डोमेन और पाथ प्रीफ़िक्स, दोनों शामिल होते हैं. Dynamic Links बनाते समय, आपको यूआरएल प्रीफ़िक्स देना होगा.
कस्टम डोमेन सेट अप करने के लिए, आपके Firebase प्रोजेक्ट में एडिटर या मालिक की अनुमति होनी चाहिए.
Dynamic Links के लिए अपने वेब डोमेन का इस्तेमाल करना
Dynamic Links और अपने वेब पेजों, यूनिवर्सल लिंक, और ऐप्लिकेशन लिंक के लिए, एक ही डोमेन का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करने पर आपको यह ध्यान रखना होगा कि आपके Dynamic Link यूआरएल, आपके वेब यूआरएल से मेल न खाएं. किसी खास यूआरएल प्रीफ़िक्स का इस्तेमाल करने के लिए Dynamic Links को कॉन्फ़िगर करने पर, उस प्रीफ़िक्स से शुरू होने वाले सभी यूआरएल को Dynamic Links माना जाता है. इसलिए, होस्ट किए गए सामान्य कॉन्टेंट पर ले जाने के लिए, उस प्रीफ़िक्स वाले यूआरएल का इस्तेमाल नहीं किया जा सकता.
उदाहरण के लिए, अगर आपको रिसॉर्स https://example.com/my-resource
(वेब पेज, यूनिवर्सल लिंक या ऐप्लिकेशन लिंक) के लिए Dynamic Link बनाना है, तो Dynamic Links यूआरएल प्रीफ़िक्स के तौर पर https://example.com/
का इस्तेमाल नहीं किया जा सकता. ऐसा करने पर, https://example.com/my-resource
को Dynamic Link माना जाएगा.
इसके बजाय, आपको किसी दूसरे डोमेन या पाथ प्रीफ़िक्स के साथ यूआरएल प्रीफ़िक्स का इस्तेमाल करना होगा.
इसलिए, यहां दिए गए लंबी अवधि के Dynamic Links (और उससे मिलते-जुलते शॉर्ट लिंक) ठीक से काम नहीं करेंगे, क्योंकि link
पैरामीटर से तय किए गए यूआरएल, Dynamic Link यूआरएल प्रीफ़िक्स, https://example.com/
से शुरू होते हैं:
https://example.com/?link=https://example.com/my-resource https://example.com/?link=https://example.com/resources/my-resource
हालांकि, यहां दिए गए लंबी अवधि वाले Dynamic Links (और मिलते-जुलते शॉर्ट लिंक) काम कर सकते हैं, क्योंकि यूआरएल के प्रीफ़िक्स, link
यूआरएल से मेल नहीं खाते:
https://link.example.com/?link=https://example.com/my-resource https://example.com/links/?link=https://example.com/my-resource https://ex.amp.le/?link=https://example.com/my-resource
Firebase कंसोल में कस्टम डोमेन सेट अप करें
आम तौर पर, Firebase कंसोल में जाकर, कस्टम डोमेन को पूरी तरह से सेट अप किया जा सकता है. ऐसा करने के लिए:
अगर आपने अपने प्रोजेक्ट के लिए Firebase Hosting को सेट अप नहीं किया है, तो Firebase कंसोल का Hosting पेज खोलें. इसके बाद, शुरू करें पर क्लिक करें और सेटअप के निर्देशों पर क्लिक करें. फ़िलहाल, आपको बताए गए चरणों को पूरा करने की ज़रूरत नहीं है.
Firebase कंसोल का Dynamic Links पेज खोलें.
अगर आपने पहले Dynamic Links का इस्तेमाल नहीं किया है, तो शुरू करें पर क्लिक करें. इसके अलावा, ड्रॉप-डाउन मेन्यू में जाकर, यूआरएल प्रीफ़िक्स जोड़ें पर क्लिक करें.
इसके बाद, सेटअप विज़र्ड को पूरा करें. इसके लिए, उस डोमेन और पाथ प्रीफ़िक्स की जानकारी दें जिसका इस्तेमाल आपको करना है.
सिर्फ़ iOS के लिए: अपने Xcode प्रोजेक्ट की
Info.plist
फ़ाइल में,FirebaseDynamicLinksCustomDomains
नाम की एक कुंजी बनाएं और उसे अपने ऐप्लिकेशन के Dynamic Links यूआरएल के प्रीफ़िक्स पर सेट करें. उदाहरण के लिए:<key>FirebaseDynamicLinksCustomDomains</key> <array> <string>https://example.com/link</string> <string>https://example.com/promos</string> </array>
कस्टम डोमेन को मैन्युअल तरीके से सेट अप करें
कुछ मामलों में, आपको कस्टम डोमेन को मैन्युअल तरीके से सेट अप करना पड़ता है. जैसे, जब आपके पास Dynamic Links के लिए पहले से कोई कस्टम डोमेन सेट अप हो और आपको कोई दूसरा डोमेन जोड़ना हो या जब कोई ऐसा डोमेन जोड़ा जा रहा हो जो पहले से किसी Hosting साइट से कनेक्ट हो.
इसके लिए:
अगर आपने अब तक अपने डोमेन को Firebase Hosting से कनेक्ट नहीं किया है, तो अब कर लें.
Firebase Hosting के साथ अपना डोमेन सेट अप करने के लिए, लोकल प्रोजेक्ट डायरेक्ट्री में कॉन्फ़िगरेशन फ़ाइल
firebase.json
बनाना भी शामिल है.Firebase सीएलआई को नए वर्शन (v6.5.0 या उसके बाद के वर्शन) पर अपडेट करें.
अपने प्रोजेक्ट की
firebase.json
फ़ाइल में, Hosting साइट को Dynamic Links के लिए कॉन्फ़िगर करें. अगर आपके प्रोजेक्ट में एक से ज़्यादा साइटें हैं, तो उस डोमेन से जुड़ी साइट को कॉन्फ़िगर करना न भूलें जिसका आपको इस्तेमाल करना है.appAssociation
कोAUTO
पर सेट करें. इस सेटिंग की मदद से, Hosting अनुरोध किए जाने परassetlinks.json
औरapple-app-site-association
फ़ाइलों को डाइनैमिक तौर पर जनरेट करता है.फिर से लिखने के नियमों को
dynamicLinks
पर सेट करकेtrue
पर सेट करके वे पथ उपसर्ग तय करें, जिन्हें आप Dynamic Links के लिए इस्तेमाल करना चाहते हैं. इन पाथ के लिए किए गए अनुरोध, Dynamic Links पर भेजे जाते हैं.यूआरएल के पाथ को फिर से लिखने वाले नियमों के उलट, Dynamic Link रीराइट नियमों में रेगुलर एक्सप्रेशन शामिल नहीं किए जा सकते.
अगर आपकी साइट के लिए एक से ज़्यादा रीराइट नियम हैं, तो ध्यान रखें कि Hosting, अनुरोध से मैच होने वाले पहले रीराइट नियम को लागू करता है.
उदाहरण के लिए:
"hosting": { // ... "appAssociation": "AUTO", "rewrites": [ { "source": "/promos/**", "dynamicLinks": true }, { "source": "/links/share/**", "dynamicLinks": true } ] }
ऊपर दिए गए कॉन्फ़िगरेशन की मदद से, यूआरएल प्रीफ़िक्स के साथ Dynamic Links बनाया जा सकता है. जैसे:
https://your-domain/promos/link-suffix https://your-domain/links/share/link-suffix
अगर इस डोमेन का इस्तेमाल सिर्फ़ Dynamic Links के लिए किया जाता है, तो
/**
के सोर्स पाथ का इस्तेमाल करके, Dynamic Links को बिना पाथ प्रीफ़िक्स के बनाया जा सकता है:{ "source": "/**", "dynamicLinks": true }
ऊपर दिए गए नियम की मदद से, Dynamic Links बनाए जा सकते हैं. इसका उदाहरण नीचे दिया गया है:
https://your-domain/link-suffix
Hosting कॉन्फ़िगरेशन में किए गए बदलावों को डिप्लॉय करें:
firebase deploy --only hosting
(ज़रूरी नहीं) Hosting REST API का इस्तेमाल करके, डिप्लॉय किए गए
firebase.json
कॉन्टेंट की जांच की जा सकती है.सिर्फ़ iOS के लिए: अपने Xcode प्रोजेक्ट की
Info.plist
फ़ाइल में,FirebaseDynamicLinksCustomDomains
नाम की एक कुंजी बनाएं और उसे अपने ऐप्लिकेशन के Dynamic Links यूआरएल के प्रीफ़िक्स पर सेट करें. उदाहरण के लिए:<key>FirebaseDynamicLinksCustomDomains</key> <array> <string>https://example.com/promos</string> <string>https://example.com/links/share</string> </array>
Dynamic Links और Hosting के लिए प्राथमिकता का क्रम
Dynamic Links के लिए, होस्टिंग की प्राथमिकता के क्रम के बारे में खास तौर पर ध्यान रखें.
- पक्का करें कि आपका Dynamic Links यूआरएल प्रीफ़िक्स, ज़्यादा प्राथमिकता वाले होस्टिंग कॉन्फ़िगरेशन से मेल न खाता हो. उदाहरण के लिए, होस्ट किए गए स्टैटिक कॉन्टेंट को हमेशा रीराइट करने से ज़्यादा प्राथमिकता दी जाती है.
rewrites
एट्रिब्यूट में, Hosting रिस्पॉन्स, अनुरोध किए गए पाथ को कैप्चर करने वाले पहलेsource
ग्लोब के बताए गए नियम के मुताबिक होगा.
उदाहरण के लिए, अगर आपने your-domain/source-path/link-suffix
के लिए Dynamic Link सेट अप किया है, लेकिन आपके पास your-domain/source-path/index.html
पर स्टैटिक कॉन्टेंट भी है, तो स्टैटिक कॉन्टेंट को प्राथमिकता दी जाएगी. असली उपयोगकर्ता को Dynamic Link के बजाय index.html
दिखेगा. इसी तरह, अगर आपके पास your-domain/source-path/link-suffix
पर स्टैटिक कॉन्टेंट है, तो असली उपयोगकर्ता को Dynamic Link के बजाय स्टैटिक कॉन्टेंट दिखेगा.
अगर आपको Dynamic Links और Hosting, दोनों के लिए एक ही ब्रैंडिंग का इस्तेमाल करना है, तो Dynamic Links के यूआरएल प्रीफ़िक्स के लिए इनमें से कोई एक विकल्प चुनें:
पाथ प्रीफ़िक्स से मैच करने के लिए, अपना
source
एट्रिब्यूट सेट करें. उदाहरण के लिए, अगर आपके पासexample.com
का कस्टम डोमेन है, तो आपका रीराइट नियम यह हो सकता है:// Domain is example.com "rewrites": [ { "source": "/links/**", // Dynamic Links start with "https://example.com/links/" "dynamicLinks": true } ]
Dynamic Links के इस्तेमाल के लिए एक सबडोमेन सेट अप करें. इसके बाद, अपने
source
एट्रिब्यूट को उस सबडोमेन से मेल खाने के लिए सेट करें. उदाहरण के लिए, अगर आपके पासlinks.example.com
का सबडोमेन है, तो इसे रीराइट करने का नियम यह हो सकता है:// Domain is links.example.com "rewrites": [ { "source": "/**", // Dynamic Links start with "https://links.example.com/" "dynamicLinks": true } ]