获取 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
}
}
我的观察
- 即使在 Gmail Permission 页面中已撤销权限,
GoogleSignIn.hasPermissions(GoogleSignIn.getLastSignedInAccount(context), Scope(GOOGLE_PHOTOS_READ_SCOPE))
仍然 return 正确。逻辑上它应该 return false 因为用户已经撤销了权限。
- 即使应用程序已经从 Google 登录退出,当用户再次登录时,用户将获得与前一个相同的访问令牌,前提是过期时间仍在 1 小时内。
总而言之,即使在用户手动撤销权限后,我也希望能够弹出授予应用程序权限。谢谢。
我找到了解决这个问题的方法。
注销时,我需要在线程中调用此函数来清除令牌。
GoogleAuthUtil.clearToken(
context,
token
)
总的来说,这就是我退出的方式。
googleSignInClient.signOut()
.addOnCompleteListener {
if (it.isSuccessful) {
thread {
GoogleAuthUtil.clearToken(
context,
token
)
googleSignInClient.revokeAccess()
}
}
callBack(it.isSuccessful)
}
我正在开发一款能够显示来自 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
}
}
我的观察
- 即使在 Gmail Permission 页面中已撤销权限,
GoogleSignIn.hasPermissions(GoogleSignIn.getLastSignedInAccount(context), Scope(GOOGLE_PHOTOS_READ_SCOPE))
仍然 return 正确。逻辑上它应该 return false 因为用户已经撤销了权限。 - 即使应用程序已经从 Google 登录退出,当用户再次登录时,用户将获得与前一个相同的访问令牌,前提是过期时间仍在 1 小时内。
总而言之,即使在用户手动撤销权限后,我也希望能够弹出授予应用程序权限。谢谢。
我找到了解决这个问题的方法。
注销时,我需要在线程中调用此函数来清除令牌。
GoogleAuthUtil.clearToken(
context,
token
)
总的来说,这就是我退出的方式。
googleSignInClient.signOut()
.addOnCompleteListener {
if (it.isSuccessful) {
thread {
GoogleAuthUtil.clearToken(
context,
token
)
googleSignInClient.revokeAccess()
}
}
callBack(it.isSuccessful)
}