promisfying https.get 后出现没有“消息”的错误

mik*_*ana 2 javascript node.js promise async-await ecmascript-2017

我正在使用 ES2017 的await关键字,并与 一起util.promisify()使用。https.get()await

使用以下代码测试连接到 HTTPS:

const util = require('util'),
    https = require('https'),
    httpsGet = util.promisify(https.get);

var start = async function(){
    try {
        var res = await httpsGet('https://github.com')
    } catch(err) {
        console.log('>>>>>>>CAUGHT AN ERROR>>>>>>', err.message)
    }
    console.log('FINISHED')
}

start()
Run Code Online (Sandbox Code Playgroud)

返回:

>>>>>>>CAUGHT AN ERROR>>>>>> undefined
Run Code Online (Sandbox Code Playgroud)

我怀疑我的代码已损坏,但我不确定如何损坏。我怎样才能得到真正的错误?

更新:根据要求,仅记录 err 而不是 err.message:

>>>>>>>CAUGHT AN ERROR - RAW ERR>>>>>> IncomingMessage {
  _readableState:
   ReadableState {
     objectMode: false,
     highWaterMark: 16384,
     buffer: BufferList { head: null, tail: null, length: 0 },
     length: 0,
     pipes: null,
     pipesCount: 0,
     flowing: null,
     ended: false,
     endEmitted: false,
     reading: false,
Run Code Online (Sandbox Code Playgroud)

Ika*_*uss 5

的回调https.get 没有err选项。它是一个流 - 错误通过.on(error). 所以它没有回调err并且不能与util.promisify()

err显示an 的唯一原因是它res是回调的最后一项promisify-预计将出现错误。所以err这里抛出的其实是一个resStream。

但是你可以从 https.get 做出承诺,而不需要 util.promisify:

function httpsGet(option) {
  return new Promise( (resolve, reject) => {                    
    let request = https.get( option, (response) => {
        if (response.statusCode < 200 || response.statusCode > 299) {
        reject( new Error('Failed to load page'+response.statusCode) );}

        let data = "";
        response.on( 'data', (chunk) => data += chunk );
        response.on( 'end', () => resolve(JSON.parse(data)) );
    } );
    request.on( 'error', (err) => reject(err) );
 })
}
Run Code Online (Sandbox Code Playgroud)