ฉันพยายามเขียนสคริปต์เพื่อดาวน์โหลดภาพโดยใช้ 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 แก่ฉันได้ฉันจะดาวน์โหลดภาพนั้นและนำรูปภาพกลับมาใช้ใหม่ในหลายขนาด