Rob*_*Rob 6 sftp file-upload pgp node.js
我一直在执行一项任务,使用他发送给我的 asc 文件中的公共 PGP 密钥将文件上传到合作伙伴的 ftp 站点。该文件看起来像这样(大部分密钥被删掉了):
-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: PGP Desktop 10.2.1 (Build 4461)
mQEN... ... ...=K8zL
-----END PGP PUBLIC KEY BLOCK-----
Run Code Online (Sandbox Code Playgroud)
我已经尝试了几个 SFTP 节点包,但似乎没有任何工作。大多数示例使用 .rsa 文件,但我提供的只是这个 .asc 文件。从我的研究中,我可以看到有些人使用了带有此扩展名的文件,但没有人完全解释是如何使用的。
我能够使用 Filezilla 连接到 FTP 站点并收到一条消息,指出主机密钥算法是 ssh-dss 1024 以及 SHA256 和 MD5 指纹。我不确定这是否有帮助。
有没有人有使用 .asc 文件以及如何使用它们建立 SFTP 连接的经验?
编辑:我尝试使用 npm 包sftp-upload和以下代码:
var SftpUpload = require('sftp-upload'), fs = require('fs');
var options = {
host:'ftp.partnersite.com',
username:'TempUserName',
path: './CSV',
remoteDir: '/',
privateKey: fs.readFileSync('pgpkeyfile.asc'),
},
sftp = new SftpUpload(options);
sftp.on('error', function(err) {
throw err;
})
.on('uploading', function(progress) {
console.log('Uploading', progress.file);
console.log(progress.percent+'% completed');
})
.on('completed', function() {
console.log('Upload Completed');
})
.upload();
Run Code Online (Sandbox Code Playgroud)
在运行代码时,我收到以下错误:
Error: Unable to parse given privateKey value
我认为这意味着此密钥文件的 sftp_upload 格式不正确。
事实证明,SFTP 连接本身不需要 ASC 文件,而仅用于在发送文件之前对其进行加密。我能够使用节点包ssh2-sftp-client连接到 FTP 站点并使用以下代码上传文件:
sftp.connect({
host: 'ftp.site.com',
port: '22',
username: 'myusername',
password: 'mypassword',
algorithms: {
serverHostKey: [ 'ssh-dss' ],
kex: ['diffie-hellman-group14-sha1'],
cipher: ['aes128-cbc']
}
}).then(() => {
sftp.put('./CSV/myspreadsheet.csv', '/myspreadsheet.csv', false);
}).then((data) => {
console.log(data, 'the data info');
}).catch((err) => {
console.log(err, 'catch error');
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6011 次 |
| 最近记录: |