У меня есть очень простая программа nodejs, которую я использую для демонстрации взаимодействия с Alchemer API. Каждый раз, когда я запускаю следующий код, возникает задержка в несколько секунд, а затем выдается ошибка с идентификатором ECONNRESET. Однако, когда я копирую тот же URL-адрес в браузер или почтальон, он работает нормально.

Nodejs сниппет

require('dotenv').config();
const https = require('https');
const querystring = require('querystring');

const params = {
    api_token: process.env.API_TOKEN,
    api_token_secret: process.env.API_TOKEN_SECRET
};

const reqArgs = querystring.stringify(params);

console.log('Query string: ', reqArgs);

const reqOptions  = {
    host: 'api.alchemer.com',
    path: '/v5/survey?' + reqArgs
}

console.log('Query: ', reqOptions.host + reqOptions.path);
console.log('Getting data...');
    
const req = https.request(reqOptions, resp => {
    let data = '';

    resp.on('data', chunk => {
        data += chunk;
    });

    resp.on('error', err => {
        console.error('Error on response:');
        console.error(err);
    });

    resp.on('end', () => {
        console.log('Request complete:');
        console.log(data);
    });
});

req.on('error', (err) => {
    console.error('Error on request:');
    console.error(err);
})

Наблюдаемая ошибка

Error: socket hang up
    at connResetException (internal/errors.js:607:14)
    at TLSSocket.socketOnEnd (_http_client.js:493:23)
    at TLSSocket.emit (events.js:327:22)
    at endReadableNT (internal/streams/readable.js:1327:12)
    at processTicksAndRejections (internal/process/task_queues.js:80:21) {
  code: 'ECONNRESET'
}
1
Reilly 22 Фев 2021 в 04:26

1 ответ

Лучший ответ

Потому что вы не звоните req.end()! Таким образом, он никогда не отправляет запрос на серверную часть.

0
lx1412 22 Фев 2021 в 03:06