跳过内容

Supabase Apple 登录 Android

本指南将帮助您在 Android 上将 Apple Sign-In 与 Supabase 身份验证集成。假设您已经完成:

步骤 1:部署后端 Edge Function

步骤 1:部署后端 Edge Function

首先,我们需要部署 Supabase Edge Function 来处理 Apple OAuth 回调。

  1. 导航到您的 Supabase 项目目录

    终端窗口
    cd your-project/supabase
  2. 创建边缘函数 终端窗口

    复制到剪贴板
    supabase functions new apple-signin-callback
  3. Copy the edge function code

    完整的边缘函数实现可在 示例应用.

    复制以下文件到您的项目:

    • supabase/functions/apple-signin-callback/index.ts - 主边缘函数 code
    • supabase/functions/apple-signin-callback/deno.json - 依赖项的导入映射(包括 jose 用于 JWT 签名的库
  4. 配置 JWT 验证

    Apple OAuth 回调端点必须是公共的(无需身份验证,因为 Apple 将重定向到它。更新您的 supabase/config.toml 复制到剪贴板

    [functions.apple-signin-callback]
    enabled = true
    verify_jwt = false # Important: Set to false for public OAuth callback
    import_map = "./functions/apple-signin-callback/deno.json"
    entrypoint = "./functions/apple-signin-callback/index.ts"
  5. 部署函数

    终端窗口
    supabase functions deploy apple-signin-callback
  6. 获取函数URL

    部署后,您将获得一个类似于:

    https://your-project-ref.supabase.co/functions/v1/apple-signin-callback

    如果您无法找到它,请尝试以下操作:

    1. 打开 https://supabase.com/dashboard/project/YOUR_PROJECT_REF/functions
    2. 点击 apple-signin-callback 函数URL以复制它。 Supabase Functions Apple Sign-In Callback

步骤 2:配置 Apple Developer Portal

步骤 2:配置 Apple Developer Portal

现在我们需要使用后端 URL 配置 Apple Developer Portal 并获取所需的所有值。

  1. 遵循 Apple Login Android 设置指南

    完成 Apple Login Android 设置指南 到:

    • 创建服务 ID
    • 生成私钥 (.p8 文件)
    • 获取您的团队 ID 和密钥 ID
    • 配置返回 URL
  2. 在 Apple 开发者门户中设置返回 URL

    在配置返回 URL 时(Apple 指南中的第 6.9 步),使用您的 Supabase Edge Function URL:

    https://your-project-ref.supabase.co/functions/v1/apple-signin-callback

    重要提示:使用 Supabase Edge Function URL

    不要 使用来自 Supabase 的重定向 URL Apple Login Android 设置指南. 这个指南使用自定义后端服务器 URL。对于 Supabase 集成, 您必须 使用您的 Supabase Edge Function URL。

  3. 完成 Apple 设置指南后,您应该有:

    APPLE_TEAM_ID

    • Exact Match Required: Your Apple Developer Team ID
    • APPLE_KEY_ID: The Key ID from Apple Developer Portal
    • APPLE_PRIVATE_KEY: Your .p8 private key file (needs to be base64 encoded)
    • ANDROID_SERVICE_ID: Your Apple Service ID (e.g., com.example.app.service)
    • BASE_REDIRECT_URL: Your deep link URL (e.g., capgo-demo-app://path)

步骤 3:设置 Supabase 秘密

标题:步骤 3:设置 Supabase 秘密

现在我们需要配置 Supabase Edge Function 的环境变量(秘密)。

  1. 编码您的私钥

    首先,将您的 Apple 私钥 (.p8 文件) 编码为 base64:

    终端窗口
    base64 -i AuthKey_XXXXX.p8

    复制整个输出(它是一个长的字符串)。

  2. 使用 Supabase 设置密钥 CLI

    终端窗口
    supabase secrets set APPLE_TEAM_ID=your_team_id
    supabase secrets set APPLE_KEY_ID=your_key_id
    supabase secrets set APPLE_PRIVATE_KEY=your_base64_encoded_key
    supabase secrets set ANDROID_SERVICE_ID=your.service.id
    supabase secrets set BASE_REDIRECT_URL=your-app://path
    supabase secrets set APPLE_REDIRECT_URI=https://your-project-ref.supabase.co/functions/v1/apple-signin-callback
  3. 替代方案:在 Supabase 控制台中设置密钥

    如果您更喜欢使用控制台:

    1. 前往您的 Supabase 项目控制台
    2. 导航到 边缘函数设置密钥
    3. 添加每个密钥变量及其值

步骤 4:使用身份验证助手

标题为“步骤 4:使用身份验证助手”

现在您可以在应用程序中使用身份验证助手 code。

完整的实现可在 示例应用程序的 supabaseAuthUtils.ts 文件

import { authenticateWithAppleSupabase } from './supabaseAuthUtils';
const result = await authenticateWithAppleSupabase();
if (result.success) {
console.log('Signed in:', result.user);
// Navigate to your authenticated area
} else {
console.error('Error:', result.error);
}

更新助手函数

标题:更新助手函数

当使用助手函数时, authenticateWithAppleSupabase 您必须 更新以下值以匹配您的配置: 更新

  1. - 将其设置为您的 Supabase Edge Function URL: redirectUrl 复制到剪贴板

    const redirectUrl = platform === 'android'
    ? 'https://your-project-ref.supabase.co/functions/v1/apple-signin-callback'
    : undefined;
  2. - 将其设置为您的 Apple Service ID: clientId 复制到剪贴板

    await SocialLogin.initialize({
    apple: {
    clientId: isIOS
    ? undefined // iOS uses bundle ID automatically
    : 'your.service.id.here', // Your Apple Service ID for Android
    redirectUrl: redirectUrl,
    },
    });

完整的实现 参考 步骤5:测试集成

  1. Section titled “Step 5: Test the Integration”

    终端窗口
    npx cap sync android
    npx cap run android
  2. 测试认证流程

    • 点击“使用 Apple 登录”按钮
    • 您应该在浏览器中看到 Apple OAuth 页面
    • 认证后,您应该被重定向回您的应用
    • 检查控制台日志以查看是否有错误
  3. 验证流程

    完整的流程应该是:

    1. 用户点击“使用 Apple 登录”
    2. 应用程序打开 Apple OAuth 的浏览器
    3. 用户使用 Apple 进行身份验证
    4. Apple 重定向到: https://your-project-ref.supabase.co/functions/v1/apple-signin-callback
    5. Edge 函数将 code 替换为令牌
    6. Edge 函数重定向到: your-app://path?id_token=...&access_token=...
    7. 安卓应用接收深度链接并处理身份令牌
    8. 应用使用身份令牌登录 Supabase

如果身份验证失败:

  • 重定向 URI 不匹配: 验证 Apple Developer Portal 中的 Return URL 与 APPLE_REDIRECT_URI secret
  • 深度链接未工作: 检查 AndroidManifest.xml 意图过滤器是否匹配你的 BASE_REDIRECT_URL
  • 缺少密钥: 使用 supabase secrets list
  • 令牌交换失败: 在 Supabase 控制台中查看 Edge Function 日志以获取详细的错误消息
  • 应用程序未接收回调: 确保 onNewIntent 在 MainActivity 中正确实现
  • 查看 示例应用程序 code 以获取参考

如何工作

如何工作

在 Android 上,Apple Sign-In 使用 OAuth 重定向流程:

  1. 初始化: 使用您的 Service ID 和后端重定向 URL 初始化插件
  2. OAuth 流程: 打开浏览器/Chrome 自定义标签页以访问 Apple 的 OAuth 页面
  3. 后端回调: Apple 重定向到您的 Supabase Edge Function 以获取授权 code
  4. 令牌交换: 边缘函数使用 Apple 令牌端点交换 code 以获取令牌
  5. 深度链接重定向: Apple 边缘函数重定向回您的应用程序,带有身份令牌
  6. Supabase 身份验证: 应用程序接收令牌并登录 Supabase

由于 Apple 没有为 Android 提供原生 Sign in with Apple 支持,因此需要此流程。