我使用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
时编写的字节完全相同的字节数来读取流。这不可能是对的。我在这里缺少什么?
答案 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);