【发布时间】:2014-03-23 06:20:47
【问题描述】:
我有以下代码,但是当调用 resolve 时它会抛出:
Possibly unhandled Error: undefined
at Promise$_rejecter (c:\projects\Test\promiseftp\node_modules\bluebird\js\main\promise.js:602:58)
at WriteStream.<anonymous> (c:\projects\Test\promiseftp\index.js:45:33)
at WriteStream.EventEmitter.emit (events.js:117:20)
at fs.js:1598:14
at Object.oncomplete (fs.js:107:15)
代码如下:
var Client = require('ftp');
var path = require('path');
var fs = require('fs');
var Promise = require('bluebird');
var c = new Client();
var connectionProperties = {
host: "myhost",
user: "myuser",
password: "mypwd"
};
c.connect(connectionProperties);
var downloadFiles = new Promise.method(function () {
return new Promise(function (reject, resolve) {
c.on('ready', function () {
c.list(function (err, list) {
if (err) reject(err);
list.forEach(function (element, index, array) {
//Ignore directories
if (element.type === 'd') {
console.log('ignoring directory ' + element.name);
return;
}
//Ignore non zips
if (path.extname(element.name) !== '.zip') {
console.log('ignoring file ' + element.name);
return;
}
c.get(element.name, function (err, stream) {
if (err) reject(err);
console.log(element.name);
stream.once('close', function () {
//c.end();
//resolve();
});
var pipeaction = stream.pipe(fs.createWriteStream(element.name));
pipeaction.on('close', function () {
console.log('close');
//THROWS HERE!
resolve();
});
});
});
});
});
});
});
downloadFiles().then(function () {
console.log('woot');
});
有什么想法吗?
【问题讨论】:
-
附带说明 - 当您使用
Promise.method时,您可以跳过整个 'return new Promise' 位,您可以改为 - 就像在 .then 调用中一样 - 返回解决并抛出拒绝。另外,如果我是你,我也会承诺 ftp 客户端。另外,close是否被记录?它是否到达close事件? -
Close 被记录两次。即使在做出 ftp 承诺后,我也会遇到同样的错误
-
你不能两次解决一个promise,看起来这是
forEach的问题。但是,您确定它会引发resolve()吗?该错误看起来更像是调用了reject()。 -
@Bergi 他已经定义了
new Promise(function(reject, resolve){})- 参数应该是resolve, reject。参数顺序错误时,调用resolve()相当于调用真实的reject(undefined)
标签: javascript node.js promise bluebird