TsgcWebSocketServer方法 › WriteData

WriteData 方法

向由连接 GUID 标识的单个客户端发送消息。

重载

重载 1

语法

function WriteData(const aGuid, aMessage: string): Boolean;

参数

名称类型描述
aGuidconst string客户端握手完成时服务器分配的目标连接标识符。
aMessageconst 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!.');

重载 2

语法

function WriteData(const aGuid: String; aStream: TStream; aSize: Integer = 0; const aStreaming: TwsStreaming = stmNone) : Boolean;

参数

名称类型描述
aGuidconst String客户端握手完成时服务器分配的目标连接标识符。
aStreamTStream包含发送给客户端内容的源流,作为 WebSocket 二进制帧。调用方仍是流的所有者。
aSizeInteger可选的片段大小(字节);当大于零时,流将被分割为多个此大小的片段。使用 0(默认值)以单个帧发送整个流。
aStreamingconst TwsStreaming分片传输的流模式(stmNonestmStartstmContinuestmFinish)。默认为 stmNone,发送完整的独立消息。

返回值

当找到具有给定 GUID 的连接并将流交给其套接字时为 True;当不存在匹配的活动连接时为 False。(Boolean

备注

此重载针对单个客户端,发送从提供的流中读取的二进制负载。流从其当前位置消耗,服务器不获取所有权,因此调用方必须在 WriteData 返回之前(或排队时,在发送完成之前)保持其有效。当 QueueOptions.Binary 设置为非 qmNone 的值时,帧将从连接线程而非调用方线程排队并分发(当 IOHandlerOptions.IOHandlerType = iohIOCP 时不支持)。当发送需要跨多个 WebSocket 帧分片的超大负载时,请将 aSizeaStreaming 结合使用。

示例


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

返回方法