WSDataFrameExtensions.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. //------------------------------------------------------------------------------
  2. // 此代码版权(除特别声明或在XREF结尾的命名空间的代码)归作者本人若汝棋茗所有
  3. // 源代码使用协议遵循本仓库的开源协议及附加协议,若本仓库没有设置,则按MIT开源协议授权
  4. // CSDN博客:https://blog.csdn.net/qq_40374647
  5. // 哔哩哔哩视频:https://space.bilibili.com/94253567
  6. // Gitee源代码仓库:https://gitee.com/RRQM_Home
  7. // Github源代码仓库:https://github.com/RRQM
  8. // API首页:https://www.yuque.com/rrqm/touchsocket/index
  9. // 交流QQ群:234762506
  10. // 感谢您的下载和使用
  11. //------------------------------------------------------------------------------
  12. //------------------------------------------------------------------------------
  13. using System.Text;
  14. using TouchSocket.Core;
  15. using TouchSocket.Sockets;
  16. namespace TouchSocket.Http.WebSockets
  17. {
  18. /// <summary>
  19. /// WSDataFrame辅助扩展类
  20. /// </summary>
  21. public static class WSDataFrameExtensions
  22. {
  23. /// <summary>
  24. /// 追加文本
  25. /// </summary>
  26. /// <param name="dataFrame"></param>
  27. /// <param name="text"></param>
  28. /// <param name="encoding"></param>
  29. /// <returns></returns>
  30. public static WSDataFrame AppendText(this WSDataFrame dataFrame, string text, Encoding encoding = default)
  31. {
  32. dataFrame.Opcode = WSDataType.Text;
  33. byte[] data = (encoding == default ? Encoding.UTF8 : encoding).GetBytes(text);
  34. if (dataFrame.PayloadData == null)
  35. {
  36. dataFrame.PayloadData = new ByteBlock();
  37. }
  38. dataFrame.PayloadData.Write(data);
  39. return dataFrame;
  40. }
  41. /// <summary>
  42. /// 追加二进制流
  43. /// </summary>
  44. /// <param name="dataFrame"></param>
  45. /// <param name="buffer"></param>
  46. /// <param name="offset"></param>
  47. /// <param name="length"></param>
  48. /// <returns></returns>
  49. public static WSDataFrame AppendBinary(this WSDataFrame dataFrame, byte[] buffer, int offset, int length)
  50. {
  51. dataFrame.Opcode = WSDataType.Binary;
  52. if (dataFrame.PayloadData == null)
  53. {
  54. dataFrame.PayloadData = new ByteBlock();
  55. }
  56. dataFrame.PayloadData.Write(buffer, offset, length);
  57. return dataFrame;
  58. }
  59. /// <summary>
  60. /// 构建请求数据(含Make)
  61. /// </summary>
  62. /// <param name="dataFrame"></param>
  63. /// <param name="byteBlock"></param>
  64. /// <returns></returns>
  65. public static bool BuildRequest(this WSDataFrame dataFrame, ByteBlock byteBlock)
  66. {
  67. dataFrame.FIN = true;
  68. dataFrame.Mask = true;
  69. if (dataFrame.MaskingKey == null)
  70. {
  71. dataFrame.SetMaskString("RRQM");
  72. }
  73. return dataFrame.Build(byteBlock, true);
  74. }
  75. /// <summary>
  76. /// 构建请求数据(含Make)
  77. /// </summary>
  78. /// <param name="dataFrame"></param>
  79. /// <returns></returns>
  80. public static byte[] BuildRequestToBytes(this WSDataFrame dataFrame)
  81. {
  82. dataFrame.FIN = true;
  83. dataFrame.Mask = true;
  84. if (dataFrame.MaskingKey == null)
  85. {
  86. dataFrame.SetMaskString("RRQM");
  87. }
  88. using (ByteBlock byteBlock = new ByteBlock())
  89. {
  90. dataFrame.Build(byteBlock, true);
  91. byte[] data = byteBlock.ToArray();
  92. return data;
  93. }
  94. }
  95. /// <summary>
  96. /// 构建响应数据(无Make)
  97. /// </summary>
  98. /// <param name="dataFrame"></param>
  99. /// <param name="byteBlock"></param>
  100. /// <returns></returns>
  101. public static bool BuildResponse(this WSDataFrame dataFrame, ByteBlock byteBlock)
  102. {
  103. dataFrame.FIN = true;
  104. return dataFrame.Build(byteBlock, false);
  105. }
  106. /// <summary>
  107. /// 构建响应数据(无Make)
  108. /// </summary>
  109. /// <param name="dataFrame"></param>
  110. /// <returns></returns>
  111. public static byte[] BuildResponseToBytes(this WSDataFrame dataFrame)
  112. {
  113. dataFrame.FIN = true;
  114. using (ByteBlock byteBlock = new ByteBlock())
  115. {
  116. dataFrame.Build(byteBlock, false);
  117. byte[] data = byteBlock.ToArray();
  118. return data;
  119. }
  120. }
  121. /// <summary>
  122. /// 设置Mask。
  123. /// </summary>
  124. /// <param name="dataFrame"></param>
  125. /// <param name="mask"></param>
  126. /// <returns></returns>
  127. public static WSDataFrame SetMaskString(this WSDataFrame dataFrame, string mask)
  128. {
  129. byte[] masks = Encoding.UTF8.GetBytes(mask);
  130. if (masks.Length != 4)
  131. {
  132. throw new OverlengthException("Mask只能为ASCII,且只能为四位。");
  133. }
  134. dataFrame.MaskingKey = masks;
  135. return dataFrame;
  136. }
  137. /// <summary>
  138. /// 当<see cref="WSDataType.Text"/>时,转换为Text消息。
  139. /// </summary>
  140. /// <param name="dataFrame"></param>
  141. /// <param name="encoding"></param>
  142. /// <returns></returns>
  143. public static string ToText(this WSDataFrame dataFrame, Encoding encoding = default)
  144. {
  145. return (encoding == default ? Encoding.UTF8 : encoding).GetString(dataFrame.PayloadData.Buffer, 0, dataFrame.PayloadLength);
  146. }
  147. }
  148. }