[英]Does FtpWebRequest TLS connection need a client certificate?
我正在尝试使用FtpWebRequest
创建一个FTPRequest
以将报告文件发送到我的服务器。 但我不了解 SSL/TLS 连接。
我使用的服务器接受 TLS 连接。 那么,仅仅设置EnableSsl = true
足够了吗? 或者我需要客户证书?
如果我只是将EnableSsl
设置为true
则连接被接受并发送文件。
ftpRequest = (FtpWebRequest)WebRequest.Create(url);
ftpRequest.UseBinary = true;
ftpRequest.UsePassive = true;
ftpRequest.KeepAlive = false;
ftpRequest.Proxy = null;
ftpRequest.Credentials = new NetworkCredential(username, password);
如果我想要 TLS/SSL:
ftpRequest.EnableSsl = true;
X509Certificate cert = X509Certificate.CreateFromCertFile(filePath);
X509CertificateCollection certCollection = new X509CertificateCollection { cert };
ftpRequest.ClientCertificates = certCollection;
如果我设置证书并尝试连接,服务器不会响应并且不会给我任何异常。
我真的需要证书吗? 我不知道证书是否在连接上有差异。 证书的目的是什么?
谢谢
客户端证书是一种身份验证方式(作为密码的替代或补充)。 仅当您的 FTPS 服务器需要使用客户端证书进行身份验证时才需要它。 它类似于使用 SSH 中的私钥进行身份验证。
根据我的经验,很少使用客户端证书。 如果你需要它,你就会知道。 而且您通常没有密码(尽管有可能,甚至更罕见的是,您需要密码和客户端证书来进行身份验证)。
通常,要使用 FTPS(基于 TLS/SSL 的 FTP),您只需要:
ftpRequest.EnableSsl = true;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.