Я пытаюсь реализовать гибридный протокол OpenID + OAuth в своем приложении для Google. Я получаю токен запроса. Итак, следующий шаг в качестве документа в системе федеративного входа - это токен запроса обмена на токен доступа.
Я пробовал использовать Java-библиотеку OAuth, но не получаю токен доступа. Пробую и трехногий, и двуногий подходы не увенчались успехом.
Кому-нибудь удастся сделать гибридный протокол.
GoogleOAuthParameters oauthParameters = new GoogleOAuthParameters();
oauthParameters.setOAuthConsumerKey(consumerKey);
oauthParameters.setOAuthConsumerSecret(consumerSecret);
calendarService = new CalendarService("marketplace-hello");
try {
calendarService.setOAuthCredentials(oauthParameters,
new OAuthHmacSha1Signer());
CalendarEventFeed results = calendarService.query(calendarFeedUrl,
CalendarFeed.class);
}
catch (OAuthException e)
{
throw new ServletException("Unable to initialize calendar service", e);
}
Это вызывает исключение com.google.gdata.client.authn.oauth.OAuthException: oauth_token не существует.
oAuthParameters.setOAuthType (OAuthType.TWO_LEGGED_OAUTH); и xoauth_requestor_id attibute для feedURL, если я добавлю эти строки в код, я получаю исключение Invalid AuthSub Token, я не знаю, почему он говорит Invalid AuthSub.