Sauter au contenu

Connexion Google sur iOS

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. guide de configuration générale.

Dans cette partie, vous apprendrez à configurer l'authentification Google sur iOS.

  1. Créez un ID de client iOS dans le console Google

    1. Cliquez sur la barre de recherche

      Barre de recherche de la console Google
    2. Recherchez credentials et cliquez sur APIs and Services un (le numéro 2 sur l'écran d'écran)

      Résultats de recherche montrant l'option de clés d'accès avec les APIs et Services mis en évidence
    3. Cliquez sur le bouton create credentials

      Créer des clés d'accès dans le Console de Google
    4. Sélectionnez OAuth client ID

      L'option ID client OAuth dans le menu de création de clés d'accès
    5. Sélectionnez le Application type pour iOS

      Sélection de type d'application avec l'option iOS mise en évidence
    6. Trouvez l'ID de l'application

      1. Ouvrez Xcode

      2. Double-cliquez sur App

        Cible de l'application dans le navigateur de projet Xcode
      3. Assurez-vous d'être sur Targets -> App

        section Cibles dans Xcode avec l'application sélectionnée
      4. Trouvez votre Bundle Identifier

        Champ Identifiant de la boutique dans les paramètres de projet Xcode
      5. Retournez à la console Google et collez votre Bundle Identifier dans Bundle ID

        Champ ID de la boutique dans la forme de création de client iOS de la console Google
    7. Optionnellement, ajoutez votre App Store ID ou Team ID dans le champ ID du client si vous avez publié votre application sur l'App Store

    8. Après avoir rempli tous les détails, cliquez sur create

      Bouton Créer en bas de la forme de création de client iOS
    9. Cliquez OK

      OK sur le dialogue de confirmation de l'ID client créé
    10. Ouvrez le client iOS créé récemment

      Client iOS créé récemment dans la liste des identifiants
    11. Copiez les données suivantes

      Détails de l'ID client affichant l'ID client et l'ID client inversé à copier
  2. Modifiez les informations de votre application Info.plist

    1. Ouvrez Xcode et trouvez le Info.plist fichier

      fichier Info.plist dans le navigateur de projet Xcode
    2. Cliquez avec le bouton droit sur ce fichier et ouvrez-le en tant que source code

      Menu contextuel montrant l'option Ouvrir en tant que source Code
    3. En bas de votre Plist fichier, vous verrez une </dict> tag

      Balise de fermeture de dictionnaire dans le fichier Info.plist
    4. Insérer le fragment suivant juste avant la fermeture </dict> tag

      Info.plist avec les schémas de URL code insérés avant la fermeture de la balise
      <key>CFBundleURLTypes</key>
      <array>
      <dict>
      <key>CFBundleURLSchemes</key>
      <array>
      <string>YOUR_DOT_REVERSED_IOS_CLIENT_ID</string>
      </array>
      </dict>
      </array>
    5. Changer YOUR_DOT_REVERSED_IOS_CLIENT_ID à la valeur copiée dans l'étape précédente

      Info.plist avec le client ID réel inséré dans les schémas de URL
    6. Sauvegardez le fichier avec Command + S

  3. Modifier le AppDelegate.swift

    1. Ouvrez le AppDelegate

      Ouvrez le fichier AppDelegate.swift dans le navigateur de projet Xcode
    2. Insérer import GoogleSignIn en haut du fichier

      AppDelegate.swift avec l'import GoogleSignIn ajouté
    3. Trouvez le func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) fonction

      La fonction d'ouverture d'application openURL dans AppDelegate
    4. Modifiez 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 call
      var handled: Bool
      handled = GIDSignIn.sharedInstance.handle(url)
      if handled {
      return true
      }
      return ApplicationDelegateProxy.shared.application(app, open: url, options: options)
      }
      Fonctionnalité d'application modifiée openURL avec gestion GoogleSignIn
    5. Enregistrez le fichier avec Command + S

  4. Configurer la connexion Google dans votre JavaScript/TypeScript code

    1. Importer SocialLogin et Capacitor

      import { SocialLogin } from '@capgo/capacitor-social-login';
      import { Capacitor } from '@capacitor/core';
    2. 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 specific
      onMounted(() => {
      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 support
      iOSClientId: 'YOUR_IOS_CLIENT_ID', // Required: from step 1
      iOSServerClientId: 'YOUR_WEB_CLIENT_ID', // Optional: same as webClientId, needed for some advanced features
      mode: 'online' // 'online' or 'offline'
      }
      })
      })
    3. Implémentez la fonction de connexion. Créez un bouton et exécutez le code suivant lors du clic

      Pour le mode en ligne :

      const res = await SocialLogin.login({
      provider: 'google',
      options: {}
      })
      // handle the response - contains user data
      console.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 mode
      console.log('Server auth code:', res.result.serverAuthCode)
  5. Testez votre application

    1. Construisez votre application et exécutez-la cap sync

    2. Si vous avez tout fait correctement, vous devriez voir le flux de connexion Google fonctionner correctement

      Démo du flux de connexion Google sur iOS montrant le processus de connexion et l'authentification réussie

Incompatibilité du plugin d'écran de confidentialité

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 : Appeler 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: {}
});

Si vous utilisez Google Login sur iOS pour planifier l'authentification et les flux de compte, connectez-le à Utilisez @capgo/capacitor-social-login pour la capacité native dans Utilisez @capgo/capacitor-social-login, Utilisez @capgo/capacitor-social-login pour le détail d'implémentation dans @capgo/capacitor-social-login, Utilisez @capgo/capacitor-passkey pour le détail d'implémentation dans @capgo/capacitor-passkey, Utilisez @capgo/capacitor-native-biometric pour le détail d'implémentation dans @capgo/capacitor-native-biometric, et Authentification à deux facteurs pour le détail d'implémentation dans Authentification à deux facteurs.