Google Android 登录
复制一个安装步骤和完整的Markdown指南的可复制提示。
简介
简介在本指南中,您将学习如何在 Android 设备上设置 Google 登录和 Capgo 社交登录。 我假设您已经阅读了.
一般设置指南
使用 Google 登录简介
-
创建一个Android客户端ID。
-
点击搜索栏
-
在搜索框中
credentials并点击截图中的APIs and Services第 2 项
-
点击
create credentials
-
选择
OAuth client ID
-
选择
Android应用程序类型
-
打开 Android Studio
-
在浏览器的最下方,找到
Gradle Scripts
-
找到
build.gradle用于模块app
-
复制
android.defaultConfig.applicationId这是你的package name在 Google 控制台中
-
现在,打开终端。确保你在你的应用程序的
android文件夹中运行./gradlew signInReport
- 滚动到命令的顶部。您应该看到以下内容。复制
SHA1.
- 现在,返回 Google 控制台。输入
applicationId作为Package Name并您的 SHA1 在证书字段中,点击create
-
-
创建一个 Web 客户端(这是为 Android 必须的)
-
前往
Create credentials页面在 Google 控制台 -
设置应用类型为
Web
-
点击
Create
-
复制客户端 ID,您将其作为
webClientId在您的 JS/TS code 中
-
-
修改您的
MainActivity-
请在 Android Studio 中打开您的应用。您可以通过
cap open android -
查找
MainActivity.java-
打开
app文件夹
-
查找
java
-
找到你的
MainActivity.java并点击它
-
-
修改
MainActivity.java. 请添加以下内容 codeimport 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;import com.getcapacitor.BridgeActivity;// ModifiedMainActivityForSocialLoginPlugin is VERY VERY important !!!!!!public class MainActivity extends BridgeActivity implements ModifiedMainActivityForSocialLoginPlugin {@Overridepublic 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);}}// This function will never be called, leave it empty@Overridepublic void IHaveModifiedTheMainActivityForTheUseWithSocialLoginPlugin() {}} -
保存文件
-
-
在应用程序中使用Google登录
-
首先,导入
SocialLoginimport { SocialLogin } from '@capgo/capacitor-social-login'; -
调用initialize。 这应该只调用一次。
// onMounted is Vue specific// webClientId is the client ID you got in the web client creation step not the android client ID.onMounted(() => {SocialLogin.initialize({google: {webClientId: '673324426943-avl4v9ubdas7a0u7igf7in03pdj1dkmg.apps.googleusercontent.com',}})}) -
呼叫
SocialLogin.login. 创建一个按钮并在点击时运行以下 code。const res = await SocialLogin.login({provider: 'google',options: {}})// handle the responseconsole.log(JSON.stringify(res))
-
-
进入
-
配置模拟器进行测试
Device manager点击加号按钮
-
创建虚拟设备
-
选择任何支持
Play Store图标
如您所见,
pixel 8支持Play Store服务 -
点击
next
-
确保操作系统映像类型为
Google Play. 必须 类型为Google Play
-
点击下一步
-
确认您的设备。您可以为模拟器命名
-
进入
Device Manager并启动您的模拟器
-
模拟器启动后,进入其设置
-
进入
Google Play
- 点击
Update等待约60秒
-
-
测试您的应用
如果您一切都正确完成了,您应该看到Google登录流程正常工作:
故障排除
标题为“故障排除”的部分如果您遇到任何问题,请查看 Github 问题.
与 Google 登录相关的问题是 始终 与 SHA1 证书有关。
如果您无法获取开发 SHA1 证书,请尝试使用自定义 keystore。 以下 是关于如何在项目中添加 keystore 的注释。