Axios使用数据二进制格式发送我的纯JSON

时间:2018-08-31 00:03:55

标签: axios http-status-code-400

当我的Vuejs代码尝试发布JSON时,后端返回400错误。

我通过Chrome网络捕获找到了线索。
我的Axios代码使用数据二进制格式发送了JSON。

curl 'http://localhost:5000/api/auth/login'  \
  -H 'Content-Type: application/json;charset=UTF-8' \
  -H 'Accept: application/json' \
  --data-binary '{"username":"admin","password":"ehllow"}'

但是我不知道它是如何工作的。
我期望的请求是

curl ... -D '{"username":"admin","password":"ehllow"}'`

不是--data-binary

这是我的JavaScript代码。

axios({
  method: 'post',
  url: '/api/auth/login',
  data: {
    "username": "admin",
    "password": "ehllow"
  },
  config: {
    headers: {
      'Content-Type': 'application/json'
    }
  }
})
.then(function (response) {
  //handle success
  console.log(response);
})
.catch(function (response) {
  //handle error
  console.log(response);
});

如何更改我的axios代码以将json发送到普通数据(-D

1 个答案:

答案 0 :(得分:0)

我有同样的问题,答案在这里: axios post request to send form data

简而言之:

let data = new FormData();
data.set("username", "admin");
data.set("password", "ehllow");
axios({
  method: 'post',
  url: '/api/auth/login',
  data: data,
  config: {
    headers: {
      'Content-Type': 'application/json'
    }
  }
})

让我循环一下,因为二进制数据的读取方式不同于表单数据。