本文主要介绍.NET中使用FluentFTP连接FTP Server(服务器)时,使用FTPS(FTP over SSL)的验证验证服务器证书(ssl)方法及代码。

注意:FluentFTP不支持SFTP连接,因为它是通过SSH的FTP,一种完全不同的协议。使用SSH.NET

1、第一种方法

如果SSL证书没有错误,请进行连接

client.ValidateCertificate += new FtpSslValidation(delegate (FtpClient c, FtpSslValidationEventArgs e) {
if (e.PolicyErrors != System.Net.Security.SslPolicyErrors.None){
e.Accept = false;
}else{
e.Accept = true;
}
});

2、第二种方法

如果证书与白名单证书匹配,则进行连接。

首先,您必须发现有效证书的字符串。使用此代码将有效证书字符串保存到文件:

client.ValidateCertificate += new FtpSslValidation(delegate (FtpClient c, FtpSslValidationEventArgs e) {
    File.WriteAllText(@"C:\cert.txt", e.Certificate.GetRawCertDataString());
});

然后最后使用此代码检查收到的证书是否与您信任的证书匹配:

string ValidCert = "<insert contents of cert.txt>";
client.ValidateCertificate += new FtpSslValidation(delegate (FtpClient c, FtpSslValidationEventArgs e) {
if (e.PolicyErrors == SslPolicyErrors.None || e.Certificate.GetRawCertDataString() == ValidCert) {
e.Accept = true;
}else{
throw new Exception("Invalid certificate : " + e.PolicyErrors);
}
});

官方文档https://github.com/robinrodricks/FluentFTP#faq_ftps

相关文档:.NET 使用FluentFTP实现FTP上传下载文件方法及示例代码

推荐文档