POST请求的身份验证错误:使用Axios时未提供“身份验证凭据”,但使用POSTMAN时有效

时间:2019-11-15 12:55:20

标签: reactjs axios authorization postman token

我正在使用React并尝试处理用户的密码更改。我正在发送这样的POST请求:

axios.post('http://127.0.0.1:8000/users/password/change/', {
            headers: {
                'Content-type': 'application/json',
                'Authorization': `Token ${token}`
            },
            data: {
                new_password1: newPassword1,
                new_password2: newPassword2
            }
        })

...并且我收到401错误:“未提供身份验证凭据”。

但是,如果我通过 POSTMAN 发送确切的相同请求,则效果很好。

我也在同一应用程序中执行GET请求以获取用户数据,它也可以正常工作:

axios.get('http://127.0.0.1:8000/users/' + path + '/' + userId + '/', {
            headers: {
                'Content-type': 'application/json',
                'Authorization': `Token ${token}`
            }
        })

可能是什么问题...?

1 个答案:

答案 0 :(得分:1)

axios.post期望(URL,数据,配置)。

所以您需要这样使用:

  axios.post(
    "http://127.0.0.1:8000/users/password/change/",
    {
      new_password1: newPassword1,
      new_password2: newPassword2
    },
    {
      headers: {
        "Content-type": "application/json",
        "Authorization": `Token ${token}`
      }
    }
  );

文档:

https://github.com/axios/axios#axiosposturl-data-config