安卓接入Google登录

目录

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 代码库:

allprojects {
    repositories {
        google()

        // If you're using a version of Gradle lower than 4.1, you must instead use:
        // maven {
        //     url 'https://maven.google.com'
        // }
    }
}

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

apply plugin: 'com.android.application'
    ...

    dependencies {
        implementation 'com.google.android.gms:play-services-auth:20.2.0'
    }

3.添加Google sign代码

        废话不多,直接上代码


public class LoginActivity extends AppCompatActivity {

    private ActivityLoginBinding binding;

    // Google
    private GoogleSignInClient mGoogleSignInClient;
    private static final int RC_SIGN_IN = 9001;
    private static final String serverClientId = "49031722657-r22t4obi9v020qpba9d9f0eonchlcqn4.apps.googleusercontent.com";

    @Override
    public void onDestroy() {
        super.onDestroy();
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        binding = ActivityLoginBinding.inflate(getLayoutInflater());
        setContentView(binding.getRoot());

        final Button loginButton = binding.login;
        loginButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                signIn();
            }
        });
        final Button logoutButton = binding.logout;
        logoutButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                signOut();
            }
        });

        GoogleSignInOptions gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
                .requestId()
                .requestEmail()
                .requestIdToken(serverClientId)
                .build();

        // Build a GoogleSignInClient with the options specified by gso.
        mGoogleSignInClient = GoogleSignIn.getClient(this, gso);
    }

    private void signIn() {
        Intent signInIntent = mGoogleSignInClient.getSignInIntent();
        startActivityForResult(signInIntent, RC_SIGN_IN);
    }

    private void signOut() {
        mGoogleSignInClient.signOut().addOnCompleteListener(this, new OnCompleteListener<Void>() {
            @Override
            public void onComplete(@NonNull Task<Void> task) {
                Toast.makeText(getApplicationContext(), "signOut Complete!", Toast.LENGTH_LONG).show();
            }
        });
    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        if (requestCode == RC_SIGN_IN) {
            // The Task returned from this call is always completed, no need to attach a listener.
            Task<GoogleSignInAccount> completedTask = GoogleSignIn.getSignedInAccountFromIntent(data);
            try {
                GoogleSignInAccount account = completedTask.getResult(ApiException.class);
                // Signed in successfully
                String result = "id = " + account.getId() + "\n" + "token = " + account.getIdToken();
                Toast.makeText(getApplicationContext(), result, Toast.LENGTH_LONG).show();
            } catch (ApiException e) {
                // The ApiException status code indicates the detailed failure reason.
                // Please refer to the GoogleSignInStatusCodes class reference for more information.
                String result = "signInResult:failed code=" + e.getStatusCode();
                Toast.makeText(getApplicationContext(), result, Toast.LENGTH_LONG).show();
            }
        }
    }
}

        创建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)是怎么来的

要配置 Google Play,您需要遵循以下步骤: 1. 创建一个 Google Play 开发者帐户:访问 Google Play 开发者控制台(https://play.google.com/apps/publish/)并按照指示创建一个新的开发者帐户。您可能需要支付一次性注册费。 2. 创建应用程序清单:在开发者控制台中,点击“创建应用程序”按钮,然后填写应用程序的基本信息,如名称、说明、分类等。您还需要上传应用程序的图标和截图。 3. 设置应用程序定价和分发设置:根据您的需求,选择免费或付费模式,并设置价格。您还可以选择在哪些国家/地区分发您的应用程序。 4. 配置应用程序内购买(可选):如果您的应用程序支持应用程序内购买,您需要在开发者控制台中设置相关产品和价格。 5. 上传应用程序包:准备好您的应用程序包文件(APK),然后将其上传到开发者控制台。您还可以选择为不同的设备提供不同的 APK 版本。 6. 设置应用程序列表信息:提供关于您的应用程序的详细信息,例如描述、关键词、隐私政策等。这些信息将显示在 Google Play 商店中。 7. 进行测试和发布:在完成所有配置后,您可以选择进行测试以确保应用程序在各种设备上正常运行。一旦您满意,就可以点击“发布”按钮将应用程序提交到 Google Play 商店进行审核和发布。 请注意,以上步骤只是一个简要概述,具体步骤可能会根据您的应用程序类型和需求而有所不同。建议您参考 Google Play 开发者文档以获取更详细的指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

coding·life

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值