Axios Http client - Как создать Http Post url с параметрами формы
Я пытаюсь создать запрос postHTTP с некоторыми параметрами формы, которые должны быть установлены. Я использую axios с сервером node. У меня уже есть реализация java-кода для построения URL-адреса, как указано ниже:
КОД JAVA:
HttpPost post = new HttpPost(UriBuilder.fromUri (getProperty("authServerUrl"))
.path(TOKEN_ACCESS_PATH).build(getProperty("realm")));
List<NameValuePair> formParams = new ArrayList<NameValuePair>();
formParams.add(new NameValuePair("username",getProperty ("username")));
formParams.add(new NameValuePair("password",getProperty ("password")));
formParams.add(new NameValuePair("client_id, "user-client"));
Я пытаюсь сделать то же самое в аксиомах.
РЕАЛИЗАЦИЯ AXIOS:
axios.post(authServerUrl +token_access_path,
{
username: 'abcd', //gave the values directly for testing
password: '1235!',
client_id: 'user-client'
}).then(function(response) {
console.log(response); //no output rendered
}
Является ли подход к правильной установке этих параметров формы в post post?
Ответы
Ответ 1
Вы должны сделать следующее:
var querystring = require('querystring');
//...
axios.post(authServerUrl + token_access_path,
querystring.stringify({
username: 'abcd', //gave the values directly for testing
password: '1235!',
client_id: 'user-client'
}), {
headers: {
"Content-Type": "application/x-www-form-urlencoded"
}
}).then(function(response) {
console.log(response);
});
Ответ 2
Зачем вставлять другую библиотеку или модуль, чтобы делать что-то настолько простое с чистым ванильным JavaScript? Это действительно одна строка JS для создания желаемых данных для отправки в вашем запросе POST.
// es6 example
const params = {
format: 'json',
option: 'value'
};
const data = Object.entries(params)
.map(([key, val]) => '${key}=${encodeURIComponent(val)}')
.join('&');
console.log(data);
// => format=json&option=value
const options = {
method: 'POST',
headers: { 'content-type': 'application/x-www-form-urlencoded' },
data,
url: 'https://whatever.com/api',
};
const response = await axios(options); // wrap in async function
console.log(response);