0

我正在尝试设置 axios 发布请求以将成员添加到受众列表,但我不知道如何添加 API 密钥(不断给出错误 401:“您的请求不包含 API 密钥。”) . 我在“授权”标题中尝试了很多东西,就像我在下面放的一样(还有:、、、、,"Bearer ${mailchimpKey}"可能"${mailchimpKey}"还有更多......)。"Bearer ${mailchimpKey}""Basic ${mailchimpKey}"

我也不知道“用户名”是什么,但是当我在其他地方测试 API 时,“任何”都有效。

有谁知道我应该如何设置?

axios
.post(
  `https://${server}.api.mailchimp.com/3.0/lists/${list_id}/members`,
  {
    email_address: email,
    status: "subscribed",
  },
  {
    "User-Agent": "Request-Promise",
    Connection: "keep-alive",
    Authorization: `Basic any:${mailchimpKey}`,
    // Testing on localhost
    "Access-Control-Allow-Origin": "*",
    "Access-Control-Allow-Headers": "Content-Type",
  }
)
4

1 回答 1

0

如果您打算使用HTTP 基本身份验证,只需使用 Axiosauth 配置选项

axios.post(
  `https://${server}.api.mailchimp.com/3.0/lists/${encodeURIComponent(list_id)}/members`,
  {
    email_address: email,
    status: "subscribed",
  },
  {
    auth: {
      username: "anystring",
      password: mailchimpKey
    },
    headers: { // personally, I wouldn't add any extra headers
      "User-agent": "Request-Promise"
    }
  }
)

HTTP 基本身份验证标头看起来像

Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ=

其中“Basic”之后的字符串是 Base64 编码的"username:password"字符串。Axios 提供auth了方便的选项,因此您不需要自己对字符串进行编码。

您遇到的其他一些问题是:

  • headers在配置选项之外添加请求标头
  • 尝试发送Access-Control-Allow-OriginAccess-Control-Allow-Headers作为请求标头。这些只是响应标头。将它们添加到您的请求中很可能会导致更多的 CORS 错误
于 2021-05-27T00:29:13.540 回答