我一直在执行一项任务,使用他发送给我的asc文件中的公共PGP密钥将文件上传到合作伙伴的ftp站点。该文件如下所示(已删除大部分密钥):
-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: PGP Desktop 10.2.1 (Build 4461)
mQEN... ... ...=K8zL
-----END PGP PUBLIC KEY BLOCK-----
我已经尝试了几个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();
在运行代码时,出现以下错误: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');
});
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句