NodeJS请求承诺ERR_TLS_CERT_ALTNAME_INVALID

时间:2019-01-24 21:10:55

标签: node.js request-promise

尝试使用HTTPS向网站发送请求时,出现以下错误:ERR_TLS_CERT_ALTNAME_INVALID

我尝试将insecure: true添加到我的请求有效负载中,但这没有任何作用,我也尝试添加rejectUnauthorized: false,但这给了我400错误-错误的请求。

var rp = require('request-promise').defaults({jar: true});
var sess = rp.jar();

function SendRequest() {
  let link = "https://www.example.com";
  payload = {
    method: 'GET',
    jar: sess,
    json: true,
    url: link,
    headers: {
      'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
      'Accept-Encoding': 'gzip, deflate, br',
      'Accept-Language': 'en-GB,en-US;q=0.9,en;q=0.8',
      'Connection': 'keep-alive',
      'Host': link,
      'Upgrade-Insecure-Requests': '1', // removed this nothing changed
      'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Mobile Safari/537.36'
    },
    gzip: true
    // tried adding insecure: true (did nothing) & rejectUnauthorized: false (returned 400 error)
  }
  rp(payload)
    .then(function(json) {
      console.log(json)
    })
  }

我希望请求能够顺利通过。

1 个答案:

答案 0 :(得分:0)

发现400错误实际上是与标题'Host': link,有关,并且在删除此错误并将rejectUnauthorized: false添加回所有内容后即可使用。