node.js中返回的unirest响应未定义

时间:2016-06-24 07:37:24

标签: javascript node.js response unirest

我正在研究facebook bot,但我绝不是node.js开发人员,这是我第一次使用它,因为我想离开我的舒适区一点点。

这是我的请求函数

function requestExc() {
    var resDictionary = {} 
    unirest.get("http://openapi.ro/api/exchange/" + queryDict["code"] + ".json")
    .query({"date" : queryDict["date"]})
    .end(function(res) {
        if (res.error) {
            console.log('GET error', res.error)
        } else {
            console.log('GET response', res.body)
            resDictionary["rate"] = res.body["rate"]
            resDictionary["date"] = res.body["date"]
        }
    })

    console.log("resDictionary IS " + resDictionary)
    ///prints resDictionary IS [object Object]
    return resDictionary
}

所以我试图得到它的结果

var response = requestExc()
if (response !== null) {
    respondToSender(response, sender)
}

然后采取相应行动

function respondToSender(res, sender) {
    console.log("RES IS " + res)
    //prints RES IS [object Object]
  if (res["rate"] === null) {
        //do stuff
  }
}

但是当变量到达respondToSender时,它总是未定义的。

 TypeError: Cannot read property 'rate' of undefined

我也尝试过使用Json.parse(),但它也是一样的。

3 个答案:

答案 0 :(得分:4)

好的,问题是unirest(像许多node.js模块一样)异步工作意味着您的代码很可能按此顺序执行:

var response = requestExc() // request is sent first, ok
if (response !== null) {    // this is done second
    respondToSender(response, sender)
}
                            // the response arrived third, when it is not needed

所以要处理这些东西,你必须使用回调/ end方法。请参阅示例here

unirest.post('http://mockbin.com/request')
.query('name=nijiko')
.query({
  pet: 'spot'
})
.end(function (response) {
  console.log(response); // this is where you should use respondToSender
});

console.log(response);仅在回复时启动,这就是您想要的。

答案 1 :(得分:3)

reddit的某个人教会了我如何添加回调,现在它可以按我的意愿运行。完整的代码是:

// GET a resource
function requestExc(callback) {
    unirest.get("http://openapi.ro/api/exchange/" + queryDict["code"] + ".json")
    .query({"date" : queryDict["date"]})
    .end(function(res) {
        if (res.error) {
            console.log('GET error', res.error)
            callback(res.error, null)
        } else {
            console.log('GET response', res.body)
            callback(null, res.body)
        }
    })
}

我称之为

var response = requestExc(function(error, res) {
            console.log("date array is " + dateArray)
            if (error === null) {
                respondToSender(res["rate"], res["date"], sender, queryDict)
            } else {
                sendTextMessage(sender, "Imi pare rau, dar am intimpinat o problema in comunicarea cu BNR")
            }
        })

答案 2 :(得分:0)

我将它包装在 Promise 中以使其正常工作,想知道这是否合适以及是否有帮助?

return new Promise((resolve, reject) => {
   unirest('GET', 'https://url')
       .headers({
           'Accept': 'application/json'
       })
       .send("")
       .then(function (response) {
           if(!response.error) {
               resolve(response)
           } else {
               reject(response)
           }
       })
});