Authentification Apple sur Android
Copiez un prompt de configuration avec les étapes d'installation et le guide markdown complet pour ce plugin.
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
Comprendre le flux sur Android.
Section intitulée “Comprendre le flux sur Android.”Utilisez-moi 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 au courant des défis et du flux, commençons la configuration.
Créer l'ID du service
Section intitulée « Créer l'ID du 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 ne l'est pas, activez-la.
- Cliquez sur votre application
-
Retournez à tous
All Identifiers
-
Cliquez sur
App Idset allez àServices IDs
-
Créer un nouveau identifiant
-
Cliquez sur le bouton plus
-
Sélectionner
Servcice IDset cliquezContinue
-
Entrer une description et des identifiants et cliquez
Continuie.
-
Veuillez vérifier les détails et cliquez sur
Register
-
Cliquez sur le service créé récemment
-
Activer l'
Sign in with Appleoption
-
Configurer le
Sign In with Apple
-
Assurez-vous que le
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.
-
Confirmer les données et cliquez
Done
-
Cliquez sur
Continue
-
Cliquez sur
Save
-
Création de la clé
Section intitulée “Création de la clé”-
Retourner à tous les
All Identifiers
-
Cliquez sur
Keys
-
Cliquez sur l'icône du 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 la clé et téléchargez la clé.
-
Trouvez la clé téléchargée et enregistrez-la dans le dossier arrière-plan.
Obtenir l'ID d'équipe
Sous-section intitulée « Obtenir l'ID d'équipe »Pour utiliser Login with Apple sur Android, vous devez obtenir le Team IDIl sera utilisé dans l'arrière-plan.
-
Allez sur ce site web et faites défiler vers le bas
-
Trouvez la
Team ID
Configuration de la redirection de l'application
Section intitulée “Configuration de la redirection de l'application”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.
- Modifier le
AndroidManifest.xml-
Ouvrez le fichier, je vais utiliser
AndroidStudio
-
Trouvez la
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 le fichier MainActivity.java dans Android Studio
MainActivity
-
code pour ajouter à MainActivity pour gérer les liens profonds
@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 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 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 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' }})Créer l'application
Section intitulée “Créer l'application”-
Si vous n'avez pas encore d'ID d'application, cliquez sur le bouton plus
-
Sélectionner
App IDset cliquez sur continuer
-
Cliquez sur le type
Appet cliquezContinue
-
Entrer la description 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 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.