我正在将 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