Я получил код авторизации от выполнения запроса «GET» и входа в систему, и я пытаюсь использовать этот код для получения токена аутентификации, используя http «POST», но я всегда получаю код ответа 400. Мой код выглядит следующим образом:
// Create HTTP Objects
HttpClient httpclient = HttpClients.createDefault();
HttpPost httpPost = new HttpPost("https://www.googleapis.com/oauth2/v4/token");
// Add Header
httpPost.addHeader("Content-Type", "application/x-www-form-urlencoded");
// Create Parameters
List<NameValuePair> params = new ArrayList<>();
params.add(new BasicNameValuePair("code", code));
params.add(new BasicNameValuePair("client_id", client_id));
params.add(new BasicNameValuePair("client_secret", client_secret));
params.add(new BasicNameValuePair("redirect_uri", redirect_uri));
params.add(new BasicNameValuePair("grant_type", "authorization_code"));
// Add Parameters and Excecute
httpPost.setEntity(new UrlEncodedFormEntity(params, "UTF-8"));
HttpResponse response = httpclient.execute(httpPost);
Кажется, что они идеально соответствуют документации, которую они предоставляют здесь:
https://developers.google.com/identity/protocols/OAuth2WebServer
Есть идеи, почему это происходит?