johan's code

senior meeting
This commit is contained in:
shinichi
2020-09-25 12:43:01 +02:00
parent fb57a1779c
commit dded1a5b24

View File

@@ -14,6 +14,7 @@ namespace Server
private byte[] buffer = new byte[1024]; private byte[] buffer = new byte[1024];
private byte[] totalBuffer = new byte[1024]; private byte[] totalBuffer = new byte[1024];
private int bytesReceived; private int bytesReceived;
private int totalBufferReceived = 0;
public string Username { get; set; } public string Username { get; set; }
@@ -31,6 +32,33 @@ namespace Server
int receivedBytes = this.stream.EndRead(ar); int receivedBytes = this.stream.EndRead(ar);
byte[] lengthBytes = new byte[4]; byte[] lengthBytes = new byte[4];
if (totalBufferReceived + receivedBytes > 1024)
{
throw new OutOfMemoryException("buffer too small");
}
Array.Copy(buffer, 0, totalBuffer, totalBufferReceived, receivedBytes);
totalBufferReceived += receivedBytes;
int expectedMessageLength = BitConverter.ToInt32(totalBuffer, 0);
while (totalBufferReceived >= expectedMessageLength)
{
//volledig packet binnen
byte[] packetBytes = new byte[expectedMessageLength];
Array.Copy(totalBuffer, 6, packetBytes, 0, expectedMessageLength - 6);
Console.WriteLine(Encoding.ASCII.GetString(packetBytes) + " " + expectedMessageLength);
Array.Copy(totalBuffer, expectedMessageLength, totalBuffer, 0, (totalBufferReceived - expectedMessageLength));
totalBufferReceived -= expectedMessageLength;
expectedMessageLength = BitConverter.ToInt32(totalBuffer, 0);
}
/*
Array.Copy(this.buffer, 0, lengthBytes, 0, 4); Array.Copy(this.buffer, 0, lengthBytes, 0, 4);
int expectedMessageLength = BitConverter.ToInt32(lengthBytes); int expectedMessageLength = BitConverter.ToInt32(lengthBytes);
@@ -73,7 +101,7 @@ namespace Server
this.bytesReceived = 0; this.bytesReceived = 0;
} }
*/
this.stream.BeginRead(this.buffer, 0, this.buffer.Length, new AsyncCallback(OnRead), null); this.stream.BeginRead(this.buffer, 0, this.buffer.Length, new AsyncCallback(OnRead), null);
} }