Node.js: como enviar cabeçalhos com dados de formulário usando o módulo de solicitação?

111

Eu tenho um código como o seguinte:

var req = require('request');

req.post('someUrl',
   { form: { username: 'user', password: '', opaque: 'someValue', logintype: '1'}, },
   function (e, r, body) {
      console.log(body);
});

Como posso definir cabeçalhos para isso? Preciso do user agent, content-type e provavelmente algo mais nos cabeçalhos:

headers = { 
   'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/27.0.1453.110 Safari/537.36',
   'Content-Type' : 'application/x-www-form-urlencoded' 
};

Tentei de várias maneiras, mas posso enviar o cabeçalho ou os dados do formulário, mas não consegui enviar os dois.

Mykola G.
fonte

Respostas:

194

Eu finalmente consegui fazer isso. Resposta no snippet de código abaixo:

var querystring = require('querystring');
var request = require('request');

var form = {
    username: 'usr',
    password: 'pwd',
    opaque: 'opaque',
    logintype: '1'
};

var formData = querystring.stringify(form);
var contentLength = formData.length;

request({
    headers: {
      'Content-Length': contentLength,
      'Content-Type': 'application/x-www-form-urlencoded'
    },
    uri: 'http://myUrl',
    body: formData,
    method: 'POST'
  }, function (err, res, body) {
    //it works!
  });
Mykola G.
fonte
throw new Error ('undefined não é um uri ou objeto de opções válido.') ^ Erro: undefined não é um uri ou objeto de opções válido. a pedido (C: \ Users \ pjt \ node_modules \ request \ index.js: 44: 11) em Request._callback (C: \ Users \ pjt \ routes \ payment.js: 170: 11) em Request.self.callback (C: \ Users \ pjt \ node_modules \ request \ request.js: 186: 22) em emitTwo (events.js: 106: 13) em Request.emit (events.js: 194: 7) em Request. <anônimo> (C: \ Users \ pjt \ node_modules \ request \ request.js: 1163: 10) em emitOne (events.js: 96: 13) em Request.emit (events.js: 191: 7)
Tamilselvan K
Isso não funcionou para mim onde a resposta abaixo, que apenas define a forma de um objeto, funcionou.
ozzieisaacs de
49

Isso deve funcionar.

var url = 'http://<your_url_here>';
var headers = { 
    'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:24.0) Gecko/20100101 Firefox/24.0',
    'Content-Type' : 'application/x-www-form-urlencoded' 
};
var form = { username: 'user', password: '', opaque: 'someValue', logintype: '1'};

request.post({ url: url, form: form, headers: headers }, function (e, r, body) {
    // your callback body
});
user606521
fonte
Obrigado, mas parece que neste caso os dados do formulário não são enviados de forma adequada. Tenho quase o mesmo código em .Net e caso sejam enviados dados do formulário não devo ter formulário de login no corpo e devo ter token. Vou postar aqui em breve, provavelmente vai ajudar
Mykola G.
17

Acho que é só porque você esqueceu o MÉTODO HTTP . O método HTTP padrão de solicitação é GET.

Você deve adicionar method: 'POST'e seu código funcionará se seu back-end receber o método post.

var req = require('request');

req.post({
   url: 'someUrl',
   form: { username: 'user', password: '', opaque: 'someValue', logintype: '1'},
   headers: { 
      'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/27.0.1453.110 Safari/537.36',
      'Content-Type' : 'application/x-www-form-urlencoded' 
   },
   method: 'POST'
  },

  function (e, r, body) {
      console.log(body);
  });
nodejh
fonte
1
Esta é uma resposta melhor, pois não depende do stringify, o que a torna mais fácil de ler.
Keith John Hutchison
6

Eu encontrei a solução para este problema e devo trabalhar tenho certeza disso porque também enfrento o mesmo problema

aqui está minha solução ----->

var request = require('request');

//set url
var url = 'http://localhost:8088/example';

//set header
var headers = {
    'Authorization': 'Your authorization'
};

//set form data
var form = {first_name: first_name, last_name: last_name};

//set request parameter
request.post({headers: headers, url: url, form: form, method: 'POST'}, function (e, r, body) {

    var bodyValues = JSON.parse(body);
    res.send(bodyValues);
});
Chetna Joshi
fonte
1
editei minha resposta, por favor, veja e diga se houver algum problema nisso. obrigado
Chetna Joshi
sua resposta está certa e me ajudou também, mas tente implementar um código curto que explique apenas a solução
Amy
2

Apenas lembre-se de definir o método para POST nas opções. Aqui está meu código

var options = {
    url: 'http://www.example.com',
    method: 'POST', // Don't forget this line
    headers: {
        'Content-Type': 'application/x-www-form-urlencoded',
        'X-MicrosoftAjax': 'Delta=true', // blah, blah, blah...
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36',
    },
    form: {
        'key-1':'value-1',
        'key-2':'value-2',
        ...
    }
};

//console.log('options:', options);

// Create request to get data
request(options, (err, response, body) => {
    if (err) {
        //console.log(err);
    } else {
        console.log('body:', body);
    }
});
VnDevil
fonte