【发布时间】:2014-11-04 18:30:07
【问题描述】:
这是我的方法:
var q = require('q');
var request = require("request");
exports.route = function (req, res) {
var userId = req.query.userId;
if (!userId) {
res.send(JSON.stringify({
errorCode: 400,
error: "userId is missing, please form your query like <url>/avatar?userId=00.42.1"
}), 400);
return;
}
getAvatar(userId).then(function (success) {
console.log('success');
res.json(success);
}, function (error) {
console.log('error');
res.json({error: error});
}
);
};
function getAvatar(userId) {
var isErrorInResponse = function (error, response) {
return typeof error !== 'undefined' || error == null || response.statusCode > 202;
};
var deferred = q.defer();
var url = "http://localhost/avatar" + userId;
console.log(url);
request(url, function (error, response, body) {
if (isErrorInResponse(error, response)) {
deferred.reject(new Error({error: error, response: response, body: body}));
} else {
deferred.resolve(body);
}
});
return deferred.promise;
};
GET localhost:8090/avatar?userId=42 produces 以下日志:
http://localhost/avatar/42
error
并将此响应发送给客户端:
{
"error": {}
}
这是我的版本,我无法更新:
"dependencies": {
"consolidate": "0.9.0",
"express": "3.1.0",
"multipart-parser": "0.0.2",
"mustache": "0.7.2",
"poplib": "0.1.5",
"q": "0.9.3",
"q-io": "1.6.x",
"request": "2.27.0",
"string": "^2.2.0",
"xml2js": "0.2.8"
}
问题是,为什么我在deferred.reject(... 发送的承诺没有收到完整的错误,我需要进行哪些更改才能使其正常工作?
【问题讨论】:
标签: javascript node.js promise q