我正在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为您完成这一工作),因此它应该有某种内容。但没有尸体,没有数据,我无法从中读取信息。尸体藏在哪里?


当前回答

一份咖啡:

# My little helper
read_buffer = (buffer, callback) ->
  data = ''
  buffer.on 'readable', -> data += buffer.read().toString()
  buffer.on 'end', -> callback data

# So request looks like
http.get 'http://i.want.some/stuff', (res) ->
  read_buffer res, (response) ->
    # Do some things with your response
    # but don't do that exactly :D
    eval(CoffeeScript.compile response, bare: true)

和编译

var read_buffer;

read_buffer = function(buffer, callback) {
  var data;
  data = '';
  buffer.on('readable', function() {
    return data += buffer.read().toString();
  });
  return buffer.on('end', function() {
    return callback(data);
  });
};

http.get('http://i.want.some/stuff', function(res) {
  return read_buffer(res, function(response) {
    return eval(CoffeeScript.compile(response, {
      bare: true
    }));
  });
});

其他回答

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

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

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

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

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

编辑: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有值,控制就会简单地传递到下一行。

只是一个改进版的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(")将分配 新的内存只有一次。

我还想添加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);
});