Node.js: Jak wysłać nagłówki z danymi formularza za pomocą modułu request?

111

Mam kod podobny do następującego:

var req = require('request');

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

Jak mogę ustawić dla tego nagłówki? Potrzebuję klienta użytkownika, typu treści i prawdopodobnie czegoś innego w nagłówkach:

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' 
};

Próbowałem na wiele sposobów, ale mogę wysłać nagłówek lub dane formularza, nie udało mi się wysłać obu.

Mykoła G.
źródło

Odpowiedzi:

194

W końcu udało mi się to zrobić. Odpowiedz we fragmencie kodu poniżej:

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!
  });
Mykoła G.
źródło
zgłoś nowy błąd („undefined nie jest prawidłowym obiektem uri lub opcji.”) ^ Błąd: undefined nie jest prawidłowym obiektem uri lub opcji. na żądanie (C: \ Users \ pjt \ node_modules \ request \ index.js: 44: 11) at Request._callback (C: \ Users \ pjt \ tours \ payment.js: 170: 11) at Request.self.callback (C: \ Users \ pjt \ node_modules \ request \ request.js: 186: 22) at emitTwo (events.js: 106: 13) at Request.emit (events.js: 194: 7) at Request. <anonymous> (C: \ Users \ pjt \ node_modules \ request \ request.js: 1163: 10) w emitOne (events.js: 96: 13) at Request.emit (events.js: 191: 7)
Tamilselvan K
To nie zadziałało dla mnie, gdzie odpowiedź poniżej, która ustawia tylko obiekt do formy, zadziałała.
ozzieisaacs
49

To powinno działać.

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
źródło
Dzięki, ale wydaje się, że w tym przypadku dane z formularza nie są wysyłane we właściwy sposób. Mam prawie taki sam kod w .Net iw przypadku przesłania danych z formularza nie powinienem mieć formularza logowania w treści i powinienem mieć token. Wkrótce wrzucę to tutaj, prawdopodobnie pomoże
Mykola G.
17

Myślę, że to tylko dlatego, że zapomniałeś METODY HTTP . Domyślną metodą żądania HTTP jest GET.

Należy dodać, method: 'POST'a kod będzie działał, jeśli backend otrzyma metodę postu.

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
źródło
1
Jest to lepsza odpowiedź, ponieważ nie opiera się na stringify, co ułatwia czytanie.
Keith John Hutchison
6

Znalazłem rozwiązanie tego problemu i powinienem pracować. Jestem tego pewien, ponieważ mam ten sam problem

oto moje rozwiązanie ----->

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
źródło
1
zredagowałem odpowiedź, zobacz, a następnie powiedz, czy jest jakiś problem. dziękuję
Chetna Joshi
Twoja odpowiedź jest w porządku i pomógł mi też, ale starają się realizować krótkiego kodu, które wyjaśniają jedynie rozwiązanie
Amy
2

Pamiętaj tylko o ustawieniu metody na POST w opcjach. Oto mój kod

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
źródło