我正在尝试将 html 页面与我的 Mailchimp(免费)帐户连接起来。我已经阅读了文档,应该很简单。
这是我的 JS 代码(页面加载时加载的 jQuery 1.2.2):
username = [your-username];
apiKey = [your-mailchimp-api-key];
baseUrlMailchimp = "https://us5.api.mailchimp.com/3.0/";
apiMC = function(type, data, url, callback) {
$.ajax({
type: type,
dataType: 'jsonp',
data: data,
contentType: 'application/json',
url: url,
beforeSend: function(xhr) {
xhr.setRequestHeader('Authorization', 'Basic ' + btoa(username + ":" + apiKey));
},
success: function(e) {
if (callback) {
callback(e)
}
},
error: function(e) {
console.log(e);
}
});
}
apiMC('GET', '', baseUrlMailchimp + 'lists', function(res){console.log(res)})
问题是我收到错误 401(您的请求不包含 API 密钥)。
如果我从 Chrome REST 客户端启动相同的请求:
在基本身份验证字段中指定 url 和 user/api,一切正常!
我不明白为什么,有人可以帮助我吗?
更新:来自 MAILCHIMP 的回答
嘿,弗朗西斯科,
我查看了提供的文章链接,看起来您确实遇到了相同的 Origin 策略块。同源策略阻止 ajax 调用其非源域。因此,您需要使用服务器端方法来触发 API 调用。
此外,此时 MailChimp 不支持 API 3.0 的 Jsonp。
如果还有什么我可以提供帮助的,请随时联系支持。
结尾