我有以下代码,但是当调用 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');
});
任何想法为什么?