Android 上的 Google 登录
复制一个包含安装步骤和本插件的完整 Markdown 指南的配置提示。
简介
简介在本指南中,您将学习如何在 Android 设备上设置 Google 登录和 Capgo 社交登录。 我假设您已经阅读了.
使用 Google 登录
简介在本部分中,您将学习如何在 Android 设备上设置 Google 登录。
-
点击搜索栏
-
targetLanguage
-
在搜索框中
credentials并点击APIs and Services截图中的第二个选项(第 2 个)
-
点击
create credentials
-
选择
OAuth client ID
-
选择
Android应用类型
-
打开 Android Studio
-
在导航器的最下方找到
Gradle Scripts
-
查找
build.gradle为模块app
-
复制
android.defaultConfig.applicationId这将是你的package name在 Google 控制台中
-
现在,打开终端。确保你在你的应用程序的文件夹中,并运行
androidfolder of your app and run./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 证书,请尝试使用自定义密钥库。 这里 是关于如何将密钥库添加到您的项目中的注释。