Как сделать удаленный вызов REST внутри Node.js? любой CURL?

190

В Node.js , кроме использования дочернего процесса для вызова CURL , есть ли способ сделать вызов CURL API REST удаленного сервера и получить возвращаемые данные?

Мне также нужно настроить заголовок запроса для удаленного вызова REST , а также строку запроса в GET (или POST).

Я нахожу это: http://blog.nodejitsu.com/jsdom-jquery-in-5-lines-on-nodejs

но это не показывает путь к строке запроса POST.

murvinlai
источник
Я написал этот github.com/jonataswalker/vps-rest-client
Джонатас Уолкер,

Ответы:

213

смотреть на http.request

var options = {
  host: url,
  port: 80,
  path: '/resource?id=foo&bar=baz',
  method: 'POST'
};

http.request(options, function(res) {
  console.log('STATUS: ' + res.statusCode);
  console.log('HEADERS: ' + JSON.stringify(res.headers));
  res.setEncoding('utf8');
  res.on('data', function (chunk) {
    console.log('BODY: ' + chunk);
  });
}).end();
Raynos
источник
3
Итак, даже если это POST, я также добавляю данные в строку запроса?
Мурвинлай
3
@murvinlai не уверен. Пойдите, прочитайте документы, источник, спецификацию HTTP. Не эксперт в этом регионе.
Raynos
15
Стоит отметить, что вы не вводите http или https в запись вашего хоста, например, var options = {host: graph.facebook.com ....}, а не {host: http: graph.facebook.com}. Это сбило меня с толку на несколько циклов. (Увидеть ниже). Это оба отличные ответы. Спасибо вам обоим.
двоичный гигант
9
Могу ли я просто указать, что если ответ длинный, использования res.on ('data', ..) недостаточно. Я полагаю, что правильный способ также заключается в том, чтобы res.on ('конец' ..) знал, когда вы получили все данные. Тогда вы можете обработать.
Ксерри
4
Это очень старый ответ - для тех, кто пишет сегодня узел js, вы наверняка используете npmjs.com/package/node-fetch или другой пакет, основанный на API выборки, который основан на стандарте Fetch. Смотрите мой ответ ниже.
Saille
94

Как насчет использования запроса - упрощенный HTTP-клиент .

Изменить февраль 2020 года: запрос устарел, поэтому вам, вероятно, больше не следует его использовать.

Вот ПОЛУЧИТЬ:

var request = require('request');
request('http://www.google.com', function (error, response, body) {
    if (!error && response.statusCode == 200) {
        console.log(body) // Print the google web page.
     }
})

ОП тоже хотел ПОЧТУ:

request.post('http://service.com/upload', {form:{key:'value'}})
Мэтт Фреар
источник
1
Работает нормально с google.com, но при запросе API api graph возвращает «RequestError: Ошибка: сокет зависает». Пожалуйста, руководство, спасибо!
Динамическое Ремо
Этот модуль содержит много вопросов!
Пратик
Как я могу передать параметр запроса при использовании REST API таким образом?
vdenotaris
3
По состоянию на 11 февраля 2020 года запрос полностью УСТАРЕЛ. Вы можете увидеть это на сайте github.com/request/request#deprecated
Садиэль
Любое руководство о том, что новички должны использовать? Я фильтрую через множество примеров, которые используют это.
Steve3p0
36

Посмотрите на http://isolasoftware.it/2012/05/28/call-rest-api-with-node-js/

var https = require('https');

/**
 * HOW TO Make an HTTP Call - GET
 */
// options for GET
var optionsget = {
    host : 'graph.facebook.com', // here only the domain name
    // (no http/https !)
    port : 443,
    path : '/youscada', // the rest of the url with parameters if needed
    method : 'GET' // do GET
};

console.info('Options prepared:');
console.info(optionsget);
console.info('Do the GET call');

// do the GET request
var reqGet = https.request(optionsget, function(res) {
    console.log("statusCode: ", res.statusCode);
    // uncomment it for header details
//  console.log("headers: ", res.headers);


    res.on('data', function(d) {
        console.info('GET result:\n');
        process.stdout.write(d);
        console.info('\n\nCall completed');
    });

});

reqGet.end();
reqGet.on('error', function(e) {
    console.error(e);
});

/**
 * HOW TO Make an HTTP Call - POST
 */
// do a POST request
// create the JSON object
jsonObject = JSON.stringify({
    "message" : "The web of things is approaching, let do some tests to be ready!",
    "name" : "Test message posted with node.js",
    "caption" : "Some tests with node.js",
    "link" : "http://www.youscada.com",
    "description" : "this is a description",
    "picture" : "http://youscada.com/wp-content/uploads/2012/05/logo2.png",
    "actions" : [ {
        "name" : "youSCADA",
        "link" : "http://www.youscada.com"
    } ]
});

// prepare the header
var postheaders = {
    'Content-Type' : 'application/json',
    'Content-Length' : Buffer.byteLength(jsonObject, 'utf8')
};

// the post options
var optionspost = {
    host : 'graph.facebook.com',
    port : 443,
    path : '/youscada/feed?access_token=your_api_key',
    method : 'POST',
    headers : postheaders
};

console.info('Options prepared:');
console.info(optionspost);
console.info('Do the POST call');

// do the POST call
var reqPost = https.request(optionspost, function(res) {
    console.log("statusCode: ", res.statusCode);
    // uncomment it for header details
//  console.log("headers: ", res.headers);

    res.on('data', function(d) {
        console.info('POST result:\n');
        process.stdout.write(d);
        console.info('\n\nPOST completed');
    });
});

// write the json data
reqPost.write(jsonObject);
reqPost.end();
reqPost.on('error', function(e) {
    console.error(e);
});

/**
 * Get Message - GET
 */
// options for GET
var optionsgetmsg = {
    host : 'graph.facebook.com', // here only the domain name
    // (no http/https !)
    port : 443,
    path : '/youscada/feed?access_token=you_api_key', // the rest of the url with parameters if needed
    method : 'GET' // do GET
};

console.info('Options prepared:');
console.info(optionsgetmsg);
console.info('Do the GET call');

// do the GET request
var reqGet = https.request(optionsgetmsg, function(res) {
    console.log("statusCode: ", res.statusCode);
    // uncomment it for header details
//  console.log("headers: ", res.headers);


    res.on('data', function(d) {
        console.info('GET result after POST:\n');
        process.stdout.write(d);
        console.info('\n\nCall completed');
    });

});

reqGet.end();
reqGet.on('error', function(e) {
    console.error(e);
});
Джулио Роггеро
источник
1
Как мне получить доступ к значениям из d ??? d = {"data": [{"id": 1111, "name": "peter"}]}. как получить значение имени?
Питер
2
удалось получить значения с помощью var thed = JSON.parse (d); console.log («идентификатор:» + thed.data [0] .id); Но когда-то я получаю «Неожиданный конец ввода»
Питер
33

Я использую node-fetch, потому что он использует знакомый (если вы веб-разработчик) fetch () API . fetch () - это новый способ делать произвольные HTTP-запросы из браузера.

Да, я знаю, что это вопрос узла js, но разве мы не хотим сократить число разработчиков API, которые нужно запомнить и понять, и улучшить возможность повторного использования нашего кода javascript? Извлечение - это стандарт, так как насчет того, чтобы мы с этим сошлись?

Еще одна приятная вещь в fetch () - она ​​возвращает обещание JavaScript , поэтому вы можете написать асинхронный код следующим образом:

let fetch = require('node-fetch');

fetch('http://localhost', {
  method: 'POST',
  headers: {'Content-Type': 'application/json'},
  body: '{}'
}).then(response => {
  return response.json();
}).catch(err => {console.log(err);});

Fetch заменяет XMLHTTPRequest . Вот еще немного информации .

Saille
источник
Проблема node-fetchпри написании API заключается в том, что работает только полный URL и не будет работать с относительными URL.
Себастьян
5

Вардар

Пример (axios_example.js) с использованием Axios в Node.js:

const axios = require('axios');
const express = require('express');
const app = express();
const port = process.env.PORT || 5000;

app.get('/search', function(req, res) {
    let query = req.query.queryStr;
    let url = `https://your.service.org?query=${query}`;

    axios({
        method:'get',
        url,
        auth: {
            username: 'the_username',
            password: 'the_password'
        }
    })
    .then(function (response) {
        res.send(JSON.stringify(response.data));
    })
    .catch(function (error) {
        console.log(error);
    });
});

var server = app.listen(port);

Убедитесь, что в вашем каталоге проекта вы делаете:

npm init
npm install express
npm install axios
node axios_example.js

Затем вы можете протестировать REST API Node.js, используя ваш браузер по адресу: http://localhost:5000/search?queryStr=xxxxxxxxx

Точно так же вы можете сделать сообщение, например:

axios({
  method: 'post',
  url: 'https://your.service.org/user/12345',
  data: {
    firstName: 'Fred',
    lastName: 'Flintstone'
  }
});

SuperAgent

Точно так же вы можете использовать SuperAgent.

superagent.get('https://your.service.org?query=xxxx')
.end((err, response) => {
    if (err) { return console.log(err); }
    res.send(JSON.stringify(response.body));
});

И если вы хотите сделать базовую аутентификацию:

superagent.get('https://your.service.org?query=xxxx')
.auth('the_username', 'the_password')
.end((err, response) => {
    if (err) { return console.log(err); }
    res.send(JSON.stringify(response.body));
});

Ref:

Юйцы
источник
5

Чтобы использовать новейшие функции Async / Await

https://www.npmjs.com/package/request-promise-native

npm install --save request
npm install --save request-promise-native

//код

async function getData (){
    try{
          var rp = require ('request-promise-native');
          var options = {
          uri:'https://reqres.in/api/users/2',
          json:true
        };

        var response = await rp(options);
        return response;
    }catch(error){
        throw error;
    }        
}

try{
    console.log(getData());
}catch(error){
    console.log(error);
}
CodeMirror
источник
4

Еще один пример - для этого нужно установить модуль запроса.

var request = require('request');
function get_trustyou(trust_you_id, callback) {
    var options = {
        uri : 'https://api.trustyou.com/hotels/'+trust_you_id+'/seal.json',
        method : 'GET'
    }; 
    var res = '';
    request(options, function (error, response, body) {
        if (!error && response.statusCode == 200) {
            res = body;
        }
        else {
            res = 'Not Found';
        }
        callback(res);
    });
}

get_trustyou("674fa44c-1fbd-4275-aa72-a20f262372cd", function(resp){
    console.log(resp);
});
Хардик Ранпария
источник
4
var http = require('http');
var url = process.argv[2];

http.get(url, function(response) {
  var finalData = "";

  response.on("data", function (data) {
    finalData += data.toString();
  });

  response.on("end", function() {
    console.log(finalData.length);
    console.log(finalData.toString());
  });

});
Себ
источник
3

Я не нашел ничего с помощью cURL, поэтому я написал обертку вокруг node-libcurl и ее можно найти по адресу https://www.npmjs.com/package/vps-rest-client. .

Сделать POST так:

var host = 'https://api.budgetvm.com/v2/dns/record';
var key = 'some___key';
var domain_id = 'some___id';

var rest = require('vps-rest-client');
var client = rest.createClient(key, {
  verbose: false
});

var post = {
  domain: domain_id,
  record: 'test.example.net',
  type: 'A',
  content: '111.111.111.111'
};

client.post(host, post).then(function(resp) {
  console.info(resp);

  if (resp.success === true) {
    // some action
  }
  client.close();
}).catch((err) => console.info(err));
Джонатас Уокер
источник
2

Если у вас Node.js 4.4+, взгляните на reqclient , он позволяет вам совершать звонки и регистрировать запросы в стиле cURL , чтобы вы могли легко проверять и воспроизводить звонки вне приложения.

Возвращает объекты Promise вместо передачи простых обратных вызовов, так что вы можете обработать результат более «модным» способом, цепочкой легко результаты и обрабатывать ошибки стандартным способом. Также удаляет множество стандартных конфигураций для каждого запроса: базовый URL, время ожидания, формат типа контента, заголовки по умолчанию, параметры и привязку запроса в URL, а также основные функции кэша.

Это пример того, как его инициализировать, сделать вызов и зарегистрировать операцию в стиле curl :

var RequestClient = require("reqclient").RequestClient;
var client = new RequestClient({
    baseUrl:"http://baseurl.com/api/", debugRequest:true, debugResponse:true});
client.post("client/orders", {"client": 1234, "ref_id": "A987"},{"x-token": "AFF01XX"});

Это войдет в консоль ...

[Requesting client/orders]-> -X POST http://baseurl.com/api/client/orders -d '{"client": 1234, "ref_id": "A987"}' -H '{"x-token": "AFF01XX"}' -H Content-Type:application/json

И когда ответ возвращается ...

[Response   client/orders]<- Status 200 - {"orderId": 1320934}

Это пример того, как обрабатывать ответ с объектом обещания:

client.get("reports/clients")
  .then(function(response) {
    // Do something with the result
  }).catch(console.error);  // In case of error ...

Конечно, он может быть установлен с: npm install reqclient.

Мариано Руис
источник
1

Вы можете использовать curlrequest, чтобы легко установить, какое время запроса вы хотите сделать ... вы даже можете установить заголовки в опциях, чтобы « подделать » вызов браузера.

luizpanariello
источник
1

Предупреждение: по состоянию на 11 февраля 2020 года запрос полностью устарел.

Если вы реализуете данные формы, для получения дополнительной информации ( https://tanaikech.github.io/2017/07/27/multipart-post-request-using-node.js ):

var fs = require('fs');
var request = require('request');
request.post({
  url: 'https://slack.com/api/files.upload',
  formData: {
    file: fs.createReadStream('sample.zip'),
    token: '### access token ###',
    filetype: 'zip',
    filename: 'samplefilename',
    channels: 'sample',
    title: 'sampletitle',
  },
}, function (error, response, body) {
  console.log(body);
});
Lwf804
источник
0

Я обнаружил, что суперагент действительно полезен, например, он очень прост

const superagent=require('superagent')
superagent
.get('google.com')
.set('Authorization','Authorization object')
.set('Accept','application/json')
Дэвид Иннокентий
источник