尝试通过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连接).