2

我正在将 OpenID 2.0 迁移到 OAuth 2.0 登录(请参阅https://developers.google.com/accounts/docs/OpenID?hl=ja)。我想将新的 OpenID 2.0 标识符映射到数据库中的旧的/现有的 OpenID Connect 标识符。

我正在处理 OAuth 响应 (redirect_uri),我想使用https://www.googleapis.com/oauth2/v3/token端点来交换访问令牌和 openid_id 的授权代码字段,我将使用它来选择我的数据库中的现有用户。

但是,我对https://www.googleapis.com/oauth2/v3/token的调用返回“未找到”。任何线索为什么?

我正在使用 scribe 1.3.7,这是我的代码:

OAuthService service = new ServiceBuilder().provider(Google2Api.class).apiKey(xxxxxxxx).apiSecret(yyyyyyyyyyyyyyy).callback(zzzzzzzzzzzzzzzzzzzz).scope("openid profile https://mail.google.com/ https://www.googleapis.com/auth/userinfo.email").build();
Token accessToken = service.getAccessToken(null, new Verifier(oauth_verifier);
OAuthRequest request = new OAuthRequest(Verb.GET, "https://www.googleapis.com/oauth2/v3/token");
request.addQuerystringParameter("format","json");
request.addQuerystringParameter(OAuthConstants.REALM, "http://*.unclestock.com");
service.signRequest(accessToken, request); 
Response response = request.send(); 
// result -> not found
4

1 回答 1

3

GET请求https://www.googleapis.com/oauth2/v3/token返回“未找到”。您需要对POST请求使用 HTTP。

将代码的第 3 行更新为以下内容,然后重试:

OAuthRequest request = new OAuthRequest(Verb.POST, "https://www.googleapis.com/oauth2/v3/token");

您可以在官方文档中阅读更多关于将代码交换为访问令牌和 ID 令牌的信息。

于 2015-02-01T03:47:35.530 回答