Ответ 1
Вы должны отправлять свои данные в POST-запросе со значением заголовка Content-Type
установленным в application/x-www-form-urlencoded
, а не в json.
У меня есть автономная работа Keycloak на моей локальной машине.
Я создал новую область под названием "spring-test", затем новый клиент под названием "login-app"
Согласно остальной документации:
POST: http://localhost:8080/auth/realms/spring-test/protocol/openid-connect/token
{
"client_id": "login-app",
"username": "user123",
"password": "pass123",
"grant_type": "password"
}
должен дать мне токен JWT, но я получаю неверный запрос с ответом
{
"error": "invalid_request",
"error_description": "Missing form parameter: grant_type"
}
Я предполагаю, что что-то не хватает в моей конфигурации.
РЕДАКТИРОВАТЬ: я использовал тело json, но он должен быть закодирован в форме URL: работает следующее тело:
token_type_hint:access_token&token:{token}&client_id:{client_id}&client_secret:{client_secret}
Вы должны отправлять свои данные в POST-запросе со значением заголовка Content-Type
установленным в application/x-www-form-urlencoded
, а не в json.
Для тех, у кого проблемы с curl, команда curl выглядит следующим образом:
curl -d "client_secret=<client-secret>" -d "client_id=<client-id>" -d "username=<username>" -d "password=<password>" -d "grant_type=password" "http://localhost:8080/auth/realms/<realm-name>/protocol/openid-connect/token"
Команда curl работает без заголовка Content-Type
.
Этот работал для меня, проверьте это
И я передал body следующим образом → body: 'grant_type = пароль & username = abc & password = abc & client_id = yourId'
Вот полный пример, когда обмен code
для access_token
с keycloak
органом с использованием axios
.
Я использовал строку запроса в этом примере:
npm install querystring --save-dev
или же
yarn add querystring --dev
Отправка запроса:
import queryString from 'querystring'
const params = {
grant_type: 'authorization_code,
client_id: 'client-id-here',
code: 'code-from-previous-redirect',
redirect_uri: location.protocol + '//' + location.host
};
axios({
method: 'post',
url: 'https://my-keycloak.authority/token',
data: queryString.stringify(params),
config: {
headers: {'Content-Type': 'application/x-www-form-urlencoded'}
}
}).then(response => {
console.log(response.data);
}).catch(error => {
console.error(error);
});
Вам необходимо отправить запрос POST с параметрами в виде строки в кодировке URL в теле запроса.
Объект FormData не работает.