ClientTunnel.cpp 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. //ClientTunnel.cpp
  2. #include "stdafx.h"
  3. #include "ClientTunnel.h"
  4. #ifdef _DEBUG
  5. #define new DEBUG_NEW
  6. #undef THIS_FILE
  7. static char THIS_FILE[] = __FILE__;
  8. #endif
  9. CClientTunnel *CClientTunnel::m_pInstance = NULL;
  10. static void netGetDataBufLenCb(IN SOCKET hSocket, IN void *pHeaderBuf,
  11. OUT unsigned long *nDataLen);
  12. static void netHandleNetEvent(IN SOCKET hSocket, IN ETransportEvent eEvent,
  13. IN void *pDataBuf, IN unsigned long nDataLen,
  14. IN int nError, IN void *pContext);
  15. ///////////////////////////////////////////////////////////////////////////////
  16. ///////////////////////////////////////////////////////////////////////////////
  17. #pragma comment(lib, "Transport.lib")
  18. CClientTunnel::CClientTunnel()
  19. {
  20. m_hSocket = INVALID_SOCKET;
  21. }
  22. CClientTunnel::~CClientTunnel()
  23. {
  24. }
  25. int CClientTunnel::net_OpenSocket(IN ETransportType eType,
  26. IN unsigned short usPort,
  27. IN LPTRANSPORT_EVENT eventHandler,
  28. void *pContext)
  29. {
  30. //LOG4C((LOG_NOTICE,"CClientTunnel::net_OpenSocket"));
  31. TransportStatus status = TRANSPORT_OK;
  32. unsigned long ulHeaderLen = MESSAGE_HEADER_LEN;
  33. m_eventHandler = eventHandler;
  34. m_pContext = pContext;
  35. eventHandler = netHandleNetEvent;
  36. pContext = this;
  37. LPTRANSPORT_GETDATABUFLEN cbHandler = netGetDataBufLenCb;
  38. SOCKET hSocket = CTransportImpl::net_OpenSocket(
  39. eType,
  40. usPort,
  41. eventHandler,
  42. cbHandler,
  43. ulHeaderLen,
  44. pContext);
  45. if( INVALID_SOCKET == hSocket )
  46. {
  47. return TRANSPORT_ERROR;
  48. }
  49. m_hSocket = hSocket;
  50. return status;
  51. }
  52. void CClientTunnel::net_CloseSocket()
  53. {
  54. CTransportImpl::net_CloseSocket();
  55. }
  56. int CClientTunnel::net_Connect(IN unsigned long ulIPValue, IN unsigned short usPort)
  57. {
  58. int nResult = TRANSPORT_OK;
  59. nResult = CTransportImpl::net_Connect(ulIPValue, usPort);
  60. return nResult;
  61. }
  62. unsigned long CClientTunnel::net_Send(IN void *pHeader,
  63. IN void *pMessage,
  64. IN unsigned long ulDataLen)
  65. {
  66. unsigned long ulSendLen = 0;
  67. unsigned long ulBufLen = 0;
  68. TMessageHeader *pSendHeader = (TMessageHeader *)pHeader;
  69. ulBufLen = MESSAGE_HEADER_LEN + ulDataLen;
  70. char *pSendBuf = new char[ulBufLen];
  71. memset(pSendBuf, 0, ulBufLen);
  72. TMessageHeader *pMessageHeader = (TMessageHeader *)pSendBuf;
  73. pMessageHeader->byVersion = 101;
  74. pMessageHeader->wHeaderFlag = MESSAGE_HEADER_FLAG;
  75. pMessageHeader->wMessageId = pSendHeader->wMessageId;
  76. pMessageHeader->wMessageSubId = pSendHeader->wMessageSubId;
  77. pMessageHeader->dwDataLen = ulDataLen;
  78. pMessageHeader->wReserve = 0;
  79. memcpy((void *)(pSendBuf+MESSAGE_HEADER_LEN), pMessage, ulDataLen);
  80. // convert network word
  81. htons(pMessageHeader->wHeaderFlag);
  82. htons(pMessageHeader->wMessageId);
  83. htons(pMessageHeader->wMessageSubId);
  84. htonl(pMessageHeader->dwDataLen);
  85. htons(pMessageHeader->wCheckSum);
  86. htonl(pMessageHeader->wReserve);
  87. //Send the message
  88. SOCKET hSocket = m_hSocket;
  89. ulSendLen = CTransportImpl::net_Send(hSocket, (void *)pSendBuf, ulBufLen);
  90. delete [] pSendBuf;
  91. pSendBuf = NULL;
  92. return ulSendLen;
  93. }
  94. void netGetDataBufLenCb(IN SOCKET hSocket, IN void *pHeaderBuf,
  95. OUT unsigned long *nDataLen)
  96. {
  97. TMessageHeader *pHeader = NULL;
  98. *nDataLen = 0;
  99. pHeader = (TMessageHeader *)pHeaderBuf;
  100. if( NULL == pHeader )
  101. {
  102. return;
  103. }
  104. if( MESSAGE_HEADER_FLAG != pHeader->wHeaderFlag )
  105. {
  106. return;
  107. }
  108. unsigned long dwDataBufLen = pHeader->dwDataLen;
  109. ntohl(dwDataBufLen);
  110. *nDataLen = dwDataBufLen;
  111. return;
  112. }
  113. void netHandleNetEvent(IN SOCKET hSocket, IN ETransportEvent eEvent,
  114. IN void *pDataBuf, IN unsigned long nDataLen,
  115. IN int nError, IN void *pContext)
  116. {
  117. //Notify application layer
  118. CClientTunnel *pClientTunnel = (CClientTunnel *)pContext;
  119. if( NULL == pClientTunnel )
  120. {
  121. return;
  122. }
  123. void *pUserData = pClientTunnel->m_pContext;
  124. TransportBool bHandle = TRUE;
  125. if( Transport_ReadEv == eEvent )
  126. {
  127. if( nDataLen <= 0 )
  128. {
  129. return;
  130. }
  131. //提取消息头,获得消息ID
  132. char *pMessageBuf = (char *)pDataBuf;
  133. TMessageHeader *pHeader = (TMessageHeader *)pMessageBuf;
  134. //网络字节顺序的转换
  135. ntohs(pHeader->wHeaderFlag);
  136. ntohs(pHeader->wMessageId);
  137. ntohs(pHeader->wMessageSubId);
  138. ntohl(pHeader->dwDataLen);
  139. ntohs(pHeader->wCheckSum);
  140. ntohl(pHeader->wReserve);
  141. bHandle = (MESSAGE_HEADER_FLAG == pHeader->wHeaderFlag);
  142. }
  143. if( bHandle )
  144. {
  145. if( NULL != pClientTunnel->m_eventHandler )
  146. {
  147. pClientTunnel->m_eventHandler(hSocket, eEvent, pDataBuf, nDataLen, nError, pUserData);
  148. }
  149. }
  150. }