2

Google OAuth2 API を使用して基本的なユーザー プロファイル情報を取得しようとしていますが、Invalid_grant とエラーの説明 Invalid Code を示すアクセス/リフレッシュ トークンをフェッチしようとして失敗します。以下は、トークンを取得するための私のコードです

public static String getUserInfoJson(final String authCode) throws IOException{

    GoogleTokenResponse response = flow.newTokenRequest(authCode)
                .setRedirectUri(CALLBACK_URI)
                .execute();
    Credential credential = flow.createAndStoreCredential(response,
                null);
    final HttpRequestFactory requestFactory = HTTP_TRANSPORT
            .createRequestFactory(credential);
    // Make an authenticated request
    final GenericUrl url = new GenericUrl(USER_INFO_URL);
    final HttpRequest request = requestFactory.buildGetRequest(url);
    request.getHeaders().setContentType("application/json");
    final String jsonIdentity = request.execute().parseAsString();

    return jsonIdentity;

}

以下は、authCodeを作成するための私のコードです

    private static final String CLIENT_ID = "CLIENT_ID_BUT_NOT_EMAIL_ID"; //Not emailid
    private static final String CLIENT_SECRET = "SecretKey";
    private static final String CALLBACK_URI = "http://localhost:8080/Spring4MVCHelloWorld/OAuthRedirect";
    private static final String ACCESS_TYPE = "offline";

    private static final Iterable<String> SCOPE = Arrays
        .asList("https://www.googleapis.com/auth/userinfo.profile;https://www.googleapis.com/auth/userinfo.email"
                .split(";"));
    private static final String USER_INFO_URL = "https://www.googleapis.com/oauth2/v1/userinfo";
    private static final JsonFactory JSON_FACTORY = new JacksonFactory();
    private static final HttpTransport HTTP_TRANSPORT = new NetHttpTransport();

    private String stateToken;

    private static GoogleAuthorizationCodeFlow flow;

    public GoogleAuthHelper() {
        flow = new GoogleAuthorizationCodeFlow.Builder(HTTP_TRANSPORT,
            JSON_FACTORY, CLIENT_ID, CLIENT_SECRET, SCOPE)
            .setAccessType(ACCESS_TYPE)
            .build();

        generateStateToken();
    }

    public String buildLoginUrl() {

        final GoogleAuthorizationCodeRequestUrl url = flow
            .newAuthorizationUrl();

        return url.setRedirectUri(CALLBACK_URI).setState(stateToken).build();
    }

    private void generateStateToken() {

        SecureRandom sr1 = new SecureRandom();

        stateToken = "google;" + sr1.nextInt();

    }

    public String getStateToken() {
        return stateToken;
    }

ユーザーはリダイレクト URL に正常にリダイレクトされますが、その後の getUserInfoJson の呼び出しは 400 応答で失敗します。私はこれに似た多くのSOの質問を無駄にしました。

4

0 に答える 0