c#-使用WinSCP .NET程序集连接到SFTP服务器时,“主机密钥与配置的密钥不匹配”

尝试通过C#实现SFTP连接时遇到了一些麻烦.目前,我可以使用WinSCP与主机,端口,登录名,密码和密钥文件(ppk文件)进行连接.

我的实现就像使用WinSCP .NET一样:

SessionOptions sessionOptions = new SessionOptions
{
    Protocol              = Protocol.Sftp,
    HostName              = "",
    UserName              = "",
    SshHostKeyFingerprint = "",
    SshPrivateKeyPath     = "",
    PrivateKeyPassphrase  = ""
};

using (Session session = new Session ())
{
    session.Open (sessionOptions);
}

在session.Open中,我总是会收到一个异常.当我不填写SshHostKeyFingerprint参数时,会收到以下异常:

SessionOptions.Protocol is Protocol.Sftp or Protocol.Scp, but SessionOptions.SshHostKeyFingerprint is not set.

然后我用PuTTYgen打开了我的ppk文件.之后,我复制了“密钥指纹”并将其放入代码中.现在,我收到以下异常:

Host key does not match configured key

这是否意味着我必须在服务器中拥有此密钥?如果是这样,我应该把钥匙放在哪里?在这种情况下,为什么不通过指纹就可以通过WinSCP连接?

谢谢!

解决方法:

必须将SshHostKeyFingerprint设置为服务器的公共密钥(也称为主机密钥)的指纹,而不是身份验证密钥对(您本地的ppk文件)的公共密钥中的指纹.
请参阅WinSCP站点上的Understanding SSH key pairs文章.

WinSCP GUI之所以可能有效,是因为它具有从您首次在该特定服务器上使用WinSCP以来的SSH主机密钥的缓存副本.

看起来WinSCP站点上有关于how you might go about getting SshHostKeyFingerprint within .NET的信息.甚至还有一个标志可用于跳过主机密钥验证(不安全:您可能正在连接到其他服务器,或者有人可能会MITM连接).

上一篇:如何使用phpseclib复制或移动远程文件?


下一篇:常用DOS命令