TsgcWebSocketClientMétodos › WriteData

WriteData Method

Envia uma mensagem de texto ao servidor WebSocket, opcionalmente dividindo-a em fragmentos de um determinado tamanho.

Overloads

Overload 1

Sintaxe

procedure WriteData(const aText: String; const aSize: Integer = 0; const aStreaming: TwsStreaming = stmNone);

Parâmetros

NameTypeDescrição
aTextconst StringO payload de texto a ser enviado ao servidor como um frame de texto WebSocket.
aSizeconst IntegerTamanho de fragmento opcional em bytes; quando maior que zero, a mensagem é dividida em múltiplos fragmentos desse tamanho. Use 0 (o padrão) para enviar a mensagem inteira como um único frame.
aStreamingconst TwsStreamingModo de streaming para transmissão fragmentada (stmNone, stmStart, stmContinue, stmFinish). Padrão stmNone, que envia uma mensagem completa e independente.

Observações

WriteData transmite a string como um frame de texto WebSocket na conexão ativa. Por padrão, a chamada executa na thread chamadora e retorna assim que os bytes são entregues ao socket. Quando QueueOptions.Text é definido com um valor diferente de qmNone, a mensagem é enfileirada e efetivamente enviada a partir da própria thread da conexão, o que evita locks quando várias threads escrevem simultaneamente. A chamada é um no-op quando o cliente não está conectado, e qualquer exceção de socket é encaminhada para OnError. Use a sobrecarga de stream ao enviar payloads grandes ou dados binários.

Exemplo


oClient.WriteData('My First sgcWebSockets Message!.');

Sobrecarga 2

Sintaxe

procedure WriteData(const aStream: TStream; const aSize: Integer = 0; const aStreaming: TwsStreaming = stmNone);

Parâmetros

NameTypeDescrição
aStreamconst TStreamStream de origem cujo conteúdo será enviado como um frame binário WebSocket. O chamador permanece o proprietário do stream.
aSizeconst IntegerTamanho de fragmento opcional em bytes; quando maior que zero, o stream é dividido em múltiplos fragmentos deste tamanho. Use 0 (o padrão) para enviar todo o stream como um único frame.
aStreamingconst TwsStreamingModo de streaming para transmissão fragmentada (stmNone, stmStart, stmContinue, stmFinish). Padrão stmNone, que envia uma mensagem completa e independente.

Observações

WriteData lê o stream fornecido a partir de sua posição atual e transmite o conteúdo como um frame binário WebSocket. A chamada é executada na thread chamadora por padrão; quando QueueOptions.Binary é definido para um valor diferente de qmNone, a mensagem é enfileirada e efetivamente despachada a partir da thread da conexão. O método é uma operação sem efeito quando o cliente não está conectado, e as exceções de socket são capturadas e encaminhadas para OnError. Libere o stream apenas após o retorno da chamada (ou, ao enfileirar, após o envio ser concluído).

Exemplo


oStream := TMemoryStream.Create;
try
  oStream.LoadFromFile('payload.bin');
  oClient.WriteData(oStream);
finally
  oStream.Free;
end;

Voltar para Métodos