1

以下のコードがありますが、解決が呼び出されるとスローされます:

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');
});

理由はありますか?

4

2 に答える 2

0

私はついにそれを機能させ、結果をブログに書きました - http://blog.jonathanchannon.com/2014/03/22/using-node-and-ftp-with-promises/

于 2014-03-22T10:06:10.860 に答える