我正在try 编写一个脚本来使用node下载图像.js.这就是我目前的情况:
var maxLength = 10 // 10mb
var download = function(uri, callback) {
http.request(uri)
.on('response', function(res) {
if (res.headers['content-length'] > maxLength*1024*1024) {
callback(new Error('Image too large.'))
} else if (!~[200, 304].indexOf(res.statusCode)) {
callback(new Error('Received an invalid status code.'))
} else if (!res.headers['content-type'].match(/image/)) {
callback(new Error('Not an image.'))
} else {
var body = ''
res.setEncoding('binary')
res
.on('error', function(err) {
callback(err)
})
.on('data', function(chunk) {
body += chunk
})
.on('end', function() {
// What about Windows?!
var path = '/tmp/' + Math.random().toString().split('.').pop()
fs.writeFile(path, body, 'binary', function(err) {
callback(err, path)
})
})
}
})
.on('error', function(err) {
callback(err)
})
.end();
}
一、 但是,要使其更加健壮:
- 有没有这样做并且做得更好的图书馆?
- 关于内容标题(关于内容长度,有一个谎言标题)?
- 还有其他我应该关心的状态码吗?我应该为重定向而烦恼吗?
- 我想我在某个地方读到过,
binary
编码将被弃用.那我该怎么办? - 我怎样才能让它在windows上工作?
- 还有其他方法可以让这个脚本更好吗?
原因:对于一个类似于imgur的功能,用户可以给我一个URL,我下载了该图像,并将其改为多种大小.