我无法想象我的生活。以下是request模块的实现,但我也尝试使用node-XMLHttpRequest模块无效。
var request = require('request');
var url = 'http://api.stackexchange.com/2.1/questions?pagesize=100&fromdate=1356998400&todate=1359676800&order=desc&min=0&sort=votes&tagged=javascript&site=stackoverflow';
request.get({ url: url }, function(error, response, body) {
if (error || response.statusCode !== 200) {
console.log('There was a problem with the request');
return;
}
console.log(body); // outputs gibberish characters like �
console.log(body.toString()); // also outputs gibberish
});
似乎是一个编码问题,但我在浏览器中使用了完全相同的代码(使用本机XHR对象),它可以正常工作。我究竟做错了什么?
答案 0 :(得分:10)
内容为gzipped。您可以使用request
和zlib
解压缩来自API的流式响应:
var request = require('request')
,zlib = require('zlib');
var url = 'http://api.stackexchange.com/2.1/questions?pagesize=100&fromdate=1356998400&todate=1359676800&order=desc&min=0&sort=votes&tagged=javascript&site=stackoverflow';
request({ url: url, headers: {'accept-encoding': 'gzip'}})
.pipe(zlib.createGunzip())
.pipe(process.stdout); // not gibberish
答案 1 :(得分:6)
虽然pero的答案是正确的,但有一种更简单的方法可以做到这一点。
由于您正在使用请求,因此您还可以添加gzip: true
标记:
var request = require('request');
var url = 'http://api.stackexchange.com/2.1/questions?pagesize=100&fromdate=1356998400&todate=1359676800&order=desc&min=0&sort=votes&tagged=javascript&site=stackoverflow';
request.get({ url: url, headers: {'accept-encoding': 'gzip'}, gzip: true }, function(error, response, body) {
console.log(body); // not gibberish
});