如要接收您建立的 Firebase Dynamic Links,您必須在應用程式中加入 Dynamic Links SDK,並建立實作 OnDynamicLinkReceived
虛擬函式的 firebase::dynamic_links::Listener
物件。
C++ SDK 適用於 Android 和 iOS,但每個平台都需要進行一些額外設定。
事前準備
如要使用 Firebase Dynamic Links,您必須先完成下列步驟:
註冊 C++ 專案並設定使用 Firebase。
如果您的 C++ 專案已使用 Firebase,則表示已為 Firebase 註冊及設定。
將 Firebase C++ SDK 新增至 C++ 專案。
請注意,將 Firebase 新增至 C++ 專案時,牽涉到 Firebase 控制台和開放式 C++ 專案中的工作。舉例來說,您可以從控制台下載 Firebase 設定檔,再移至 C++ 專案。
新增自訂網址配置 (僅限 iOS)
Firebase Dynamic Links C++ 用戶端程式庫會使用 iOS 上的自訂網址通訊協定來處理連結。您必須在應用程式中新增自訂網址配置,才能支援接收 Dynamic Links。
如要開啟專案設定,請按兩下左側樹狀檢視中的專案名稱。
從「TARGETS」(目標) 部分選取您的應用程式,選取「Info」(資訊) 分頁標籤,然後展開「URL Types」(網址類型) 部分。
按一下「+」按鈕,然後為已反轉的客戶端 ID 新增網址配置。如要找出這個值,請按照下列步驟操作:
開啟
設定檔,然後尋找GoogleService-Info.plist REVERSED_CLIENT_ID
鍵。複製該鍵的值,然後貼到設定頁面中的「網址配置」方塊中。
將其他欄位留白。
按一下「+」按鈕,然後新增第二個網址配置。這個值與應用程式的軟體包 ID 相同。
舉例來說,如果您的軟體包 ID 是
com.example.ios
,請在「URL Schemes」方塊中輸入該值。您可以在專案設定的「一般」分頁 (「Identity」>「Bundle Identifier」) 中找到應用程式的軟體包 ID。
接收 Dynamic Link
建立及初始化應用程式
您必須先建立並初始化 firebase::App
物件,才能檢查收到的 Dynamic Links。
包含 firebase::App
的標頭檔案:
#include "firebase/app.h"
接下來的步驟會因平台而異:
Android
建立 firebase::App
,並傳遞 JNI 環境和 jobject
參照至 Java 活動做為引數:
app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"), jni_env, activity);
iOS
建立 firebase::App
:
app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"));
實作 Listener 以檢查 Dynamic Links
如要檢查收到的 Dynamic Link,請實作並使用 firebase::dynamic_links::Listener
類別。
納入接收 Dynamic Links 的標頭檔案:
#include "firebase/dynamic_links.h"
初始化 Dynamic Links 程式庫:
::firebase::dynamic_links::Initialize(app, null);
建立實作 firebase::dynamic_links::Listener
的物件,並透過 SetListener()
將其提供給 Dynamic Links 程式庫,或將其做為第二個引數傳遞至 Initialize。
如要接收 Dynamic Links,Listener 類別必須實作 OnDynamicLinkReceived
虛擬函式。您可以覆寫方法,接收深層連結 (如果有)。
class Listener : public firebase::dynamic_links::Listener { public: // Called on the client when a dynamic link arrives. void OnDynamicLinkReceived( const firebase::dynamic_links::DynamicLink* dynamic_link) override { printf("Received link: %s", dynamic_link->url.c_str()); } };