Я пытаюсь получить токен доступа GitHub oauth. Перенаправление пользователя на https://github.com/login/oauth/authorize прекрасно работает и получает код.Ошибка Cookie при получении токена доступа OAuth от GitHub
Однако, когда я делаю запрос POST от сервера к https://github.com/login/oauth/acces_token, сервер отвечает
403: Forbidden/Cookies must be enabled to use GitHub.
Я получаю что-то здесь не так? Это API! Какова роль куки здесь? Как я могу исправить ошибку?
Мой код (используя OkHttp)
String code= ...;
HttpUrl url = new HttpUrl.Builder()
.scheme("https").host("github.com")
.addPathSegments("login/oauth/acces_token")
.build();
StringBuilder formEncoded = new StringBuilder();
formEncoded.append("client_id=").append(URLEncoder.encode(..., "UTF-8"));
formEncoded.append("&client_secret=").append(URLEncoder.encode(..., "UTF-8"));
formEncoded.append("&code=").append(URLEncoder.encode(code, "UTF-8"));
Response resp = client.newCall(
new Request.Builder().url(url)
.post(RequestBody.create(
MediaType.parse("application/x-www-form-urlencoded"),
formEncoded.toString()))
.addHeader("Accept", "application/json").build())
.execute();
if (resp.code() != HttpServletResponse.SC_OK) {
log.error("Error while getting token: {}: {}/{}",
resp.code(), resp.message(), resp.body().string());
throw new RuntimeException("Error while getting access token");
}
см. Также http://fajitanachos.com/Authenticating-with-the-GitHub-API/ и https://github.com/vjeux/GithubLogin/blob/master/token.php – ruediste