我正在尝试从mailchimp API返回已更改成员的列表,如果我使用curl / Postman,则会返回以下(正确的)json:
{
"members": [
{
"id": "187fhdy650b10e8d43552b6c3672368212",
"email_address": "example@email.co.uk",
"unique_email_id": "2edbhgy73836",
"email_type": "html",
"status": "unsubscribed",
"merge_fields": {
"FNAME": "",
"LNAME": "",
"MMERGE5": "",
//etc....
我想使用Node应用程序返回此对象,因此使用node-fetch
如下:
fetch(`https://us5.api.mailchimp.com/3.0/lists/<listid>/members?since_last_changed=2016-10-18T23:10:18+00:00`, {headers: authHeader})
.then((response) => {
if (response.ok) {
res.status(response.status).send(response)
} else {
res.status(response.status).send(response)
}
}).catch((error) => {
res.status(500).send(error.message)
})})
这会返回一个完全不同的json结构,对我来说这表明它是接收数据的中途,并且获取承诺不应该已经解决。它非常大,所以我包括我所看到的关键信息:
{
"_opts": {},
"_chunkSize": 16384,
"_readableState": {
"objectMode": false,
"highWaterMark": 16384,
"buffer": [],
"length": 0,
"pipes": null,
"pipesCount": 0,
"flowing": null,
"ended": false,
"endEmitted": false,
"reading": false,
"sync": false,
"needReadable": true,
"emittedReadable": false,
"readableListening": false,
"resumeScheduled": false,
"defaultEncoding": "utf8",
"ranOut": false,
"awaitDrain": 0,
"readingMore": false,
"decoder": null,
"encoding": null
},
"readable": true,
"domain": null,
"_events": {
"end": [
null,
null
]
},
"_eventsCount": 7,
"_writableState": {
"objectMode": false,
"highWaterMark": 16384,
"needDrain": false,
"ending": true,
"ended": true,
"finished": false,
"decodeStrings": true,
"defaultEncoding": "utf8",
"length": 2674,
"writing": true,
"corked": 0,
"sync": false,
"bufferProcessing": false,
"writelen": 2674,
"bufferedRequest": null,
"lastBufferedRequest": null,
"pendingcb": 1,
"prefinished": false,
"errorEmitted": false,
"bufferedRequestCount": 0,
"corkedRequestsFree": {
"next": null,
"entry": null
}
},
"writable": false,
"allowHalfOpen": true,
"_transformState": {
"needTransform": false,
"transforming": true,
"writechunk": {
"type": "Buffer",
"data": [
31,
139,
8,
0,
0,
0,
0,
0,
198,....
我尝试过以不同的方式对其进行解析,例如首先阅读响应:
.then((response) => {
response.text()})
.then((response) => {
res.status(200).send(response)
})
返回一个未定义的对象。并解析为json:
.then((response) => {
res.status(200).send(response.json())
})
返回一个空对象{}
我可以尝试使用我的提取电话吗?
答案 0 :(得分:0)
fetch()
返回一个解析为响应对象的promise,而该响应对象又有各种方法(.text()
,.json()
),这些方法返回解析为响应主体的promise。 / p>
所以试试这个:
fetch(`https://us5.api.mailchimp.com/3.0/lists/<listid>/members?since_last_changed=2016-10-18T23:10:18+00:00`, {headers: authHeader})
.then(response => {
res.status(response.status);
return response.json();
}).then(body => {
res.send(body);
}).catch(error => {
res.status(500).send(error.message)
});