Node.jsの読み取りストリームで作業するのはかなり奇妙な問題があります。私はSSH2を使用して私とSFTPサーバー間のSFTP接続を作成しています。次に、sftpストリームから読み込みストリームを作成しようとします。読み込まれたストリームの放出された 'data'イベントから、データを配列に追加します。読み込みストリームの 'close'イベントが発生すると、私はBuffer.concatを呼び出して、1つのバッファに取り込んだすべてのデータの連結を作成します。これは、ここでスタックオーバーフローで尋ねられる他の質問に記載されているのと同じテクニックです。たとえば、hereとなります。しかし、私は取得したデータを使用することができません。それはバッファのサイズが私は(取得されたデータの長さを数える)から取得しようとしているファイルのサイズが32バイト少ないようです。これは私のSFTP接続と関係がありますか?または、私の読み込みストリームをどのように作成するのですか?Node.jsとSSH2を使用してSFTPサーバーからファイルを読み取る
重要な場合、ファイルのタイプはzipです。バッファに読み込んだ後にファイルを(node.jsと手動で)解凍しようとすると、うまくいきません。私は、ファイル上のreaddirを使用すると、ファイルのサイズが正しい
- :
調査した後、私はあることを見出しました。
- 私の開発用FTPサーバー(JSFTP)を使用すると、上記の同じ手法を使用してうまく動作します。
アドバイスはありがとうございます。ここで
は私のコードです:
var Client = require('ssh2').Client;
var m_ssh2Credentials = {
host: config.ftpHostName,
port: config.ftpPort,
username: config.ftpUser,
password: config.ftpPassword,
readyTimeout: 20000,
algorithms: { cipher: ["3des-cbc", "aes256-cbc", "aes192-cbc","aes128-cbc"]}
};
...
var conn = new Client();
var dataLength = 0;
conn.on('ready', function() {
conn.sftp(function(err, sftp) {
if (err) {
writeToErrorLog("downloadFile(): Failed to open SFTP connection.");
} else {
writeToLog("downloadFile(): Opened SFTP connection.");
}
var streamErr = "";
var dataLength = 0;
var stream = sftp.createReadStream(config.ftpPath + "/" + m_fileName)
stream.on('data', function(d){
data.push(d);
dataLength += d.length;
});
.on('error', function(e){
streamErr = e;
})
.on('close', function(){
if(streamErr) {
writeToErrorLog("downloadFile(): Error retrieving the file: " + streamErr);
} else {
writeToLog("downloadFile(): No error using read stream.");
m_fileBuffer = Buffer.concat(data, dataLength);
writeToLog("Data length: " + dataLength);
writeToLog("downloadFile(): File saved to buffer.");
}
conn.end();
});
})
})
.on('error', function(err) {
writeToErrorLog("downloadFile(): Error connecting: " + err);
}).connect(m_ssh2Credentials);
sftp.fastGet/fastDownloadの問題は、一時停止機能を提供していないが、ストリームができることです。 –