Keycloak Отсутствует параметр формы: grant_type

У меня есть автономная работа 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}

Ответ 1

Вы должны отправлять свои данные в POST-запросе со значением заголовка Content-Type установленным в application/x-www-form-urlencoded, а не в json.

Ответ 2

Для тех, у кого проблемы с 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.

Ответ 3

Этот работал для меня, проверьте это

И я передал body следующим образом → body: 'grant_type = пароль & username = abc & password = abc & client_id = yourId'

Ответ 4

Вот полный пример, когда обмен 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 не работает.