我尝试使用Google oauth在我的Android应用上验证用户身份.然后我想将它发送到我的应用服务器,以便它可以随时与Google日历连接.
我试着用
GoogleAuthUtil.getToken(getApplicationContext(), mAccountName, mScope);
关注本文:https: //developers.google.com/accounts/docs/CrossClientAuth
当我将其与范围一起使用时,
mScope = "oauth2:https://www.googleapis.com/auth/calendar https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/userinfo.profile";
我会获得一个令牌,该令牌有效一小时
但是当我尝试获取授权代码时(因此我可以获得一个有效期较长的刷新令牌,使用
mScope2 ="oauth2:server:client_id:{CLIENT_ID}.apps.googleusercontent.com"+ ":api_scope:https://www.googleapis.com/auth/calendar https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/userinfo.profile";
我收到"invalid_scope"或"Unknown"异常.
我究竟做错了什么?
编辑:好的,在谷歌API控制台上创建一个新的应用程序并将plus.login添加到范围后我得到一个代码,但由于某种原因我的服务器无法解析此令牌.绑定解析服务器时会收到有关重定向URL的错误.顺便说一句,当我使用相同的参数进行Web流程时,它可以工作.