Google 登录设置
复制一个包含安装步骤和本插件的完整 Markdown 指南的配置提示。
介绍
《介绍》一节In this guide, you will learn how to setup Google Login with Capgo Social Login. You will need the following in order to setup Google Login:
- Google 帐户
《一般设置》一节
注意在本部分中,您将设置Google显示的登录屏幕。
- 请访问 console.cloud.google.com
- 点击项目选择器
- 如果您尚未创建项目,请 创建新项目.
- 点击Google Console中的新项目按钮
New project
- __CAPGO_KEEP_0__
Create
- 确保您正在正确的项目
- 点击Google Console中的新项目按钮
- 开始配置
OAuth consent screen-
点击搜索栏
-
搜索
OAuth consent screen并点击它
-
配置同意屏幕
点击
create
-
- 填写有关您的应用的信息
-
首先,让我们从
App Information
- 请输入您的
App Name - 输入
user support email
-
您 可以 添加应用程序Logo。
-
您 应该配置 App域名配置部分的授权域名字段
App domain
-
提供开发者的电子邮件 开发者联系信息部分的电子邮件字段 configure the
-
点击
save and continue
- 请输入您的
-
- 配置权限范围
-
点击
add or remove scopes
-
选择以下权限范围并点击
update
-
点击
save and continue
-
- 添加测试用户
- 点击
add users
- 输入您的Google邮箱,按回车,然后点击
add
- 点击
save and continue
- 点击
- 点击
back to dashboard
- 提交您的应用程序进行验证
在线访问与离线访问的区别
在线访问与离线访问的区别您可以通过多种方式使用 Google 登录。以下是使用 Capacitor 的不同方式的总结表格:
| 在线访问 | 离线访问 | |
|---|---|---|
| 需要后端 | ❌ | ✅ |
| 长期有效的访问令牌 | ❌ | ✅ |
| 易于设置 | ✅ | ❌ |
如果您仍然不知道应该选择哪一个,请考虑以下场景:
-
您希望用户登录后立即为其颁发一个自定义的 JWT。您的应用程序将不会调用 Google API
在这种情况下,请选择在线访问
-
您的应用程序将从客户端调用一些 Google API,但永远不会从后端调用
在这种情况下,请选择在线访问
-
您的应用程序将从后端调用一些 Google API,但仅当用户正在主动使用应用程序时
在这种情况下,请选择在线访问
-
您的应用程序将定期检查用户的日历,即使用户不在主动使用应用程序
在这种情况下,请选择离线访问
在线访问的示例后端
标题:在线访问的示例后端在本教程的这一部分,我将展示如何在您的后端验证用户。
这个示例将非常简单,并且将基于以下技术:
您可以在这里找到本例的code 这里
如您所见:
这个想法很简单。您发送一个简单的请求到 GET 并且这个返回您令牌是否有效或无效以及如果有效,则给您用户的电子邮件。它还给您一些关于用户令牌的其他信息 https://www.googleapis.com/oauth2/v3/tokeninfo Google OAuth Playground 展示令牌信息响应,包含用户详细信息
__CAPGO_KEEP_0__
如果您想调用 Google API,我强烈建议您查看 Google OAuth 2.0 playground从那里您可以轻松看到您可以调用的 API
使用离线访问与您的后端
标题:使用离线访问与您的后端要使用离线访问,您需要以下内容:
- HTTP 服务器
在本例中,我将使用以下技术来为我的应用提供离线访问:
-
低Db (一个简单的数据库)
本例的code可以在这里找到 客户端__CAPGO_KEEP_0__如下所示:
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() 上一个 serverAuthCode 入门指南