当前位置:   article > 正文

安卓接入Google登录_com.google.android.gms

com.google.android.gms

目录

1.配置Google Cloud

2.添加 Google Play 服务

3.添加Google sign代码

4.常见的CommonStatusCodes

后补Web clien(Auto-created for Google Sign-in)由来


1.配置Google Cloud

        首先要在 Google Cloud 中创建一个项目。左侧菜单->API和服务->凭据。进入之后先配置同意屏幕。

 

填写必必要的信息,应用名称、用户支持电子邮件地址、开发者电子邮件地址 。

到第3步添加测试用户(只有填写的测试用户才能登录测试)

 OAuth 同意屏幕 配置完成之后选择凭据 CREATECREDENTIALS 

 选择Android平台应用,填写基础的信息

创建之后信息如下:

关键点在一些其他的文档教程中会发现存在一条 Web client(Auto-created for Google Sign-in),如下图所示:这里暂时先不讲,后续会讲到这点

2.添加 Google Play 服务

在项目的顶级 build.gradle 文件中,确保包含 Google 的 Maven 代码库:

  1. allprojects {
  2. repositories {
  3. google()
  4. // If you're using a version of Gradle lower than 4.1, you must instead use:
  5. // maven {
  6. // url 'https://maven.google.com'
  7. // }
  8. }
  9. }

然后,在应用级 build.gradle 文件中,将 Google Play 服务声明为依赖项:

  1. apply plugin: 'com.android.application'
  2. ...
  3. dependencies {
  4. implementation 'com.google.android.gms:play-services-auth:20.2.0'
  5. }

3.添加Google sign代码

        废话不多,直接上代码

  1. public class LoginActivity extends AppCompatActivity {
  2. private ActivityLoginBinding binding;
  3. // Google
  4. private GoogleSignInClient mGoogleSignInClient;
  5. private static final int RC_SIGN_IN = 9001;
  6. private static final String serverClientId = "49031722657-r22t4obi9v020qpba9d9f0eonchlcqn4.apps.googleusercontent.com";
  7. @Override
  8. public void onDestroy() {
  9. super.onDestroy();
  10. }
  11. @Override
  12. public void onCreate(Bundle savedInstanceState) {
  13. super.onCreate(savedInstanceState);
  14. binding = ActivityLoginBinding.inflate(getLayoutInflater());
  15. setContentView(binding.getRoot());
  16. final Button loginButton = binding.login;
  17. loginButton.setOnClickListener(new View.OnClickListener() {
  18. @Override
  19. public void onClick(View v) {
  20. signIn();
  21. }
  22. });
  23. final Button logoutButton = binding.logout;
  24. logoutButton.setOnClickListener(new View.OnClickListener() {
  25. @Override
  26. public void onClick(View v) {
  27. signOut();
  28. }
  29. });
  30. GoogleSignInOptions gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
  31. .requestId()
  32. .requestEmail()
  33. .requestIdToken(serverClientId)
  34. .build();
  35. // Build a GoogleSignInClient with the options specified by gso.
  36. mGoogleSignInClient = GoogleSignIn.getClient(this, gso);
  37. }
  38. private void signIn() {
  39. Intent signInIntent = mGoogleSignInClient.getSignInIntent();
  40. startActivityForResult(signInIntent, RC_SIGN_IN);
  41. }
  42. private void signOut() {
  43. mGoogleSignInClient.signOut().addOnCompleteListener(this, new OnCompleteListener<Void>() {
  44. @Override
  45. public void onComplete(@NonNull Task<Void> task) {
  46. Toast.makeText(getApplicationContext(), "signOut Complete!", Toast.LENGTH_LONG).show();
  47. }
  48. });
  49. }
  50. @Override
  51. public void onActivityResult(int requestCode, int resultCode, Intent data) {
  52. super.onActivityResult(requestCode, resultCode, data);
  53. if (requestCode == RC_SIGN_IN) {
  54. // The Task returned from this call is always completed, no need to attach a listener.
  55. Task<GoogleSignInAccount> completedTask = GoogleSignIn.getSignedInAccountFromIntent(data);
  56. try {
  57. GoogleSignInAccount account = completedTask.getResult(ApiException.class);
  58. // Signed in successfully
  59. String result = "id = " + account.getId() + "\n" + "token = " + account.getIdToken();
  60. Toast.makeText(getApplicationContext(), result, Toast.LENGTH_LONG).show();
  61. } catch (ApiException e) {
  62. // The ApiException status code indicates the detailed failure reason.
  63. // Please refer to the GoogleSignInStatusCodes class reference for more information.
  64. String result = "signInResult:failed code=" + e.getStatusCode();
  65. Toast.makeText(getApplicationContext(), result, Toast.LENGTH_LONG).show();
  66. }
  67. }
  68. }
  69. }

        创建GoogleSignInOptions时可以选择requestId()、requestEmail()、requestProfile()、requestIdToken(serverClientId)。

        getEmail() 获取用户的电子邮件地址

        getId() 获取用户的 Google ID(供客户端使用)

        getIdToken() 获取用户的 ID 令牌,如果要获取idToken,则创建时需要用到requestIdToken(serverClientId),其中serverClientId就是创建的凭据中的客户端ID值。

        注意:如果使用在第1步中创建的signTest的客户端ID的话在登录时会返回错误码 10。提示应用配置错误。还记得在上述文中提到的Web client(Auto-created for Google Sign-in)在官方的文档中有这样一段描述

        按照官方描述我怎么也找不到自动创建的Web client。找不到就自己创建一个咯。在凭据中创建一个类型为Web应用的客户端ID即可,创建完成之后使用这个客户端ID就可以正常登录了。美滋滋。。。

4.常见的CommonStatusCodes

定义描述
0SUCCESS成功。
5

INVALID_ACCOUNT

客户端试图使用指定的无效帐户名连接到服务。
7

NETWORK_ERROR

网络错误。(国内一般是未科学上网导致)
10

DEVELOPER_ERROR

应用程序配置错误。此错误不可恢复,将被视为致命错误。开发人员应该在这之后查看日志,以确定更多可操作的信息。
16

CANCELED

客户端断开连接或主动取消(PendingResult.cancel())。

22RECONNECTION_TIMED_OUT连接超时。

        详细地址:https://developers.google.com/android/reference/com/google/android/gms/common/api/CommonStatusCodes#DEVELOPER_ERROR


搬运地址:https://developers.google.com/identity/sign-in/android/start

GitHub地址:https://github.com/googlesamples/google-services.git


后补Web clien(Auto-created for Google Sign-in)由来

        在官方的接入文档中有一个Configure a project的按钮。使用这里的按钮来创建客户端ID的流程如下: 

 这里选择Android,输入包名,指纹,按照这种方式创建出来的客户端ID会有2个。

 一个是Android,一个是Web应用。终于知道Web client(Auto-created for Google Sign-in)是怎么来的

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/706944
推荐阅读
相关标签
  

闽ICP备14008679号