在满足https.get后没有'消息'时出错

时间:2017-07-07 10:41:04

标签: javascript node.js promise async-await es2017

我使用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()

返回:

>>>>>>>CAUGHT AN ERROR>>>>>> undefined

我怀疑我的代码坏了,但我不确定如何。 如何才能收到真正的错误?

更新:根据要求,只记录错误而不是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,

1 个答案:

答案 0 :(得分:3)

https.get does not have an err option的回调。这是一个流-通过.on(error)处理错误。因此它没有err回调,也不能与util.promisify()

一起使用

显示err的唯一原因是res是回调的最后一项-promisify期望会出现错误。因此,这里抛出的err实际上是res流。

但是您可以从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) );
 })
}