获取我们在 Firebase 峰会上发布的所有信息,了解 Firebase 可如何帮助您加快应用开发速度并满怀信心地运行应用。了解详情

Recibir enlaces dinámicos con C++

Para recibir los Firebase Dynamic Links que creó , debe incluir el SDK de Dynamic Links en su aplicación y crear un firebase::dynamic_links::Listener que implemente la función virtual OnDynamicLinkReceived .

El SDK de C++ funciona tanto para Android como para iOS, y se requiere alguna configuración adicional para cada plataforma.

Antes de que empieces

Antes de poder usar Firebase Dynamic Links , debe hacer lo siguiente:

  • Registre su proyecto C++ y configúrelo para usar Firebase.

    Si su proyecto de C++ ya usa Firebase, entonces ya está registrado y configurado para Firebase.

  • Agrega el SDK de Firebase C++ a tu proyecto de C++.

Tenga en cuenta que agregar Firebase a su proyecto de C++ implica tareas tanto en la consola de Firebase como en su proyecto de C++ abierto (por ejemplo, descarga archivos de configuración de Firebase desde la consola y luego los mueve a su proyecto de C++).

Agregue esquemas de URL personalizados (solo para iOS)

La biblioteca cliente de Firebase Dynamic Links C++ usa esquemas de URL personalizados en iOS para procesar enlaces. Debe agregar esquemas de URL personalizados a su aplicación para admitir la recepción de Dynamic Links.

  1. Para abrir la configuración de su proyecto, haga doble clic en el nombre del proyecto en la vista de árbol de la izquierda.

  2. Seleccione su aplicación de la sección OBJETIVOS , luego seleccione la pestaña Información , luego expanda la sección Tipos de URL .

  3. Haga clic en el botón + , luego agregue un esquema de URL para su ID de cliente invertida. Para encontrar este valor:

    1. Abra el archivo de configuración GoogleService-Info.plist , luego busque la clave REVERSED_CLIENT_ID .

    2. Copie el valor de esa clave, luego péguelo en el cuadro Esquemas de URL en la página de configuración.

    3. Deje los otros campos en blanco.

  4. Haga clic en el botón + , luego agregue un segundo esquema de URL. Este es el mismo que el ID del paquete de su aplicación.

    Por ejemplo, si su ID de paquete es com.example.ios , escriba ese valor en el cuadro Esquemas de URL .

    Puede encontrar el ID del paquete de su aplicación en la pestaña General de la configuración del proyecto ( Identidad > Identificador del paquete).

Recibir un vínculo dinámico

Crear e inicializar la aplicación

Antes de que pueda verificar los vínculos dinámicos recibidos, deberá crear e inicializar un objeto firebase::App .

Incluya el archivo de encabezado para firebase::App :

#include "firebase/app.h"

La siguiente parte varía dependiendo de su plataforma:

Androide

Crea firebase::App , pasando el entorno JNI y una referencia del jobject de trabajo a la actividad de Java como argumentos:

app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"), jni_env, activity);

iOS

Crea la base de firebase::App :

app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"));

Implementar Listener para verificar Dynamic Links

Para buscar un vínculo dinámico recibido, implemente y use la firebase::dynamic_links::Listener .

Incluya el archivo de encabezado para recibir Dynamic Links:

#include "firebase/dynamic_links.h"

Inicializar la biblioteca de Dynamic Links:

::firebase::dynamic_links::Initialize(app, null);

Cree un objeto que implemente firebase::dynamic_links::Listener y suminístrelo a la biblioteca de Dynamic Links con SetListener() o páselo como segundo argumento a Initialize .

Para recibir Dynamic Links, su clase Listener debe implementar la función virtual OnDynamicLinkReceived . Al anular el método, puede recibir un enlace profundo, si se recibió uno.

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());
  }
};