使用.NET SslStream的FTPS服务器

时间:2013-04-02 08:24:34

标签: c# .net ssl ftps

我正在使用C#开发一个FTP服务器,我刚刚使用SslStream类完成了FTPS显式模式功能,一切顺利。

我在使用fileZilla>时遇到问题3.0.11作为客户端。我google arround,似乎sslstream实现没有正确关闭连接。 (不发送close_notify警报)。使用WinScp,SmartFTP和lftp everithing工作正常。

任何想法或任何其他SSL库?

或者某种方法可以对close_notify警报进行硬编码并发送它?

具体的代码示例会很棒!

创建sslStream:

_sslStream = new SslStream(socket.GetStream());      
var _cert = new X509Certificate2(certPath,pass);    
_sslStream.AuthenticateAsServer(_cert);

关闭连接:

_sslStream.Close();
socket.Close();
_sslStream = null;
socket = null;

FileZilla 3.6.0.2错误日志:

Response:   150 Opening data connection for LIST
Trace:  CFtpControlSocket::TransferParseResponse()
Trace:    code = 1
Trace:    state = 4
Trace:  CFtpControlSocket::SendNextCommand()
Trace:  CFtpControlSocket::TransferSend()
Trace:    state = 5
Trace:  CTlsSocket::OnRead()
Trace:  CTlsSocket::ContinueHandshake()
Trace:  TLS Handshake successful
Trace:  TLS Session resumed
Trace:  Cipher: AES-128-CBC, MAC: SHA1
Trace:  CTransferSocket::OnConnect
Trace:  CTransferSocket::OnReceive(), m_transferMode=0
Trace:  CTlsSocket::Failure(-110, 0)
Error:  GnuTLS error -110 in gnutls_record_recv: The TLS connection was non-properly terminated.
Error:  Could not read from transfer socket: ECONNABORTED - Connection aborted
Trace:  CTransferSocket::TransferEnd(3)
Trace:  CFtpControlSocket::TransferEnd()
Trace:  CTlsSocket::OnRead()
Trace:  CFtpControlSocket::OnReceive()
Response:   226 LIST successful.

4 个答案:

答案 0 :(得分:5)

我认为,你有充分的理由重新发明轮子。已经存在在C#/ .NET中实现FTPS服务器的库,如SecureBlackbox(但是,它是商业的)。

答案 1 :(得分:3)

请查看我发布的here解决方法。如果一起我们可以更好地解决这个问题,那就太棒了。

答案 2 :(得分:0)

如果在关闭之前调用Socket上的Shutdown会发生什么?

socket.Shutdown(SocketShutdown.Both);

答案 3 :(得分:0)

怎么样

_sslStream.Dispose();

我想知道Dispose方法是否处理close_notify