Passer au contenu principal
DeepLinking

Comment intégrer les liens universels dans Next.js avec Capacitor

Apprenez étape par étape comment configurer les liens universels pour votre application Next.js avec Capacitor sur les plateformes iOS et Android.

Martin Donadieu

Martin Donadieu

Spécialiste du contenu

Comment intégrer les liens universels dans Next.js avec Capacitor

Les liens universonnels sur iOS et les liens d'application sur Android permettent aux utilisateurs d'être redirigés directement dans votre application à partir d'un lien, en contournant le navigateur. Cela est particulièrement utile pour améliorer l'expérience utilisateur et maintenir le contexte d'une page web vers une application. Dans ce guide, nous allons passer en revue le processus de configuration de ces liens profonds pour une application Next.js en utilisant Capacitor.

La configuration des liens profonds ne nécessite pas beaucoup de code, mais elle implique une certaine configuration. À la fin de ce guide, vous serez en mesure de cliquer sur un lien comme https://www.capgo.app/details/22 et votre application s'ouvrira sur la page correcte si elle est installée.

Tout d'abord, nous allons créer une nouvelle application Next.js et une page de détails pour la tester :

npx create-next-app@latest capgoLinks
cd capgoLinks
mkdir pages/details
touch pages/details/[id].js
npm run build
npx cap add ios
npx cap add android

Assurez-vous que votre ID de bundle est correctement configuré dans le capacitor.config.json fichier, car il est crucial pour la configuration :

{
  "appId": "com.capgo.deeplinks",
  "appName": "capgoLinks",
  "webDir": "out",
  "bundledWebRuntime": false
}

Pour la navigation, Next.js utilise la navigation basée sur les fichiers, donc en créant un fichier à pages/details/[id].js, nous avons déjà configuré notre route sauvage.

Dans pages/details/[id].js, nous pouvons récupérer l'ID à partir de l'URL à l'aide du routeur intégré de Next.js :

import { useRouter } from 'next/router'

function DetailsPage() {
  const router = useRouter()
  const { id } = router.query

  return (
    <div>
      <p>My ID: {id}</p>
    </div>
  )
}

export default DetailsPage

Maintenant, traitons le appUrlOpen événement avec Capacitor. Cet événement est déclenché lorsque l'application est ouverte via un schéma d'URL personnalisé. Ajoutez un écouteur dans le pages/_app.js fichier :

import { useEffect } from 'react'
import { App } from '@capacitor/app'

function MyApp({ Component, pageProps }) {
  useEffect(() => {
    App.addListener('appUrlOpen', (event) => {
      const slug = event.url.split('.app').pop()
      if (slug)
        window.location.href = slug

    })
  }, [])

  return <Component {...pageProps} />
}

export default MyApp

Ce code écoute l' appUrlOpen événement et navigue vers la route appropriée dans votre application Next.js.

Configuration iOS

Pour iOS, vous aurez besoin d'un ID d'application avec les domaines associés activés. Créez un fichier apple-app-site-association avec le contenu suivant, en remplaçant YOURTEAMID et com.your.bundleid avec votre ID d'équipe et votre ID de paquet :

{
  "applinks": {
    "apps": [],
    "details": [
      {
        "appID": "YOURTEAMID.com.your.bundleid",
        "paths": ["*"]
      }
    ]
  }
}

Envoyez ce fichier dans le .well-known répertoire de votre domaine, le rendant accessible à https://www.capgo.app/.well-known/apple-app-site-association.

Dans Xcode, ajoutez le domaine à vos autorisations d'application en utilisant le format applinks:capgo.app.

Configuration Android

Pour les liens d'application Android, suivez ces étapes :

  1. Générez un fichier de clé de coffre si vous n'en avez pas un.
  2. Obtenez la empreinte SHA256 du coffre.
  3. Créez un fichier assetlinks.json avec votre nom de paquet et votre empreinte SHA256.
  4. Envoyez ce fichier dans le .well-known répertoire sur votre domaine.

Dans votre AndroidManifest.xml, ajoutez un intent-filter à l' activity élément qui gère les liens profonds :

<activity ...>
  <intent-filter android:autoVerify="true">
    <action android:name="android.intent.action.VIEW" />
    <category android:name="android.intent.category.DEFAULT" />
    <category android:name="android.intent.category.BROWSABLE" />
    <data android:scheme="https" android:host="capgo.app" />
  </intent-filter>
</activity>

Après avoir téléchargé le assetlinks.json fichier, vous pouvez le vérifier à l'aide de l'outil de liens numériques d'actifs de Google. Si tout est configuré correctement, vous verrez un signe de vérification vert.

Pour construire et signer votre application, utilisez les commandes suivantes :

cd android
./gradlew assembleRelease
cd ..
jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore my-release-key.keystore android/app/build/outputs/apk/release/app-release-unsigned.apk alias_name
zipalign -v 4 android/app/build/outputs/apk/release/app-release-unsigned.apk capgo.apk
adb install capgo.apk

Cela installera l'application signée sur votre appareil Android connecté.

Capacitor Configurez les paramètres de projet natif

Pour automatiser les paramètres de projet natif, considérez l'utilisation du Capacitor package de configuration. Installez-le dans votre projet :

npm install @capacitor/configure

Créez un capacitor.config.yaml fichier au niveau de racine de votre projet :

vars:
  BUNDLE_ID: com.capgo.deeplinks
  PACKAGE_NAME: com.capgo.deeplinks
platforms:
  ios:
    targets:
      App:
        bundleId: $BUNDLE_ID
    entitlements:
      - com.apple.developer.associated-domains: ['applinks:capgo.app']
  android:
    packageName: $PACKAGE_NAME

Exécutez l'outil de configuration avec cette configuration :

npx cap-config run capacitor.config.yaml

Cela appliquera les paramètres spécifiés dans le fichier YAML à vos projets natifs.

Conclusion

La mise en place des liens profonds avec Capacitor pour une application Next.js implique la configuration de votre domaine et des paramètres de projet pour les deux iOS et Android. Bien que le processus nécessite une attention aux détails, il est cependant plus fluide que les méthodes plus anciennes et ne nécessite pas d'extensions supplémentaires. Assurez-vous que les fichiers de vérification de domaine sont correctement servis et vérifiez-les avec les outils de plateforme correspondants. Une fois configuré, votre application s'ouvrira de manière fluide à partir de liens web, offrant une transition smooth pour vos utilisateurs de la web à l'application.

Si vous utilisez Comment intégrer les liens universels dans Next.js avec Capacitor pour planifier le travail des plugins natifs, connectez-le avec Capgo Répertoire des plugins pour le flux de travail du produit dans le répertoire de plugin Capgo les plugins Capacitor par Capgo pour le détail d'implémentation dans les plugins Capacitor par Capgo, Ajouter ou Mettre à Jour les Plugins pour le détail d'implémentation dans Ajouter ou Mettre à Jour les Plugins, Alternatives de Plugins d'Entreprise Ionic pour le flux de travail du produit dans Alternatives de Plugins d'Entreprise Ionic, et les builds natifs Capgo pour le flux de travail du produit dans les builds natifs Capgo.

Mises à jour en temps réel pour les applications Capacitor

Lorsqu'un bug du niveau web est en ligne, expédiez la correction à travers Capgo au lieu d'attendre des jours pour l'approbation de la boutique d'applications. Les utilisateurs reçoivent la mise à jour en arrière-plan tandis que les modifications natives restent dans le chemin de revue normal.

Démarrer maintenant

Dernières actualités de notre Blog

Capgo vous offre les meilleures informations dont vous avez besoin pour créer une application mobile vraiment professionnelle.