问题描述
我正在使用 node -v v14.17.0
和 "ssh2-sftp-client": "^7.0.0"
以及方法 fastPut
https://github.com/theophilusx/ssh2-sftp-client#sec-5-2-9
检查远程文件没问题,所以连接正常。
我的环境是 wsl2 Ubuntu-20.04
我面临的问题是错误
RuntimeError: abort(Error: fastPut: No response from server Local: /home/draganddrop/testi.txt Remote: Downloads/testi.txt). Build with -s ASSERTIONS=1 for more info.
at process.J (/home/draganddrop/node_modules/ssh2/lib/protocol/crypto/poly1305.js:20:53)
at process.emit (events.js:376:20)
at processpromiseRejections (internal/process/promises.js:245:33)
at processticksAndRejections (internal/process/task_queues.js:96:32)
我也尝试过使用控制台中的 sftp> put /home/draganddrop/testi.txt Downloads/testi.txt
,效果很好。
我正在使用的代码:
let Client = require('ssh2-sftp-client');
let sftp = new Client();
let remotePath = 'Downloads/testi.txt';
let localPath = '/home/draganddrop/testi.txt'
const config = {
host: 'XX.XX.XXX.XXX',port: '22',username: 'XXXXX',password: 'XXXXXX'
};
sftp.connect(config)
.then(() => {
sftp.fastPut(localPath,remotePath);
//return sftp.exists(remotePath);
})
//.then(data => {
// console.log(data); // will be false or d,-,l (dir,file or link)
//})
.then(() => {
sftp.end();
})
.catch(err => {
console.error(err.message);
});
我不知道是什么导致了这个错误,我尝试了不同的路径,得到了错误的路径错误或这个。可能是什么原因?
解决方法
问题的原因是在执行完fastPut
之前连接正在关闭。
您正在运行连接,然后在第一个 .then
中,方法 fastPut
异步运行,它不会等待完成执行并返回 undefined 到链的下一个方法 .then
.
要解决此问题,您只需返回从 fastPut
sftp.connect(config)
.then(() => sftp.fastPut(localPath,remotePath))
.then((data) => {/* do something*/}
.finally(() => sftp.end())