TsgcWebSocketServer › 方法 › WriteData
向由连接 GUID 标识的单个客户端发送消息。
function WriteData(const aGuid, aMessage: string): Boolean;
| 名称 | 类型 | 描述 |
|---|---|---|
aGuid | const string | 客户端握手完成时服务器分配的目标连接标识符。 |
aMessage | const string | 以 WebSocket 文本帧形式投递给该客户端的文本载荷。 |
当找到具有给定 GUID 的连接并且帧已传递到其套接字时为 True;当不存在匹配的活动连接时为 False。(Boolean)
此重载查找 GUID 与 aGuid 匹配的连接,并将文本消息发送给该单个客户端。GUID 是 TsgcWSConnection.Guid 公开的值,通常在 OnConnect 中捕获并由应用程序存储。当 QueueOptions.Text 设置为 qmNone 以外的值时,帧将被排入队列并从连接线程而非调用方线程分发(当 IOHandlerOptions.IOHandlerType = iohIOCP 时不支持)。使用 Broadcast 可一次性向所有活跃客户端发送消息。
oServer.WriteData('guid', 'My First sgcWebSockets Message!.');
function WriteData(const aGuid: String; aStream: TStream; aSize: Integer = 0; const aStreaming: TwsStreaming = stmNone) : Boolean;
| 名称 | 类型 | 描述 |
|---|---|---|
aGuid | const String | 客户端握手完成时服务器分配的目标连接标识符。 |
aStream | TStream | 包含发送给客户端内容的源流,作为 WebSocket 二进制帧。调用方仍是流的所有者。 |
aSize | Integer | 可选的片段大小(字节);当大于零时,流将被分割为多个此大小的片段。使用 0(默认值)以单个帧发送整个流。 |
aStreaming | const TwsStreaming | 分片传输的流模式(stmNone、stmStart、stmContinue、stmFinish)。默认为 stmNone,发送完整的独立消息。 |
当找到具有给定 GUID 的连接并将流交给其套接字时为 True;当不存在匹配的活动连接时为 False。(Boolean)
此重载针对单个客户端,发送从提供的流中读取的二进制负载。流从其当前位置消耗,服务器不获取所有权,因此调用方必须在 WriteData 返回之前(或排队时,在发送完成之前)保持其有效。当 QueueOptions.Binary 设置为非 qmNone 的值时,帧将从连接线程而非调用方线程排队并分发(当 IOHandlerOptions.IOHandlerType = iohIOCP 时不支持)。当发送需要跨多个 WebSocket 帧分片的超大负载时,请将 aSize 与 aStreaming 结合使用。
oStream := TMemoryStream.Create;
try
oStream.LoadFromFile('payload.bin');
oServer.WriteData('guid', oStream);
finally
oStream.Free;
end;