我正在http://nodejs.org/docs/v0.4.0/api/http.html#http.request上阅读文档,但由于某种原因,我似乎无法在返回的已完成响应对象上找到body/data属性。

> var res = http.get({host:'www.somesite.com', path:'/'})

> res.finished
true

> res._hasBody
true

它完成了(http。Get为您完成这一工作),因此它应该有某种内容。但没有尸体,没有数据,我无法从中读取信息。尸体藏在哪里?


当前回答

http。请求文档包含了如何通过处理数据事件接收响应体的示例:

var options = {
  host: 'www.google.com',
  port: 80,
  path: '/upload',
  method: 'POST'
};

var req = http.request(options, function(res) {
  console.log('STATUS: ' + res.statusCode);
  console.log('HEADERS: ' + JSON.stringify(res.headers));
  res.setEncoding('utf8');
  res.on('data', function (chunk) {
    console.log('BODY: ' + chunk);
  });
});

req.on('error', function(e) {
  console.log('problem with request: ' + e.message);
});

// write data to request body
req.write('data\n');
req.write('data\n');
req.end();

http。Get做的事情与http相同。请求,除非它自动调用req.end()。

var options = {
  host: 'www.google.com',
  port: 80,
  path: '/index.html'
};

http.get(options, function(res) {
  console.log("Got response: " + res.statusCode);

  res.on("data", function(chunk) {
    console.log("BODY: " + chunk);
  });
}).on('error', function(e) {
  console.log("Got error: " + e.message);
});

其他回答

你需要为请求添加一个监听器,因为node.js是异步工作的:

request.on('response', function (response) {
  response.on('data', function (chunk) {
    console.log('BODY: ' + chunk);
 });
});

你不能从http.get()的返回值中获得响应体。

get()不返回响应对象。它返回请求对象(http.clientRequest)。因此,没有任何方法可以从http.get()的返回值获取响应体。

我知道这是一个老问题,但阅读您链接到的文档表明,即使在您发布它时也是如此。

只是一个改进版的nkron响应。

const httpGet = url => {
  return new Promise((resolve, reject) => {
    http.get(url, res => {
      res.setEncoding('utf8');
      const body = [];
      res.on('data', chunk => body.push(chunk));
      res.on('end', () => resolve(body.join('')));
    }).on('error', reject);
  });
};

在字符串[]中添加块对内存使用更好,join(")将分配 新的内存只有一次。

编辑:6年后回复自己

await关键字是从HTTP请求获得响应的最佳方式,避免了回调和.then()

您还需要使用返回promise的HTTP客户机。get()仍然返回一个Request对象,因此这将不起作用。

fetch是一个低级客户端,从npm和nodeJS 17起都可以使用。 superagent是一个成熟的HTTP客户端,具有更合理的默认值,包括更简单的查询字符串编码,正确使用mime类型,默认为JSON,以及其他常见的HTTP客户端特性。 Axios也很受欢迎,具有与超级代理类似的优势

await将等待Promise有一个值—在本例中是一个HTTP响应!

const superagent = require('superagent');

(async function(){
  const response = await superagent.get('https://www.google.com')
  console.log(response.text)
})();

使用await,一旦superagent.get()返回的promise有值,控制就会简单地传递到下一行。

我还想添加http。由http.get()返回的ClientResponse有一个结束事件,所以这里是我接收正文响应的另一种方式:

var options = {
  host: 'www.google.com',
  port: 80,
  path: '/index.html'
};

http.get(options, function(res) {
  var body = '';
  res.on('data', function(chunk) {
    body += chunk;
  });
  res.on('end', function() {
    console.log(body);
  });
}).on('error', function(e) {
  console.log("Got error: " + e.message);
});