Aller directement au contenu

Authentification Apple sur Android

GitHub

Le login Apple sur Android est un peu malin. Apple n'a pas de support officiel pour Sign in with Apple sur Android, donc la solution est légèrement malin.

Android utilise actuellement une fenêtre de Chrome pour afficher un site Web OAuth2. Cette approche présente les défis :

  • Configuration difficile
  • Un serveur backend est requis

Utilisez-moi un diagramme pour expliquer le flux sur Android :

Maintenant que vous êtes au courant des défis et du flux, commençons la configuration.

  1. Se connecter à Portail du développeur Apple.

  2. Cliquez sur Identifiers.

    Section Identifiants du Portail du développeur Apple

    Vous devriez voir une page qui ressemble à ceci :

    Écran Identifiants du Portail du développeur Apple
    1. Assurez-vous que ce champ dit App IDs
    2. Assurez-vous que vous pouvez trouver votre ID d'application.
  3. Assurez-vous que la Sign in with Apple capacité est activée pour votre application

    1. Cliquez sur votre application Sélectionnez votre application de la liste
    2. Assurez-vous que la Sign in with Apple capacité est activée Case de sélection de la capacité Apple Sign in
    3. Si elle ne l'est pas, activez-la.
  4. Retournez à tous All Identifiers

    Tous les identifiants navigation button
  5. Cliquez sur App Ids et allez à Services IDs

    Navigation vers la section des identifiants de services
  6. Créer un nouveau identifiant

    1. Cliquez sur le bouton plus

      Ajouter un ID de service button
    2. Sélectionner Servcice IDs et cliquez Continue

      Option de sélection des ID de services
    3. Entrer une description et des identifiants et cliquez Continuie.

      Entrer les détails de l'ID de service
    4. Veuillez vérifier les détails et cliquez sur Register

      Confirmation de l'enregistrement de l'ID du service
    5. Cliquez sur le service créé récemment

      Sélectionner l'ID du service créé récemment
    6. Activer l' Sign in with Apple option

      Activation de la connexion avec Apple pour l'ID du service
    7. Configurer le Sign In with Apple

      Configurer le bouton de connexion avec Apple
    8. Assurez-vous que le Primary App ID est défini sur l'ID d'application configuré dans l'étape précédente

      Définir le champ ID d'application principal
    9. Ajoutez le domaine sur lequel vous allez héberger votre backend.

      Définir les champs domaine et URL de retour
    10. Confirmer les données et cliquez Done

      Configuration de domaine et URL de retour en cours de confirmation
    11. Cliquez sur Continue

      Continuer la configuration du service
    12. Cliquez sur Save

      Enregistrer la configuration du service
  1. Retourner à tous les All Identifiers

    Tous les identifiants
  2. Cliquez sur Keys

    Section Clés dans le Portail Apple Developer
  3. Cliquez sur l'icône du plus

    Bouton d'ajout de nouvelle clé
  4. Nommez votre clé

    Champ de saisie du nom de clé
  5. Sélectionnez Sign in with Apple et cliquez Configure

    Activer et configurer Sign in with Apple pour la clé
  6. Sélectionnez l'ID d'application principal, et appuyez sur Save

    Sélectionner l'ID d'application principal pour la clé
  7. Cliquez sur Continue

    Bouton de poursuite de la configuration de la clé
  8. Cliquez sur Register

    Bouton d'enregistrement de la clé
  9. Copiez l'ID de la clé et téléchargez la clé.

    Écran de la clé ID et du bouton de téléchargement
  10. Trouvez la clé téléchargée et enregistrez-la dans le dossier arrière-plan.

    Fichier de clé téléchargée

Pour utiliser Login with Apple sur Android, vous devez obtenir le Team IDIl sera utilisé dans l'arrière-plan.

  1. Allez sur ce site web et faites défiler vers le bas

  2. Trouvez la Team ID

    Emplacement de l'ID d'équipe dans le compte de développeur

Comme vous l'avez vu dans le diagramme, le backend effectue une étape appelée Redirect back to the app. Cela nécessite des modifications manuelles dans votre application.

  1. Modifier le AndroidManifest.xml
    1. Ouvrez le fichier, je vais utiliser AndroidStudio

      Fichier AndroidManifest.xml dans Android Studio
    2. Trouvez la MainActivity et ajoutez le filtre d'intention suivant

      Filtre d'intention code à ajouter dans MainActivity
      <intent-filter>
      <action android:name="android.intent.action.VIEW" />
      <category android:name="android.intent.category.DEFAULT" />
      <category android:name="android.intent.category.BROWSABLE" />
      <data android:scheme="capgo-demo-app" android:host="path" />
      </intent-filter>
  2. Modifier le MainActivity
    1. Veuillez ouvrir le fichier MainActivity.java dans Android Studio MainActivity

      Ajoutez les lignes suivantes __CAPGO_KEEP_0__:
    2. code pour ajouter à MainActivity pour gérer les liens profonds

      Code to add to MainActivity for handling deep links
      @Override
      protected void onNewIntent(Intent intent) {
      String action = intent.getAction();
      Uri data = intent.getData();
      if (Intent.ACTION_VIEW.equals(action) && data != null) {
      PluginHandle pluginHandle = getBridge().getPlugin("SocialLogin");
      if (pluginHandle == null) {
      Log.i("Apple Login Intent", "SocialLogin login handle is null");
      return;
      }
      Plugin plugin = pluginHandle.getInstance();
      if (!(plugin instanceof SocialLoginPlugin)) {
      Log.i("Apple Login Intent", "SocialLogin plugin instance is not SocialLoginPlugin");
      return;
      }
      ((SocialLoginPlugin) plugin).handleAppleLoginIntent(intent);
      return;
      }
      super.onNewIntent(intent);
      }

Un backend est requis pour Android, mais la configuration d'un backend affectera également l'IOS. Un exemple de backend est fourni ici

Cet exemple fournit les éléments suivants :

  • Une base de données JSON simple
  • A moyen de demander le JWT auprès des serveurs d'Apple
  • Une vérification JWT simple

Étant donné tout ce que j'ai dit dans ce tutoriel, voici comment cette env section ressemblerait :

  • ANDROID_SERVICE_ID = ID de service
  • IOS_SERVICE_ID = ID d'application
env: {
PRIVATE_KEY_FILE: "AuthKey_U93M8LBQK3.p8",
KEY_ID: "U93M8LBQK3",
TEAM_ID: "UVTJ336J2D",
ANDROID_SERVICE_ID: "ee.forgr.io.ionic.starter.service2",
IOS_SERVICE_ID: "me.wcaleniewolny.test.ionic.vue",
PORT: 3000,
REDIRECT_URI: "https://xyz.wcaleniewolny.me/login/callback",
BASE_REDIRECT_URL: "capgo-demo-app://path"
}

L'utilisation de la login fonction ne change pas, c'est la même chose que sur IOS. Veuillez jeter un coup d'œil à cette section pour plus d'informations. Cependant, la initialize méthode change un peu.

await SocialLogin.initialize({
apple: {
clientId: 'ee.forgr.io.ionic.starter.service2',
redirectUrl: 'https://appleloginvps.wcaleniewolny.me/login/callback'
}
})
  1. Si vous n'avez pas encore d'ID d'application, cliquez sur le bouton plus

    Bouton plus pour ajouter un nouvel identifiant
  2. Sélectionner App IDs et cliquez sur continuer

    Sélection des types d'ID d'application
  3. Cliquez sur le type App et cliquez Continue

    Sélectionner le type d'application
  4. Entrer la description et l'ID de l'application

    Entrer la description de l'application et l'ID de l'application
  5. Activer Sign with Apple capacité

    Activation de la capacité de connexion avec Apple
  6. Cliquez Continue

    Bouton Continuer pour l'enregistrement de l'application
  7. Confirmer les détails et cliquez Register

    Confirmation des détails d'enregistrement de l'application

Si vous utilisez L'authentification Apple sur Android pour planifier l'authentification et les flux de compte, connectez-le avec En utilisant @capgo/capacitor-social-login pour la capacité native en utilisant En @capgo/capacitor-social-login, @capgo/capacitor-social-login pour le détail d'implémentation en @capgo/capacitor-social-login, @capgo/capacitor-passkey pour le détail d'implémentation en @capgo/capacitor-passkey, @capgo/capacitor-native-biometric pour les détails d'implémentation dans @capgo/capacitor-native-biometric, et L'authentification à deux facteurs pour les détails d'implémentation dans L'authentification à deux facteurs.