跳过内容

Google登录设置

GitHub

在本指南中,您将学习如何设置 Google 登录与 Capgo 社交登录。您需要以下内容才能设置 Google 登录:

  • Google 帐户

在本部分中,您将设置 Google 显示的登录屏幕。

  1. 请前往 console.cloud.google.com
  2. 点击项目选择器 Google Console 项目选择器
  3. 如果您尚未创建项目,请 创建新项目.
    1. 点击 New project Google Console 中的新项目按钮
    2. 输入项目名称并点击 Create 项目名称输入框和创建按钮
    3. 确保您在正确的项目中 项目名称显示在选择器中,表示正确的项目选择
  4. 开始配置Capgo OAuth consent screen
    1. 点击搜索栏

      Google Console 搜索栏
    2. 搜索 OAuth consent screen 并点击它

      显示 OAuth 同意屏幕选项的搜索结果
    3. 配置同意屏幕

      点击 create

      OAuth 同意屏幕用户类型选择,具有外部和内部选项
  5. 填写关于您的应用的信息
    1. 让我们从 App Information

      App 信息部分显示 App 名称和用户支持邮箱字段
      • 请输入您的 App Name
      • 输入 user support email
      1. 可以 添加应用程序Logo。

        OAuth-consent屏幕中的应用程序Logo上传部分
      2. 应该 配置 App domain

        应用程序域名配置部分,授权域名字段
      3. 必须 提供开发人员的电子邮件

        开发人员联系信息部分,带有电子邮件字段
      4. 点击 save and continue

        保存并继续按钮,位于表单底部
  6. 配置权限范围
    1. 点击 add or remove scopes

      添加或删除权限按钮
    2. 选择以下权限并点击 update

      权限选择对话框
    3. 点击 save and continue

      保存并继续按钮
  7. 添加测试用户
    1. 点击 add users 添加用户按钮
    2. 输入您的Google邮箱,点击回车,点击 add 邮箱输入框
    3. 点击 save and continue 保存并继续按钮
  8. 点击 back to dashboard 完成页面底部的返回到仪表板按钮
  9. 提交您的应用程序进行验证

有多种方法可以使用 Google 登录与 Capacitor。以下是两种方法的区别总结表格:

在线访问离线访问
需要后端
长期有效的访问令牌
易于设置

在这种情况下,请选择在线访问。

  1. 您的应用程序将在客户端从调用某些 Google API,但永远不会从后端调用

    在这种情况下,请选择在线访问。

  2. Your app will call some Google APIs from the client, but never from the backend

    In this case, choose online access.

  3. 您的应用程序将在后端调用一些 Google API,但只有当用户正在积极使用应用程序时才会调用。

    在这种情况下,请选择在线访问

  4. 您的应用程序将定期检查用户的日历,即使用户不在使用应用程序时也会检查

    在这种情况下,请选择离线访问

在线访问的示例后端

标题:在线访问的示例后端

在本教程的这一部分,我将展示如何在您的后端验证用户。

该示例将非常简单,并且将基于以下技术:

您可以在此示例中找到 code 在这里

如您所见:

VS Code 展示 Google 认证 code,验证令牌

这个想法很简单。您发送一个简单的 GET 请求到 https://www.googleapis.com/oauth2/v3/tokeninfo 它会返回令牌是否有效以及令牌有效时返回用户的电子邮件。它还会给您一些关于用户令牌的其他信息

Google OAuth Playground 展示令牌信息响应,包含用户详细信息

从那里,您可以向用户颁发自己的 JWT 或颁发某种类型的会话 cookie。实现最终认证的可能性是无穷尽的

如果您想调用 Google API,我强烈建议您查看 Google 的 OAuth 2.0 Playground。从那里您可以轻松看到您可以调用的 API

使用离线访问与您的后端

使用本地访问与您的后端

要使用离线访问,您需要以下内容:

  • HTTP 服务器

在本例中,我将使用以下技术来为我的应用提供离线访问:

本例的code可以在这里找到 这里

As for the client code, it looks like this:

import { Capacitor } from '@capacitor/core';
import { GoogleLoginOfflineResponse, SocialLogin } from '@capgo/capacitor-social-login';
import { usePopoutStore } from '@/popoutStore'; // <-- specific to my app
const baseURL = "[redacted]";
async function fullLogin() {
await SocialLogin.initialize({
google: {
webClientId: '[redacted]',
iOSClientId: '[redacted]',
iOSServerClientId: 'The same value as webClientId',
mode: 'offline' // <-- important
}
})
const response = await SocialLogin.login({
provider: 'google',
options: {
forceRefreshToken: true // <-- important
}
})
if (response.provider === 'google') {
const result = response.result as GoogleLoginOfflineResponse
const res = await fetch(`${baseURL}/auth/google_offline`, {
headers: {
"Content-Type": "application/json"
},
body: JSON.stringify({
serverAuthCode: result.serverAuthCode,
platform: Capacitor.getPlatform()
}),
method: "POST"
})
if (res.status !== 200) {
popoutStore.popout("Full google login failed", "check console");
return
}
const { jwt } = await res.json();
const userinfo = await fetch(`${baseURL}/auth/get_google_user`, {
headers: {
Authorization: `Bearer ${jwt}`
}
})
if (userinfo.status !== 200) {
popoutStore.popout("Full google (userinfo) login failed", "check console");
return
}
popoutStore.popout("userinfo res", await userinfo.text());
}
}

注意这里缺少了什么:应用中没有 SocialLogin.refresh() call。 这是有意为之的。在 Google 离线模式下,刷新发生在您的后端与 serverAuthCode 交换并安全存储刷新令牌之后。

继续从 Google 登录设置

标题:继续从 Google 登录设置

如果您正在使用 Google 登录设置 来规划身份验证和帐户流程,连接它到 使用 @capgo/capacitor-social-login 为本机功能的 Using @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的实现细节 双因素认证 了解双因素认证的实现细节