Google Auth 迁移至 @capgo/social-login
复制一个设置提示,包含安装步骤和该插件的完整Markdown指南。
本指南提供了从 @codetrix-studio/capacitor-google-auth 到 @capgo/capacitor-social-login,以确保smooth的过渡和改进的身份验证体验的全面步骤。新插件将多个社交身份验证提供商统一到一个单一、一致的API。
安装
安装-
移除旧包:
终端窗口 npm uninstall @codetrix-studio/capacitor-google-auth -
安装新包:
终端窗口 npm install @capgo/capacitor-social-loginnpx cap sync
Google Auth 配置的重要变化
重要变化在 Google Auth 配置Web 客户端 ID 的要求
Web 客户端 ID 的要求关键更新: 必须在所有平台上使用更新的插件的 Web 客户端 ID。
您需要:
- 如果您没有,请在 Google Cloud 控制台中创建 Web 客户端 ID (获取凭据的方法)
- 在所有平台的
webClientId字段中使用此 Web 客户端 ID - 对于 Android,仍然需要使用 SHA1 创建 Android 客户端 ID,但这仅用于验证目的 - 令牌将不会被使用 (Android 配置指南)
Code Changes
标题为“Code Changes”的部分import { GoogleAuth } from '@codetrix-studio/capacitor-google-auth';import { SocialLogin } from '@capgo/capacitor-social-login';从简单的调用变成了更结构化的 GoogleAuth.initialize() 嵌套的Google配置: SocialLogin.initialize() 复制到剪贴板
GoogleAuth.initialize({ clientId: 'CLIENT_ID.apps.googleusercontent.com', scopes: ['profile', 'email'], grantOfflineAccess: true,});
await SocialLogin.initialize({ google: { webClientId: 'WEB_CLIENT_ID.apps.googleusercontent.com', // Use Web Client ID for all platforms iOSClientId: 'IOS_CLIENT_ID', // for iOS mode: 'offline' // replaces grantOfflineAccess }});Section titled “Sign In”
从到 GoogleAuth.signIn() The setup transforms from a simple call to a more structured with nested Google configuration: SocialLogin.login() 使用明确的提供者指定:
const user = await GoogleAuth.signIn();const res = await SocialLogin.login({ provider: 'google', options: { scopes: ['email', 'profile'], forceRefreshToken: true // if you need refresh token }});平台特定更改
标题:平台特定更改Android
标题:Android- 更新您的
MainActivity.java(全Android设置指南):
import ee.forgr.capacitor.social.login.GoogleProvider; import ee.forgr.capacitor.social.login.SocialLoginPlugin; import ee.forgr.capacitor.social.login.ModifiedMainActivityForSocialLoginPlugin; import com.getcapacitor.PluginHandle; import com.getcapacitor.Plugin; import android.content.Intent; import android.util.Log;
public class MainActivity extends BridgeActivity { public class MainActivity extends BridgeActivity implements ModifiedMainActivityForSocialLoginPlugin {
@Override public void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data);
if (requestCode >= GoogleProvider.REQUEST_AUTHORIZE_GOOGLE_MIN && requestCode < GoogleProvider.REQUEST_AUTHORIZE_GOOGLE_MAX) { PluginHandle pluginHandle = getBridge().getPlugin("SocialLogin"); if (pluginHandle == null) { Log.i("Google Activity Result", "SocialLogin login handle is null"); return; } Plugin plugin = pluginHandle.getInstance(); if (!(plugin instanceof SocialLoginPlugin)) { Log.i("Google Activity Result", "SocialLogin plugin instance is not SocialLoginPlugin"); return; } ((SocialLoginPlugin) plugin).handleGoogleLoginIntent(requestCode, data); } }
public void IHaveModifiedTheMainActivityForTheUseWithSocialLoginPlugin() {}}iOS
标题:iOS-
AppDelegate.swift中没有需要的重大更改(iOS设置指南)
-
更新您的配置在
capacitor.config.json,我们不再使用它在新插件:
{ "plugins": { "GoogleAuth": { "scopes": ["profile", "email"], "serverClientId": "xxxxxx-xxxxxxxxxxxxxxxxxx.apps.googleusercontent.com", "forceCodeForRefreshToken": true }}Web
标题为“Web”- 从您的
index.html如果您曾经使用它们:
<meta name="google-signin-client_id" content="{your client id here}" /><meta name="google-signin-scope" content="profile email" />响应类型更改
标题为“响应类型更改”认证响应现在提供一个结构化的对象,包含提供商信息、访问令牌、ID令牌和用户资料:
interface GoogleLoginResponse { provider: 'google'; result: { accessToken: { token: string; expires: string; // ... other token fields } | null; idToken: string | null; profile: { email: string | null; familyName: string | null; givenName: string | null; id: string | null; name: string | null; imageUrl: string | null; }; };}响应结构包括:
- provider: 确定身份验证提供者(
'google') - result.accessToken: 包含过期时间的访问令牌详细信息
- result.idToken: 身份验证令牌
- result.profile: 包含电子邮件、姓名和图片 URL 的用户资料
额外功能
标题为“额外功能”的部分新包支持多个社交身份验证提供商,超出Google:
这种统一的方法提供:
- 所有提供商中的API一致
- 改进的TypeScript支持
- 更好的错误处理
- 积极的维护和社区支持
查看 主文档 获取这些额外提供商的详细设置指南。
从Google Auth迁移继续到@capgo/social-login
从 Google Auth Migration 到 @capgo/social-login 的持续迁移如果您正在使用 Google Auth Migration 到 @capgo/social-login 规划身份验证和帐户流程,连接它 使用 @capgo/capacitor-social-login 使用 @capgo/capacitor-social-login 的原生能力 @capgo/capacitor-social-login @capgo/capacitor-social-login 的实现细节 @capgo/capacitor-passkey @capgo/capacitor-passkey 的实现细节 @capgo/capacitor-native-biometric @capgo/capacitor-native-biometric 的实现细节 双重验证 双重验证的实现细节。