Connexion Google sur iOS
Copier un prompt de configuration avec les étapes d'installation et le guide markdown complet pour ce plugin.
Introduction
Section intitulée “Introduction”Dans ce guide, vous apprendrez à configurer l'authentification Google avec Capgo Social Login pour iOS. Je suppose que vous avez déjà lu le guide de configuration générale. Utilisation de l'authentification Google sur iOS.
Section intitulée “Utilisation de l'authentification Google sur iOS”
Dans cette partie, vous apprendrez à configurer l'authentification Google sur iOS.Créer un ID client iOS dans le console Google
-
Cliquez sur la barre de recherche
-
Barre de recherche de la console Google
-
Recherchez et cliquez sur
credentialset cliquez sur l'APIs and Servicesle deuxième (le numéro 2 sur l'écran d'capture d'écran)
-
Cliquez sur le
create credentials
-
Sélectionnez
OAuth client ID
-
Sélectionnez le
Application typepouriOS
-
Trouvez l'ID de l'application
-
Ouvrir Xcode
-
Double-cliquez sur
App
-
Assurez-vous d'être sur
Targets -> App
-
Trouvez votre
Bundle Identifier
-
Retournez à la console Google et collez votre
Bundle IdentifierdansBundle ID
-
-
Optionnellement, ajoutez votre
App Store IDouTeam IDdans l'identifiant du client si vous avez publié votre application sur l'App Store -
Après avoir rempli tous les détails, cliquez sur
create
-
Cliquez
OK
-
Ouvrez le client iOS créé récemment
-
Copiez les données suivantes
-
-
Modifiez les informations de votre fichier Info.plist
-
Ouvrez Xcode et trouvez le
Info.plistfichier
-
Cliquez avec le bouton droit sur ce fichier et ouvrez-le en tant que source code
-
À la base de votre
Plistfichier, vous verrez un</dict>tag
-
Insérer le fragment suivant juste avant le tag de fermeture
</dict>Fichier Info.plist avec les schémas URL __CAPGO_KEEP_0__ insérés avant le tag de fermeture du dictionnaire
<key>CFBundleURLTypes</key><array><dict><key>CFBundleURLSchemes</key><array><string>YOUR_DOT_REVERSED_IOS_CLIENT_ID</string></array></dict></array> -
à la valeur copiée dans l'étape précédente
YOUR_DOT_REVERSED_IOS_CLIENT_IDFichier Info.plist avec le client ID réel inséré dans les schémas URL
-
Enregistrez le fichier avec
Command + S
-
-
Modifier le
AppDelegate.swift-
Ouvrez le AppDelegate
-
Insérer
import GoogleSignInen haut du fichier
-
Trouvez le
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:])fonction
-
Modifier la fonction pour qu'elle ressemble à ceci
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) -> Bool {// Called when the app was launched with a url. Feel free to add additional processing here,// but if you want the App API to support tracking app url opens, make sure to keep this callvar handled: Boolhandled = GIDSignIn.sharedInstance.handle(url)if handled {return true}return ApplicationDelegateProxy.shared.application(app, open: url, options: options)}
-
Enregistrer le fichier avec
Command + S
-
-
Configurer la connexion Google dans votre JavaScript/TypeScript code
-
Importer
SocialLoginetCapacitorimport { SocialLogin } from '@capgo/capacitor-social-login';import { Capacitor } from '@capacitor/core'; -
Appeler la méthode d'initialisation (ceci doit être appelé qu'une seule fois)
Configuration de base (mode en ligne - recommandé pour la plupart des applications) :
// onMounted is Vue specificonMounted(() => {SocialLogin.initialize({google: {iOSClientId: '673324426943-redacted.apps.googleusercontent.com',mode: 'online' // Default mode}})})Configuration avancée avec des identifiants de client supplémentaires :
onMounted(() => {SocialLogin.initialize({google: {webClientId: 'YOUR_WEB_CLIENT_ID', // Optional: for web platform supportiOSClientId: 'YOUR_IOS_CLIENT_ID', // Required: from step 1iOSServerClientId: 'YOUR_WEB_CLIENT_ID', // Optional: same as webClientId, needed for some advanced featuresmode: 'online' // 'online' or 'offline'}})}) -
Implémentez la fonction de connexion. Créez un bouton et exécutez le code suivant code lors du clic
Pour le mode en ligne :
const res = await SocialLogin.login({provider: 'google',options: {}})// handle the response - contains user dataconsole.log(JSON.stringify(res))Pour le mode hors ligne :
const res = await SocialLogin.login({provider: 'google',options: {forceRefreshToken: true // Recommended for offline mode}})// res contains serverAuthCode, not user data// Send serverAuthCode to your backend to get user information// Do not call SocialLogin.refresh() in offline modeconsole.log('Server auth code:', res.result.serverAuthCode)
-
-
Testez votre application
-
Construisez votre application et exécutez-la
cap sync -
Si vous avez fait tout correctement, vous devriez voir le flux de connexion Google fonctionner correctement
-
Problèmes connus
Section intitulée « Problèmes connus »Incompatibilité du plugin d'écran de confidentialité avec Cloudflare
Section intitulée « Incompatibilité du plugin d'écran de confidentialité »Le plugin de connexion Google est incompatible avec @capacitor/privacy-screenLors de l'utilisation simultanée des deux plugins, la vue de connexion Google sera interrompue par l'écran de confidentialité.
Solution de contournement : Appelez await PrivacyScreen.disable(); avant d'appeler la fonction de connexion :
import { PrivacyScreen } from '@capacitor/privacy-screen';import { SocialLogin } from '@capgo/capacitor-social-login';
await PrivacyScreen.disable();await SocialLogin.login({ provider: 'google', options: {}});