我继承了一个使用Axios的代码库,除此之外,我对这个库并不熟悉。这是一个Node应用程序,我正在尝试向第三方API发送补丁请求。Axios使用以下配置:
const axios = require('axios').create({
baseURL: process.env.API_URL,
headers: {
'Content-Type': 'application/json',
'Accept': 'application/json',
},
auth: {
username: process.env.API_USER,
password: process.env.API_PW,
},
});然后,我尝试发出以下补丁请求:
const data = {
fields: {
field_a: 'yes',
field_b: 'no',
},
};
try {
const res = await axios.patch(`/user/${user.id}`, data, {
headers: {
'Content-Type': 'application/json'
}
});
return res;
} catch (err){
console.error(err);
}根据我所看到的,我只是在进行patch调用时重新定义Content-Type头,但这只是为了弄清楚这一点。这两种方式都不起作用。我在response对象的config属性中看到的内容如下(排除了大部分内容):
{
headers: {
Accept: "application/json"
User-Agent: "axios/0.19.0"
},
method: 'patch',
}查看同一响应对象的request属性,我看到其中的方法被列为"GET“,而Content-Type头也未在此处列出。看起来好像Content-Type标头正在被剥离,方法正在被更改为GET。
如果我只将URL目标改为/userWRONGPATH/${user.id},我会收到一个404响应,但响应对象的配置数据包括以下内容:
{
headers: {
Accept: "application/json"
Content-Length: 105
Content-Type: "application/json"
User-Agent: "axios/0.19.0"
}
}响应对象的请求方法现在是预期的“PATCH”。我不确定为什么补丁方法会适用于其他路径,如果这实际上就是这里正在发生的事情。
发布于 2020-06-18 07:32:19
你好,我认为问题可能与在Axios中再次发送报头有关,您定义了一个配置,并将其添加到所有请求中。
这是我使用axios订购项目的一个示例。
// Axios custom config
const axiosInstance = axios.create({
baseURL: urlBase,
// timeout: 1000,
headers: { 'Content-type': 'application/json' },
});
export const apiPatchRequest = (url, id, obj) => (
axiosInstance.patch(`${url}/${id}`, obj)
);https://stackoverflow.com/questions/62439666
复制相似问题