内置的命令行PipelineFilter

    什么是协议? 很多人会回答 “TCP” 或者 “UDP”。 但是构建一个网络应用程序, 仅仅知道是 TCP 还是 UDP 是远远不够的。 TCP 和 UDP 是传输层协议。仅仅定义了传输层协议是不能让网络的两端进行通信的。你需要定义你的应用层通信协议把你接收到的二进制数据转化成你程序能理解的请求。

    命令行协议是一种被广泛应用的协议。一些成熟的协议如 Telnet, SMTP, POP3 和 FTP 都是基于命令行协议的。 CommandLinePipelineFilter是设计用于命令行协议的 PipelineFilter。

    如果你在 SuperSocket 中使用命令行协议,所有接收到的数据将会翻译成 StringRequestInfo 实例。

    StringRequestInfo 是这样定义的:

    SuperSocket 服务器将会收到一个 StringRequestInfo 实例,这个实例的属性为:

    如果你定义了名为 “LOGIN” 的命令, 这个命令的 ExecuteCommand 方法将会被执行,服务器所接收到的StringRequestInfo实例也将作为参数传给这个方法:

    1. public class LOGIN : IAsyncCommand<StringPackageInfo>
    2. {
    3. public async ValueTask ExecuteAsync(IAppSession session, StringPackageInfo package)
    4. {
    5. //Implement your business logic
    6. }

    请求的 key 和 body 通过字符 ‘:’ 分隔, 而且多个参数被字符 ‘,’ 分隔。 支持这种类型的请求非常简单, 你只需要用下面的代码扩展命令行协议:

    1. public class CustomPackageDecoder : IPackageDecoder<StringPackageInfo>
    2. public StringPackageInfo Decode(ref ReadOnlySequence<byte> buffer, object context)
    3. {
    4. var text = buffer.GetString(new UTF8Encoding(false));
    5. var parts = text.Split(':', 2);
    6. return new StringPackageInfo
    7. Key = parts[0],
    8. Parameters = parts[1].Split(',')
    9. };
    10. }
    11. }
    12. // register the custom package decoder through the host builder