หากต้องการรับ Firebase Dynamic Links ที่ คุณสร้างขึ้น คุณต้องรวม Dynamic Links SDK ในแอปของคุณ และสร้าง firebase::dynamic_links::Listener
ออบเจ็กต์ที่ใช้ฟังก์ชันเสมือน OnDynamicLinkReceived
C++ SDK ใช้งานได้กับทั้ง Android และ iOS โดยต้องมีการตั้งค่าเพิ่มเติมบางอย่างสำหรับแต่ละแพลตฟอร์ม
ก่อนที่คุณจะเริ่มต้น
ก่อนที่คุณจะสามารถใช้ Firebase Dynamic Links คุณต้อง:
ลงทะเบียนโปรเจ็กต์ C++ ของคุณและกำหนดค่าให้ใช้ Firebase
หากโปรเจ็กต์ C++ ของคุณใช้ Firebase อยู่แล้ว แสดงว่ามีการลงทะเบียนและกำหนดค่าสำหรับ Firebase แล้ว
เพิ่ม Firebase C++ SDK ในโครงการ C++ ของคุณ
โปรดทราบว่าการเพิ่ม Firebase ในโปรเจ็กต์ C++ ของคุณเกี่ยวข้องกับงานทั้งใน คอนโซล Firebase และในโปรเจ็กต์ C++ แบบเปิดของคุณ (เช่น คุณดาวน์โหลดไฟล์กำหนดค่า Firebase จากคอนโซล จากนั้นย้ายไฟล์เหล่านี้ไปยังโปรเจ็กต์ C++)
เพิ่มรูปแบบ URL ที่กำหนดเอง (สำหรับ iOS เท่านั้น)
ไลบรารีไคลเอนต์ Firebase Dynamic Links C++ ใช้รูปแบบ URL ที่กำหนดเองบน iOS เพื่อประมวลผลลิงก์ คุณต้องเพิ่มรูปแบบ URL ที่กำหนดเองในแอปของคุณเพื่อรองรับการรับลิงก์แบบไดนามิก
หากต้องการเปิดการกำหนดค่าโครงการ ให้ดับเบิลคลิกที่ชื่อโครงการในมุมมองแบบต้นไม้ด้านซ้าย
เลือกแอปของคุณจากส่วน เป้าหมาย จากนั้นเลือกแท็บ ข้อมูล จากนั้นขยายส่วน ประเภท URL
คลิกปุ่ม + จากนั้นเพิ่มรูปแบบ URL สำหรับรหัสไคลเอ็นต์ที่ย้อนกลับ หากต้องการค้นหาค่านี้:
เปิดไฟล์กำหนดค่า
จากนั้นมองหาคีย์GoogleService-Info.plist REVERSED_CLIENT_ID
คัดลอกค่าของคีย์นั้น แล้ววางลงในช่อง URL Schemes ในหน้าการกำหนดค่า
เว้นช่องอื่นๆ ว่างไว้
คลิกปุ่ม + จากนั้นเพิ่มรูปแบบ URL ที่สอง รหัสนี้เหมือนกับรหัสบันเดิลของแอปของคุณ
ตัวอย่างเช่น หากรหัสบันเดิลของคุณคือ
com.example.ios
ให้พิมพ์ค่านั้นในช่อง URL Schemesคุณสามารถค้นหารหัสบันเดิลของแอปได้ในแท็บ ทั่วไป ของการกำหนดค่าโปรเจ็กต์ ( ข้อมูลประจำตัว > ตัวระบุบันเดิล )
รับลิงก์ไดนามิก
สร้างและเริ่มต้นแอพ
ก่อนที่คุณจะตรวจสอบไดนามิกลิงก์ที่ได้รับ คุณจะต้องสร้างและเริ่มต้นวัตถุ firebase::App
รวมไฟล์ส่วนหัวสำหรับ firebase::App
:
#include "firebase/app.h"
ส่วนถัดไปจะแตกต่างกันไปตามแพลตฟอร์มของคุณ:
แอนดรอยด์
สร้าง firebase::App
ผ่านสภาพแวดล้อม JNI และการอ้างอิง jobject
ไปยัง Java Activity เป็นอาร์กิวเมนต์:
app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"), jni_env, activity);
iOS
สร้าง firebase::App
:
app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"));
ใช้ Listener เพื่อตรวจสอบลิงก์แบบไดนามิก
หากต้องการตรวจสอบลิงก์แบบไดนามิกที่ได้รับ ให้นำไปใช้และใช้คลาส firebase::dynamic_links::Listener
รวมไฟล์ส่วนหัวสำหรับการรับลิงก์แบบไดนามิก:
#include "firebase/dynamic_links.h"
เริ่มต้น ไลบรารีลิงก์แบบไดนามิก:
::firebase::dynamic_links::Initialize(app, null);
สร้างวัตถุที่ใช้ firebase::dynamic_links::Listener
และส่งไปยังไลบรารี Dynamic Links ด้วย SetListener()
หรือส่งเป็นอาร์กิวเมนต์ที่สองเพื่อ Initialize
ในการรับลิงก์แบบไดนามิก คลาส 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()); } };