在NodeJS中使用请求或针进行套接字挂断错误

时间:2019-03-18 22:59:58

标签: javascript node.js request needle.js

尝试连接到外部网站时,出现套接字挂断错误,下面是失败站点的示例。该代码可用于其他站点,如果我用Python重写代码,则可以成功访问测试站点。我无法对外部站点进行更改,因此希望增强NodeJS脚本以处理连接。任何帮助表示赞赏

let request = require("request-promise");
let needle = require("needle");

//Check if can connect to site

    let arrTestCases = ["https://compassandstars.com"];

    for (x in arrTestCases) {
         chkcon(arrTestCases[x])
    }

    async function chkcon(req) {
        let resultJSON = {};
        let data;
        try {
            console.log ("Validating blog " + req);
    //Attempt using RequestPromise, fails with same error
    //      let getURL = await request({
    //          url: req,
    //          headers: {
    //              'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36' 
    //          }
    ////            headers: {
    ////                'User-Agent': 'ouruseragent',
    ////                'Connection': 'keep-alive'
    ////            }
    //      })

            needle('get', req)

             .then(function(response) {
                resultJSON = {ValidURL: true};
                console.log("URL Validated successfully", response.body);
             })
             .catch(function(err) {
                console.log(err);
             })

        } catch (e) {
            console.log("Bad Blog URL ",e.message);
        } finally {
            console.log("Result: " + JSON.stringify(resultJSON), req);

        }

错误响应:

Result: {} https://compassandstars.com
{ Error: socket hang up
    at TLSSocket.onConnectEnd (_tls_wrap.js:1073:19)
    at Object.onceWrapper (events.js:219:13)
    at TLSSocket.emit (events.js:132:15)
    at endReadableNT (_stream_readable.js:1101:12)
    at process._tickCallback (internal/process/next_tick.js:152:19)
  code: 'ECONNRESET',
  path: null,
  host: 'compassandstars.com',
  port: 443,
  localAddress: undefined }

我可以在AWS Lambda上使用NodeJS 8.10重新创建问题,并在我的计算机上使用NodeJS 9.6.1在本地重新创建问题。

我的研究表明,找到建立SSL连接的兼容密码可能是错误的,但是我无法找到如何强制Request更改请求以处理此问题的方法。

0 个答案:

没有答案