获取 Google 张照片列表返回 401 未经身份验证

Getting list of Google Photos returned 401 unauthenticated

我正在开发一款能够显示来自 Google 照片的图像的应用程序。

问题

当用户在 Gmail Permission 中手动撤销我的应用程序时出现问题。用户执行此操作(撤销权限)后,再次打开应用程序,当应用程序尝试访问 Google Photos 中的图像列表时,这是我在 JSON.[= 中收到的错误18=]

{
  "error": {
    "code": 401,
    "message": "Request had invalid authentication credentials. Expected OAuth 2 access token, login cookie or other valid authentication credential. See https://developers.google.com/identity/sign-in/web/devconsole-project.",
    "status": "UNAUTHENTICATED"
  }
}

之后我所做的是注销并撤销 Google 登录。我再次登录,出现 select Gmail 帐户的弹出窗口,但未出现授予应用权限弹出窗口。它应该出现,以便应用程序可以再次请求用户允许权限。

授予应用权限弹出窗口。

这是我的做法Google登录

val googleSignInOptions =
    GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
        .requestScopes(Scope("https://www.googleapis.com/auth/photoslibrary.readonly"))
        .requestEmail()
        .build()
val googleSignInClient = GoogleSignIn.getClient(context, googleSignInOptions!!)

这是我在代码中注销和撤销的方式

googleSignInClient?.signOut()
    ?.addOnCompleteListener {
        //Sign Out Complete
        googleSignInClient?.revokeAccess()?.addOnCompleteListener {
            //Revoke Complete
        }
    }

我的观察

  1. 即使在 Gmail Permission 页面中已撤销权限,GoogleSignIn.hasPermissions(GoogleSignIn.getLastSignedInAccount(context), Scope(GOOGLE_PHOTOS_READ_SCOPE)) 仍然 return 正确。逻辑上它应该 return false 因为用户已经撤销了权限。
  2. 即使应用程序已经从 Google 登录退出,当用户再次登录时,用户将获得与前一个相同的访问令牌,前提是过期时间仍在 1 小时内。

总而言之,即使在用户手动撤销权限后,我也希望能够弹出授予应用程序权限。谢谢。

我找到了解决这个问题的方法。

注销时,我需要在线程中调用此函数来清除令牌。

GoogleAuthUtil.clearToken(
    context,
    token
)

总的来说,这就是我退出的方式。

googleSignInClient.signOut()
    .addOnCompleteListener {
        if (it.isSuccessful) {
            thread {
                GoogleAuthUtil.clearToken(
                    context,
                    token
                )
                googleSignInClient.revokeAccess()
            }
        }
        callBack(it.isSuccessful)
    }