Я пытаюсь использовать Spring Social в своем приложении, и во время отладки я заметил, что исходный параметр состояния «OAuth2» всегда имеет значение null в моем приложении.Что может привести к тому, что параметр состояния «OAuth2» будет пустым в org.springframework.social.connect.web.ConnectSupport?
См Spring Социальный исходный код org.springframework.social.connect.web.ConnectSupport
ниже:
private void verifyStateParameter(NativeWebRequest request) {
String state = request.getParameter("state");
String originalState = extractCachedOAuth2State(request);//Always null...
if (state == null || !state.equals(originalState)) {
throw new IllegalStateException("The OAuth2 'state' parameter is missing or doesn't match.");
}
}
private String extractCachedOAuth2State(WebRequest request) {
String state = (String) sessionStrategy.getAttribute(request, OAUTH2_STATE_ATTRIBUTE);
sessionStrategy.removeAttribute(request, OAUTH2_STATE_ATTRIBUTE);
return state;
}
Может кто-нибудь, пожалуйста, помогите?
редактировать: Я вижу состояние параметра передается обратно на Facebook:
Request URL:https://www.facebook.com/v2.5/dialog/oauth?client_id=414113641982912&response_type=code&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fconnect%2Ffacebook&scope=public_profile&state=0b7a97b5-b8d1-4f97-9b60-e3242c9c7eb9
Request Method:GET
Status Code:302
Remote Address:179.60.192.36:443
редактировать 2: Кстати, исключение я получаю следующее:
Exception while handling OAuth2 callback (The OAuth2 'state' parameter is missing or doesn't match.). Redirecting to facebook connection status page.
Должен ли я хранить как заголовки, так и пользовательские стратегии сеанса? Я столкнулся с той же проблемой. – gschambial