"Invalid private key file" 使用字符串中的密钥通过 SSH.NET 向 SFTP 进行身份验证时

"Invalid private key file" when authenticating to SFTP with SSH.NET using a key in a string

我有一个程序,我想连接到 SFTP 主机和 push/pull 文件。主机需要私钥才能连接。使用这些帖子作为指导:

我做了以下事情:

以下是我的代码:

SftpClient sftp = null;

if (bHost.Equals("sftp.sftpHost.com"))
{
    var keyStr = @"-----BEGIN RSA PRIVATE KEY-----
    Proc-Type: 4,ENCRYPTED
    DEK-Info: DES-EDE3-CBC,15BEAB6C0B73F39A

    ***private key***
    -----END RSA PRIVATE KEY-----";

    using (var keystrm = new MemoryStream(Encoding.UTF8.GetBytes(keyStr)))
    {
        var privateKey = new PrivateKeyFile(keystrm, "passPhrase");
        sftp = new SftpClient(bHost, bUser, new[] { privateKey });
    }
} else
{
    sftp = new SftpClient(bHost, bPort, bUser, bPw);
}

return sftp;
                   

是我的代码有问题,还是我生成 OpenSSH 格式密钥的方式不正确?

我注意到在其他示例键字符串中,它们不包括以下内容:

Proc-Type: 4,ENCRYPTED
DEK-Info: DES-EDE3-CBC,15BEAB6C0B73F39A

它可能是多行字符串中的前导空格。他们不可能在那里。

删除它们。

    var keyStr = @"-----BEGIN RSA PRIVATE KEY-----
Proc-Type: 4,ENCRYPTED
DEK-Info: DES-EDE3-CBC,15BEAB6C0B73F39A

***private key***
-----END RSA PRIVATE KEY-----";