Я пытаюсь написать скрипт для загрузки изображений с помощью 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
кодировка будет устаревшей. Что мне тогда делать? - Как я могу заставить это работать на окнах?
- Есть ли другие способы сделать этот скрипт лучше?
Почему: для функции, похожей на imgur, где пользователи могут дать мне URL, я загружаю это изображение и повторно размещаю изображение в нескольких размерах.
image
node.js
image-processing
download
Джонатан Онг
источник
источник
Я столкнулся с этой проблемой несколько дней назад, для чистого ответа NodeJS я бы предложил использовать Stream для объединения кусков вместе.
Новейшие версии Node не будут хорошо работать с двоичными строками, поэтому объединение фрагментов со строками не является хорошей идеей при работе с двоичными данными.
* Просто будьте осторожны при использовании data.read (), он очистит поток для следующей операции read (). Если вы хотите использовать его более одного раза, храните его где-нибудь.
источник
Вы можете использовать Axios ( основанный на обещаниях HTTP-клиент для Node.js) для загрузки изображений в выбранном вами порядке в асинхронной среде :
Затем вы можете использовать следующий базовый пример, чтобы начать загрузку изображений:
источник
download_image
чтобы записывать события 'finish' и 'error' для возвращенного обещанияесли вы хотите прогресс загрузки, попробуйте это:
как пользоваться:
примечание: вы должны установить оба модуля request и request-progress, используя:
источник
statusCode
чек. 500 statusCode, например, не ударит'on("error", e)
. Добавлениеon('response', (response) => console.error(response.statusCode))
значительно облегчает отладку,Основываясь на вышеизложенном, если кому-то нужно обрабатывать ошибки в потоках записи / чтения, я использовал эту версию. Обратите внимание, что
stream.read()
в случае ошибки записи, это необходимо, чтобы мы могли завершить чтение и запуститьclose
поток чтения.источник
stream.read()
кажется устаревшим, выдает ошибкуnot a function
источник
Это продолжение ответа Цезария. Если вы хотите загрузить его в определенный каталог, используйте это. Также используйте const вместо var. Так безопасно.
источник