Запись изображения на локальный сервер - PullRequest
58 голосов
/ 14 марта 2011

Обновление

Принятый ответ был хорош в прошлом году, но сегодня я бы использовал пакет, который используют все остальные: https://github.com/mikeal/request


Оригинал

Я пытаюсь захватить логотип Google и сохранить его на своем сервере с помощью node.js.

Это то, что у меня сейчас и не работает:

        var options = {
            host: 'google.com',
            port: 80,
            path: '/images/logos/ps_logo2.png'
        };

        var request = http.get(options);

        request.on('response', function (res) {
            res.on('data', function (chunk) {
                fs.writeFile(dir+'image.png', chunk, function (err) {
                    if (err) throw err;
                    console.log('It\'s saved!');
                });
            });
        });

Как мне заставить это работать?

Ответы [ 6 ]

82 голосов
/ 14 марта 2011

Здесь происходит несколько вещей:

  1. Я предполагаю, что вам нужен fs / http, и установите переменную dir:)
  2. google.com перенаправляет на www.google.com, поэтому вы сохраняете тело ответа перенаправления, а не изображение
  3. ответ передается в потоковом режиме. это означает, что событие data происходит много раз, а не один раз. Вы должны сохранить и объединить все куски вместе, чтобы получить полное тело ответа
  4. , так как вы получаете двоичные данные, вы должны соответствующим образом установить кодировку для response и writeFile (по умолчанию utf8)

Это должно работать:

var http = require('http')
  , fs = require('fs')
  , options

options = {
    host: 'www.google.com'
  , port: 80
  , path: '/images/logos/ps_logo2.png'
}

var request = http.get(options, function(res){
    var imagedata = ''
    res.setEncoding('binary')

    res.on('data', function(chunk){
        imagedata += chunk
    })

    res.on('end', function(){
        fs.writeFile('logo.png', imagedata, 'binary', function(err){
            if (err) throw err
            console.log('File saved.')
        })
    })

})
36 голосов
/ 10 декабря 2013

Эта ветка старая, но я хотел сделать то же самое с пакетом https://github.com/mikeal/request.

Вот рабочий пример

var fs      = require('fs');
var request = require('request');
// Or with cookies
// var request = require('request').defaults({jar: true});

request.get({url: 'https://someurl/somefile.torrent', encoding: 'binary'}, function (err, response, body) {
  fs.writeFile("/tmp/test.torrent", body, 'binary', function(err) {
    if(err)
      console.log(err);
    else
      console.log("The file was saved!");
  }); 
});
26 голосов
/ 07 января 2012

Я предлагаю вам использовать http-запрос , чтобы можно было управлять даже перенаправлениями.

var http = require('http-request');
var options = {url: 'http://localhost/foo.pdf'};
http.get(options, '/path/to/foo.pdf', function (error, result) {
    if (error) {
        console.error(error);
    } else {
        console.log('File downloaded at: ' + result.file);
    }
});
5 голосов
/ 05 ноября 2014

Как насчет этого?

var http = require('http'), 
fs = require('fs'), 
options;

options = {
    host: 'www.google.com' , 
    port: 80,
    path: '/images/logos/ps_logo2.png'
}

var request = http.get(options, function(res){

//var imagedata = ''
//res.setEncoding('binary')

var chunks = [];

res.on('data', function(chunk){

    //imagedata += chunk
    chunks.push(chunk)

})

res.on('end', function(){

    //fs.writeFile('logo.png', imagedata, 'binary', function(err){

    var buffer = Buffer.concat(chunks)
    fs.writeFile('logo.png', buffer, function(err){
        if (err) throw err
        console.log('File saved.')
    })

})
0 голосов
/ 27 декабря 2018

Самый чистый способ локального сохранения изображения с использованием запроса :

const request = require('request');
request('http://link/to/your/image/file.png').pipe(fs.createWriteStream('fileName.png'))

Если вам нужно добавить маркер аутентификации в заголовки, сделайте это:

const request = require('request');
request({
        url: 'http://link/to/your/image/file.png',
        headers: {
            "X-Token-Auth": TOKEN,
        }
    }).pipe(fs.createWriteStream('filename.png'))                    
0 голосов
/ 14 ноября 2018

У меня есть более простое решение, использующее fs.readFileSync(./my_local_image_path.jpg)

Это для чтения изображений из API Vision Azure Cognative Services

const subscriptionKey = 'your_azure_subscrition_key';
const uriBase = // **MUST change your location (mine is 'eastus')**
    'https://eastus.api.cognitive.microsoft.com/vision/v2.0/analyze';

// Request parameters.
const params = {
    'visualFeatures': 'Categories,Description,Adult,Faces',
    'maxCandidates': '2',
    'details': 'Celebrities,Landmarks',
    'language': 'en'
};

const options = {
    uri: uriBase,
    qs: params,
    body: fs.readFileSync(./my_local_image_path.jpg),
    headers: {
        'Content-Type': 'application/octet-stream',
        'Ocp-Apim-Subscription-Key' : subscriptionKey
    }
};

request.post(options, (error, response, body) => {
if (error) {
    console.log('Error: ', error);
    return;
}
let jsonString = JSON.stringify(JSON.parse(body), null, '  ');
body = JSON.parse(body);
if (body.code) // err
{
    console.log("AZURE: " + body.message)
}

console.log('Response\n' + jsonString);
...