Danke für das Feedback und die Anregungen! Ich freue mich natürlich auch über Pull Requests auf das GitHub Repository mit Vorschlägen, alternativ gerne per PM etc.
Nun ist der zweite Teil erschienen:
Teil 2: Lesen eines Snowman ☃ - terminierten Strings von einem TCP Socket
Dazu gibt es auch wieder einen
Artikel.
Der Server sendet in diesem Beispiel einen kurzen Text an den Client, gefolgt von der Byte-Sequenz $2603, dies ist der
Unicode-Wert für das Snowman Symbol.
Die clientseitige Implementierung für
Indy und Synapse ist relativ kompakt und leicht lesbar. Hier die für Synapse:
Delphi-Quellcode:
function ReadDelimited(AHost: string; APort: Integer; ATerminator: RawByteString): string;
var
FSock: TTCPBlockSocket;
begin
FSock := TTCPBlockSocket.Create;
try
FSock.RaiseExcept := True;
FSock.Connect(AHost, IntToStr(APort));
Result := FSock.RecvTerminated(1000, ATerminator);
finally
FSock.Free;
end;
end;
Der Terminator wird dazu im Beispiel als Konstante definiert:
FIXED_DELIMITER = '' + #$2603; // '☃';
Das Testprogramm sieht aktuell so aus:
Delphi-Quellcode:
program FixedDelimiterClient;
uses
ClientIndySockets10,
//ClientSynapse266,
//ClientSynopseCrtSock,
SysUtils;
const
FIXED_DELIMITER = '
' + #$2603;
// '☃';
SERVER_HOST = '
127.0.0.1';
SERVER_PORT = 30000;
procedure Test(ADelimiter:
string);
var
Response:
string;
begin
WriteLn(Format('
try to read from %s:%d delimited with %s',
[SERVER_HOST, SERVER_PORT, ADelimiter]));
Response := ReadDelimited(SERVER_HOST, SERVER_PORT, Utf8Encode(ADelimiter));
WriteLn(Format('
received response "%s" - %d bytes',
[Response, Length(Response)]));
end;
begin
try
Test(FIXED_DELIMITER);
Test(FIXED_DELIMITER);
Test(FIXED_DELIMITER);
except
on E:
Exception do
begin
WriteLn(E.
Message);
end;
end;
ReadLn;
end.
Da es eine Konsolenanwendung ist, sieht man den Snowman leider nicht.
Es erscheint nur "try to read from 127.0.0.1:30000 delimited with ?'