Authentification Apple sur Android
Copiez une commande de configuration avec les étapes d'installation et le guide Markdown complet pour ce plugin.
Le login Apple sur Android est un peu hacky. Apple n'a pas de support officiel pour Sign in with Apple sur Android, donc la solution est légèrement hacky.
L'Android utilise actuellement une fenêtre de Chrome pour afficher un site Web OAuth2. Cette approche présente les défis :
- Configuration difficile
- Un backend est requis
Comprendre le flux sur Android.
Section intitulée “Comprendre le flux sur Android.”Utilisez un diagramme pour expliquer le flux sur Android :
flowchart TD
A("await SocialLogin.login()") -->|Handled in the plugin|B(Generate the login URL)
B --> |Pass the link| C(Open the Chrome browser)
C --> D(Wait for the user to login)
D --> |Apple redirects to your backend|E(Handle the data returned from Apple)
E --> F(Redirect back to the app)
F --> G(Return to JS)
Maintenant que vous êtes conscient des défis et du flux, commençons la configuration.
Création de l'ID de service
Section intitulée “Création de l'ID de service”-
Se connecter à Portail du développeur Apple.
-
Cliquez sur
Identifiers.
Vous devriez voir une page qui ressemble à ceci :
- Assurez-vous que ce champ dit
App IDs - Assurez-vous que vous pouvez trouver votre ID d'application.
- Assurez-vous que ce champ dit
-
Assurez-vous que la
Sign in with Applecapacité est activée pour votre application- Cliquez sur votre application
- Assurez-vous que la
Sign in with Applecapacité est activée
- Si elle n'est pas activée, activez-la.
- Cliquez sur votre application
-
Retour à tous
All Identifiers
-
Cliquez sur
App Idset allez àServices IDs
-
Créez un nouveau identifiant
-
Cliquez sur le bouton plus
-
Sélectionner
Servcice IDset cliquezContinue
-
Entrez une description et des identifiants et cliquez
Continuie.
-
Veuillez vérifier les détails et cliquez sur
Register
-
Cliquez sur le service ID nouvellement créé
-
Activer l'
Sign in with Appleoption
-
Configurer l'
Sign In with Apple
-
Vérifiez que l'
Primary App IDest défini sur l'ID d'application configuré dans l'étape précédente
-
Ajoutez le domaine sur lequel vous allez héberger votre backend.
-
Confirmation de la configuration de l'URL de retour et du domaine
Done
-
Bouton Continuer pour la configuration du service
Continue
-
Bouton Continuer
Save
-
Création de la clé
Section intitulée “Création de la clé”-
Retour à tous
All Identifiers
-
Cliquez sur
Keys
-
Cliquez sur l'icône plus
-
Nommez votre clé
-
Sélectionnez
Sign in with Appleet cliquezConfigure
-
Sélectionnez l'ID d'application principal, et appuyez sur
Save
-
Cliquez sur
Continue
-
Cliquez sur
Register
-
Copiez l'ID de clé et téléchargez la clé.
-
Trouvez le fichier téléchargé et enregistrez-le dans le dossier du backend.
Récupérer l'ID d'équipe
Section intitulée « Récupérer l'ID de l'équipe »Pour utiliser Login with Apple sur Android, vous devez récupérer le Team ID . Il sera utilisé dans le backend.
-
Allez à ce site web et descendez
-
Trouvez la
Team ID
Configuration de la redirection de l'application
Section intitulée « Configuration de la redirection de l'application »Comme vous avez vu dans le diagramme, le backend effectue une étape appelée Redirect back to the app. Cette opération nécessite des modifications manuelles dans votre application.
- Modifier le
AndroidManifest.xml-
Ouvrez le fichier, je vais utiliser
AndroidStudio
-
Trouvez le
MainActivityet ajoutez le filtre d'intention suivant
<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>
-
- Modifier le
MainActivity-
Veuillez ouvrir
MainActivity
-
Ajoutez le code: suivant
@Overrideprotected 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);}
-
Configuration backend
Section intitulée “Configuration backend”Un backend est requis pour Android, mais la configuration d'un backend impactera également IOS. Un exemple de backend est fourni ici
Cet exemple fournit les éléments suivants :
- Une base de données JSON simple
- Un 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 serviceIOS_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"}En utilisant le plugin
Section intitulée “En utilisant le plugin”L'utilisation de la login fonction ne change pas, c'est la même chose que pour IOS. Veuillez consulter 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' }})Création de l'application
Titre de la section « Création de l'application »-
Si vous n'avez pas encore d'ID d'application, cliquez sur le bouton plus
-
Sélectionner
App IDsCliquez sur continuer
-
Cliquez sur le type
AppSélectionner le type d'applicationContinue
-
Entrer la description de l'application et l'ID de l'application
-
Activer
Sign with Applecapacité
-
Cliquez
Continue
-
Confirmer les détails et cliquez
Register
Continuez de l'authentification Apple sur Android
Section intitulée “Continuez de l'authentification Apple sur Android”Si vous utilisez Authentification Apple sur Android pour planifier l'authentification et les flux de compte, connectez-le avec Utiliser @capgo/capacitor-login-social pour la capacité native dans Utiliser @capgo/capacitor-login-social, @capgo/capacitor-login-social pour le détail d'implémentation dans @capgo/capacitor-login-social, @capgo/capacitor-passkey pour le détail d'implémentation dans @capgo/capacitor-passkey, @capgo/capacitor-biométrique-native pour le détail d'implémentation dans @capgo/capacitor-biométrique-native, et L'authentification à deux facteurs pour le détail d'implémentation dans L'authentification à deux facteurs.