跳过内容

Android 上的 Apple 登录

在 Android 上使用 Apple 登录是hacky。Apple 对 Android 没有官方支持,所以解决方案略微hacky。 Sign in with Apple Android 当前使用 Chrome tabs 来显示 OAuth2 网站。这一方法存在以下挑战:

配置困难

  • 需要后端
  • 理解 Android 流程

标题:理解 Android 流程

标题:理解 Android 流程

让我们使用一个图表来解释 Android 流程:

现在您了解了挑战和流程,请开始配置。

  1. 登录到 Apple 开发者门户.

  2. 点击 Identifiers.

    Apple 开发者门户标识符部分

    您应该看到一个类似这样的屏幕:

    Apple 开发者门户标识符屏幕
    1. 确保该字段显示 App IDs
    2. 确保您可以找到您的 App ID。
  3. 确保应用程序的 Sign in with Apple 能力已启用

    1. 点击您的应用程序 从列表中选择您的应用程序
    2. 确保应用程序的 Sign in with Apple 能力已启用 使用 Apple 能力登录选项开启
    3. 如果没有开启,请开启。
  4. 返回所有 All Identifiers

    所有标识符导航按钮
  5. 点击 App Ids 并前往 Services IDs

    服务 ID 部分导航
  6. 创建新标识符

    1. 点击加号按钮

      添加新服务 ID按钮
    2. 选择 Servcice IDs 并点击 Continue

      选择服务 ID 选项
    3. 输入描述和标识符并点击 Continuie.

      输入服务 ID 详情
    4. 请验证详细信息并点击 Register

      确认服务 ID 注册
    5. 点击新创建的服务

      选择新创建的服务 ID
    6. 启用 Sign in with Apple 选项

      启用 Apple 登录服务 ID
    7. 配置 Sign In with Apple

      配置 Apple 登录按钮
    8. 确保 Primary App ID 设置为上一步配置的 App ID

      设置主 App ID 下拉菜单
    9. 添加您将托管后端的域名。

      设置域名和返回 URL 字段
    10. 域名。点击下一步。 Done

      确认数据并点击
    11. 确认域名和返回 URL 配置 Continue

      点击
    12. 继续服务配置按钮 Save

      点击

保存服务配置按钮

创建密钥
  1. 标题为“创建密钥”的部分内容 All Identifiers

    所有标识符导航按钮
  2. 点击 Keys

    Apple Developer Portal中的Keys部分
  3. 点击加号图标

    添加新密钥按钮
  4. 命名您的密钥

    输入密钥名称字段
  5. 选择 Sign in with Apple 并点击 Configure

    启用并配置 Apple 登录密钥
  6. 选择主 App ID,按 Save

    选择主 App ID
  7. 点击 Continue

    继续配置密钥按钮
  8. 点击 Register

    注册密钥按钮
  9. 复制密钥 ID 并下载密钥。

    密钥 ID 和下载按钮屏幕
  10. 找到下载的密钥并将其保存在后端文件夹中.

    下载的密钥文件

获取团队 ID

获取团队 ID

为了使用 Login with Apple 在 Android 上,您需要获取 Team ID. 将在后端使用。

  1. 前往 访问这个网站 并向下滚动

  2. 找到 Team ID

    开发者账户中的团队 ID 位置

如图所示,后端执行一个名为 Redirect back to the app的步骤。这需要手动修改您的应用。

  1. 修改 AndroidManifest.xml
    1. 打开文件,我将使用 AndroidStudio

      AndroidStudio中的AndroidManifest.xml文件
    2. 找到并添加以下意图过滤器 MainActivity 并添加以下意图过滤器:__CAPGO_KEEP_0__

      在 MainActivity 中添加意图过滤器 code
      <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>
  2. 修改 MainActivity
    1. 请打开 MainActivity

      MainActivity.java 文件在 Android Studio 中
    2. 添加以下内容:code

      Code 添加到 MainActivity 中用于处理深度链接
      @Override
      protected 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);
      }

后端配置

后端配置部分

后端对于Android是必需的,但配置后端也会影响IOS。提供了一个示例后端 这里

本示例提供以下功能:

  • 一个简单的 JSON 数据库
  • 从 Apple 服务器获取 JWT 的方式
  • 一个简单的 JWT 验证

这里 env section 将看起来:

  • ANDROID_SERVICE_ID = 服务 ID
  • IOS_SERVICE_ID = 应用 ID
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"
}

函数的使用方法 login 函数的使用方法与 IOS 一致,详细信息请参见该部分。 然而方法有一些变化。 initialize 复制到剪贴板

await SocialLogin.initialize({
apple: {
clientId: 'ee.forgr.io.ionic.starter.service2',
redirectUrl: 'https://appleloginvps.wcaleniewolny.me/login/callback'
}
})

创建应用

创建应用
  1. 如果您没有 App ID,请点击加号按钮

    添加新标识符加号按钮
  2. 选择并点击继续 App IDs 选择App ID类型

    点击类型
  3. 选择并点击 App 选择App类型 Continue

    输入描述和App ID
  4. 输入App描述和bundle ID

    启用
  5. 能力 Sign with Apple 启用Sign in with Apple能力

    点击
  6. 选择并点击继续 Continue

    继续注册应用程序按钮
  7. 确认详细信息并点击 Register

    确认应用程序注册详细信息

从 Android 上的 Apple 登录继续

标题:从 Android 上的 Apple 登录继续

如果您正在使用 Android 上的 Apple 登录 来规划身份验证和帐户流程,连接它到 使用 @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的实现细节,以及 双因素认证 关于双因素认证的实现细节