Estou tentando escrever um script para baixar imagens usando o node.js. Isto é o que eu tenho até agora:
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();
}
Eu, no entanto, quero tornar isso mais robusto:
- Existem bibliotecas que fazem isso e fazem isso melhor?
- Existe uma chance de que os cabeçalhos de resposta estejam (sobre tamanho, tipo de conteúdo)?
- Existem outros códigos de status com os quais devo me preocupar? Devo me preocupar com redirecionamentos?
- Acho que li em algum lugar que a
binary
codificação será descontinuada. O que eu faço então? - Como faço para que isso funcione no Windows?
- Existem outras maneiras de melhorar esse script?
Motivo: para um recurso semelhante ao imgur em que os usuários podem me fornecer um URL, faço o download dessa imagem e a hospedo novamente em vários tamanhos.
image
node.js
image-processing
download
Jonathan Ong
fonte
fonte
Eu me deparei com esse problema há alguns dias atrás, para obter uma resposta pura do NodeJS, sugiro usar o Stream para mesclar os pedaços.
As versões mais recentes do Nó não funcionarão bem com cadeias binárias, portanto, mesclar partes com cadeias não é uma boa ideia ao trabalhar com dados binários.
* Apenas tome cuidado ao usar 'data.read ()', pois ele esvaziará o fluxo para a próxima operação 'read ()'. Se você quiser usá-lo mais de uma vez, guarde-o em algum lugar.
fonte
Você pode usar o Axios (um cliente HTTP baseado em promessas para Node.js) para baixar imagens na ordem que você escolher em um ambiente assíncrono :
Em seguida, você pode usar o seguinte exemplo básico para começar a baixar imagens:
fonte
download_image
de capturar o 'finish' e 'erro' evento para a promessa voltouse você quiser baixar o progresso, tente o seguinte:
Como usar:
nota: você deve instalar os módulos request e request-progress usando:
fonte
statusCode
cheque. Um statusCode 500, por exemplo, não atingirá o'on("error", e)
. Ao adicionar umon('response', (response) => console.error(response.statusCode))
que muito facilita a depuração,Com base no exposto, se alguém precisar lidar com erros nos fluxos de gravação / leitura, usei esta versão. Observe que,
stream.read()
no caso de um erro de gravação, é necessário que possamos concluir a leitura e acionarclose
o fluxo de leitura.fonte
stream.read()
parece estar desatualizado, gera um erronot a function
fonte
Esta é uma extensão da resposta de Cezary. Se você deseja fazer o download para um diretório específico, use isso. Além disso, use const em vez de var. É seguro assim.
fonte