奇怪的SslStream缓冲问题

时间:2011-12-29 16:12:52

标签: c# ssl .net-2.0

我使用SslStream加密客户端和服务器之间的TCP连接。问题是当客户端读取数据时,可能会给它一堆零字节而不是真实数据。以下示例显示了该问题:

        // Server
        using (NetworkStream tcpStream = client.GetStream())
        {
            Stream stream = tcpStream;
            if (ssl)
            {
                SslStream sslStream = new SslStream(tcpStream, true);
                sslStream.AuthenticateAsServer(cert, false, SslProtocols.Default, false);
                stream = sslStream;
            }

            byte[] buf = new byte[] {0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02};
            stream.Write(buf, 0, buf.Length);

            buf = new byte[] {0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x03};
            stream.Write(buf, 0, buf.Length);
        }



        // Client
        using (NetworkStream tcpStream = client.GetStream())
        {
            Stream stream = tcpStream;
            if (ssl)
            {
                SslStream sslStream = new SslStream(
                    tcpStream, 
                    true, 
                    delegate { return true; }
                );
                sslStream.AuthenticateAsClient(
                    "localhost",
                    null,
                    SslProtocols.Default,
                    false
                    );
                stream = sslStream;
            }

            byte[] buf = new byte[7];
            stream.Read(buf, 0, buf.Length);
            // buf is 01010101010101 as expected

            buf = new byte[9];
            stream.Read(buf, 0, buf.Length);
            // buf is 020000000000000000 instead of the expected 020303030303030303
            // a subsequent read of 8 bytes will get me 0303030303030303
            // if the ssl bool is set to false, then the expected data is received without the need for a third read
        }

似乎客户端需要以与服务器仅在使用SslStream时编写的字节完全相同的字节数来读取流。这不可能是对的。我在这里缺少什么?

1 个答案:

答案 0 :(得分:3)

此代码

buf = new byte[9];
stream.Read(buf, 0, buf.Length);

请求stream将1到9个字节读入buf。它并不总是精确读取9个字节。

Read Method返回实际读取的字节数。

试试这个:

byte[] buffer = new byte[9];
int offset = 0;
int count = buffer.Length;

do
{
    int bytesRead = stream.Read(buffer, offset, count);
    if (bytesRead == 0)
        break; // end of stream
    offset += bytesRead;
    count -= bytesRead;
}
while (count > 0);