ServerMsgHandler.cs 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using Slice;
  6. using CommonNetwork_ICE.Common;
  7. using CommonServer.Server;
  8. using CommonServer_ICE.Session;
  9. using CommonServer.Protocol;
  10. using CommonLang.Protocol;
  11. using CommonNetwork_ICE.Util;
  12. using CommonServer_ICE.Server;
  13. using CommonLang.Log;
  14. namespace CommonServer_ICE.Msg
  15. {
  16. /// <summary>
  17. /// ICE消息委托处理接口
  18. /// </summary>
  19. internal abstract class ServerMsgHandler
  20. {
  21. private static Logger log = LoggerFactory.GetLogger("ServerMsgHandler");
  22. public ServerMsgHandler()
  23. {
  24. }
  25. /// <summary>
  26. /// 获取通讯类型
  27. /// </summary>
  28. public abstract IceConnectServer getServer();
  29. /// <summary>
  30. /// 处理收到客户端发来的关键数据包
  31. /// </summary>
  32. /// <param name="recvPort">发送方侦听端口</param>
  33. /// <param name="message">数据包</param>
  34. /// <param name="ip">发送方IP</param>
  35. /// <param name="port">发送方端口</param>
  36. public abstract void RecvData(int recvPort, TransMessage message, string ip, int port);
  37. /// <summary>
  38. /// 处理收到客户端发来的关键数据包确认序列号
  39. /// </summary>
  40. /// <param name="recvPort">发送方侦听端口</param>
  41. /// <param name="serial">序列号</param>
  42. /// <param name="ip">发送方IP</param>
  43. /// <param name="port">发送方端口</param>
  44. public abstract void SendDataRecvAck(int recvPort, long serial, string ip, int port);
  45. /// <summary>
  46. /// 处理客户端连接到服务器,回发连接响应
  47. /// </summary>
  48. /// <param name="recvPort">发送方侦听端口</param>
  49. /// <param name="ip">发送方IP</param>
  50. /// <param name="port">发送方端口</param>
  51. public void Connect(int recvPort, string ip, int port)
  52. {
  53. log.Info("收到客户端发来请求连接,地址IP【" + ip + "】,端口【" + port + "】,发送方侦听端口【" + recvPort + "】");
  54. if (SessionManager.hasSession(ip, port, recvPort))
  55. {
  56. // 已经连接,发送连接成功确认
  57. IceServerIoSession confirmSession = (IceServerIoSession)SessionManager.getSession(ip, port, recvPort);
  58. if (!confirmSession.IsConnected)
  59. {
  60. confirmSession.IsConnected = true;
  61. try
  62. {
  63. confirmSession.Sender.ConnectAck();
  64. }
  65. catch (Exception e)
  66. {
  67. confirmSession.HandleException(e);
  68. }
  69. }
  70. else
  71. {
  72. log.Error("非法的多次连接,不予处理,客户端地址IP【" + ip + "】,端口【" + port + "】,发送方侦听端口【" + recvPort + "】");
  73. }
  74. return;
  75. }
  76. IceConnectServer server = this.getServer();
  77. IceServerIoSession session = SessionManager.createSession(server, ip, port, recvPort);
  78. // 初始化Session的ICE发送
  79. IceConnector connector = new IceConnector(Constants.SEND_INTERFACE_NAME, Constants.SERVER_SENDER_RECV_ADAPTER, ip, recvPort, server.getServerConfig().Ip, server.getServerConfig().Port);
  80. try
  81. {
  82. IceInit.InitIceSender(server.getCommType(), connector);
  83. }
  84. catch (Exception e)
  85. {
  86. session.HandleException(e);
  87. return;
  88. }
  89. if (connector.SenderConnector == null)
  90. {
  91. log.Error("初始化服务器端发送器异常,创建Session不成功,客户端地址IP【" + ip + "】,端口【" + port + "】,发送方侦听端口【" + recvPort + "】");
  92. return;
  93. }
  94. session.Connector = connector;
  95. session.Sender = connector.Sender;
  96. // 启用Session
  97. session.IsConnected = true;
  98. // 发送连接成功确认
  99. try
  100. {
  101. server.OnNewSessionConnected(session);
  102. session.OnSessionStarted();
  103. session.Sender.ConnectAck();
  104. }
  105. catch (Exception e)
  106. {
  107. session.HandleException(e);
  108. }
  109. }
  110. /// <summary>
  111. /// 服务器发送连接成功响应
  112. /// </summary>
  113. /// <param name="ip">发送方IP</param>
  114. /// <param name="port">发送方端口</param>
  115. public void ConnectAck(string ip, int port)
  116. {
  117. }
  118. /// <summary>
  119. /// 处理客户端发出关闭会话请求,服务器
  120. /// </summary>
  121. /// <param name="recvPort">发送方侦听端口</param>
  122. /// <param name="ip">发送方IP</param>
  123. /// <param name="port">发送方端口</param>
  124. public void Close(int recvPort, string ip, int port)
  125. {
  126. log.Info("收到客户端发来关闭连接请求,地址IP【" + ip + "】,端口【" + port + "】,发送方侦听端口【" + recvPort + "】");
  127. IceServerIoSession session = (IceServerIoSession)SessionManager.getSession(ip, port, recvPort);
  128. if (session != null)
  129. {
  130. try
  131. {
  132. session.Sender.CloseAck(recvPort);
  133. }
  134. catch (Exception e)
  135. {
  136. session.HandleException(e);
  137. }
  138. // 发送关闭确认响应
  139. session.Disconnect(true);
  140. }
  141. else
  142. {
  143. log.Error("非法的关闭命令,客户端地址IP【" + ip + "】,端口【" + port + "】,发送方侦听端口【" + recvPort + "】");
  144. return;
  145. }
  146. }
  147. /// <summary>
  148. /// 处理服务器主动关闭会话,客户端回发关闭连接响应
  149. /// </summary>
  150. /// <param name="recvPort">发送方侦听端口</param>
  151. /// <param name="ip">发送方IP</param>
  152. /// <param name="port">发送方端口</param>
  153. public void CloseAck(int recvPort, string ip, int port)
  154. {
  155. log.Info("收到客户端发来关闭成功响应,地址IP【" + ip + "】,端口【" + port + "】,发送方侦听端口【" + recvPort + "】");
  156. IceServerIoSession session;
  157. if (SessionManager.hasSession(ip, port, recvPort))
  158. {
  159. session = (IceServerIoSession)SessionManager.getSession(ip, port, recvPort);
  160. session.Disconnect(true);
  161. }
  162. else
  163. {
  164. log.Error("非法的关闭响应命令,客户端地址IP【" + ip + "】,端口【" + port + "】,发送方侦听端口【" + recvPort + "】");
  165. return;
  166. }
  167. }
  168. }
  169. }