test.cpp 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. // test.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
  2. //
  3. #include "stdafx.h"
  4. #include "framework.h"
  5. #include "test.h"
  6. // winsocket库;
  7. #include <Ws2tcpip.h>
  8. #pragma comment(lib,"Ws2_32.lib")
  9. #include <thread>
  10. #ifdef _DEBUG
  11. #define new DEBUG_NEW
  12. #endif
  13. // 唯一的应用程序对象
  14. CWinApp theApp;
  15. using namespace std;
  16. #define BUF_LEN 8192
  17. class logClient
  18. {
  19. public:
  20. logClient() {
  21. m_port = 0;
  22. m_sock = INVALID_SOCKET;
  23. };
  24. ~logClient() {
  25. disconnect();
  26. WSACleanup();
  27. };
  28. private:
  29. // 客户端套接字;
  30. SOCKET m_sock;
  31. // 客户端地址;
  32. sockaddr_in m_sin;
  33. // ip;
  34. std::string m_ip;
  35. // port;
  36. int m_port;
  37. public:
  38. bool InitSocket() {
  39. WSADATA wsaData;
  40. return (NO_ERROR == WSAStartup(MAKEWORD(2, 2), &wsaData));
  41. }
  42. bool Connect(std::string ip, int port) {
  43. // 创建;
  44. m_sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
  45. if (m_sock == INVALID_SOCKET)
  46. return false;
  47. // 连接服务器;
  48. m_sin.sin_family = AF_INET;
  49. m_sin.sin_port = htons(port);
  50. if (-1 == inet_pton(AF_INET, ip.c_str(), &m_sin.sin_addr))
  51. {
  52. return false;
  53. }
  54. if (connect(m_sock, (LPSOCKADDR)& m_sin, sizeof(m_sin)) == SOCKET_ERROR)
  55. {
  56. //Global::WriteTextLog(_T("连接服务端失败:%d"), WSAGetLastError());
  57. closesocket(m_sock);
  58. return false;
  59. }
  60. // 设置收发超时;
  61. int nNetTimeout = 3000; //1秒
  62. //发送时限
  63. setsockopt(m_sock, SOL_SOCKET, SO_SNDTIMEO, (char*)& nNetTimeout, sizeof(int));
  64. //接收时限
  65. setsockopt(m_sock, SOL_SOCKET, SO_RCVTIMEO, (char*)& nNetTimeout, sizeof(int));
  66. // 设置缓存大小;
  67. int bufSize = BUF_LEN;
  68. setsockopt(m_sock, SOL_SOCKET, SO_SNDBUF, (char*)& bufSize, sizeof(int));
  69. setsockopt(m_sock, SOL_SOCKET, SO_RCVBUF, (char*)& bufSize, sizeof(int));
  70. return true;
  71. };
  72. void disconnect() {
  73. if (m_sock != INVALID_SOCKET)
  74. {
  75. shutdown(m_sock, SD_BOTH);
  76. closesocket(m_sock);
  77. }
  78. }
  79. void ReConnect(DWORD dwError)
  80. {
  81. bool bReConnect = false;
  82. // send/recv error;
  83. if (dwError == WSAENETRESET)
  84. {
  85. bReConnect = true;
  86. //Global::WriteTextLog(_T("由于保持活动活动在操作正在进行时检测到故障,因此连接已断开。"));
  87. }
  88. else if (dwError == WSAECONNABORTED)
  89. {
  90. bReConnect = true;
  91. //Global::WriteTextLog(_T("由于超时或其他故障,虚电路终止。应用程序应关闭套接字,因为它不再可用。"));
  92. }
  93. else if (dwError == WSAECONNRESET)
  94. {
  95. bReConnect = true;
  96. //Global::WriteTextLog(_T("虚拟电路由远程端执行硬关闭或中止关闭重置。对于UDP套接字,远程主机无法传送先前发送的UDP数据报,并使用“端口无法访问”ICMP数据包进行响应。应用程序应关闭套接字,因为它不再可用。"));
  97. }
  98. else if (dwError == WSAETIMEDOUT)
  99. {//由于网络故障或另一端的系统在没有通知的情况下发生故障,连接已被丢弃。
  100. bReConnect = true;
  101. //Global::WriteTextLog(_T("由于超时或其他故障,虚电路终止。应用程序应关闭套接字,因为它不再可用。"));
  102. }
  103. if (bReConnect)
  104. {
  105. disconnect();
  106. Connect(m_ip, m_port);
  107. }
  108. }
  109. bool Send(std::string s_data)
  110. {
  111. TCHAR szLogMsg[BUF_LEN] = {0};
  112. //CString date = CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));
  113. _stprintf_s(szLogMsg,
  114. _T("{\"ReportType\":\"printLog\",\"prinMsg\":\"%s %s\"}"),
  115. CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S ")).GetString(), s_data.c_str());
  116. if (m_sock == INVALID_SOCKET)
  117. {
  118. //Global::WriteTextLog(_T("SOCKET未创建, 请创建并连接服务器"));
  119. return false;
  120. }
  121. // 向服务器发送数据;
  122. int nRet = send(m_sock, szLogMsg, _tcslen(szLogMsg)*sizeof(TCHAR), 0);
  123. if (nRet < 0)
  124. {
  125. DWORD dwError = WSAGetLastError();
  126. //Global::WriteTextLog(_T("发送数据失败:%d"), dwError);
  127. ReConnect(dwError);
  128. return false;
  129. }
  130. return true;
  131. }
  132. };
  133. int main()
  134. {
  135. int nRetCode = 0;
  136. HMODULE hModule = ::GetModuleHandle(nullptr);
  137. if (hModule != nullptr)
  138. {
  139. // 初始化 MFC 并在失败时显示错误
  140. if (!AfxWinInit(hModule, nullptr, ::GetCommandLine(), 0))
  141. {
  142. // TODO: 在此处为应用程序的行为编写代码。
  143. wprintf(L"错误: MFC 初始化失败\n");
  144. nRetCode = 1;
  145. }
  146. else
  147. {
  148. #if 0 // 验证logModule多线程下写日志是否线程安全;
  149. for ( int i = 0; i < 20; i++ )
  150. {
  151. // 创建10个线程;
  152. std::thread t([]() {
  153. TCHAR szLogMsg[1024] = {0};
  154. _stprintf_s(szLogMsg, _T("多线程抢占文件句柄:%ld"), (unsigned int)&std::this_thread::get_id());
  155. logClient log;
  156. if (log.InitSocket())
  157. {
  158. if ( log.Connect("127.0.0.1", 10006) )
  159. {
  160. while (true)
  161. {
  162. Sleep(20);
  163. log.Send(szLogMsg);
  164. }
  165. }
  166. }
  167. });
  168. t.detach();
  169. }
  170. system("pause");
  171. return 0;
  172. #endif
  173. if (LoadLogLibarary())
  174. {
  175. g_CloseApp();
  176. // 启动服务;
  177. if (g_IsAppRunning(_T("C:\\Python27\\Tools\\RedRatHub-V4.28\\RedRatHubCmd.exe")) )
  178. TRACE("启动红老鼠进程已运行\r");
  179. else
  180. {
  181. TRACE("启动红老鼠进程未运行\r");
  182. if (g_StartIRApp(_T("C:\\Python27\\Tools\\RedRatHub-V4.28\\RedRatHubCmd.exe"), _T("C:\\Python27\\Tools\\RedRatHub-V4.28\\DeviceDB.xml"), 40000))
  183. {
  184. TRACE("启动红老鼠进程启动成功\r");
  185. }
  186. else
  187. {
  188. TRACE("启动红老鼠进程启动失败\r");
  189. }
  190. }
  191. Sleep(5000); // 等待进程启动完全;
  192. // 连接服务器;
  193. if (!g_Connect(_T("127.0.0.1"), 40000))
  194. return 0;
  195. // 获取设备列表,以逗号分隔;
  196. std::string devices = g_getDeviceNames();
  197. // 加载指定目录的xml信号集文件;
  198. if ( !g_loadSignalDataSet("D:\\SAT\\resource\\RCU\\product\\ARTEL_WZ_RC311_2841.xml") )
  199. {
  200. TRACE("加载信号集文件失败\r");
  201. }
  202. else
  203. {
  204. TRACE("加载信号集文件成功\r");
  205. }
  206. Sleep(500);
  207. // 获取信号数据集,以\n分隔;
  208. std::string signals = g_getSignalsName();
  209. TRACE(signals.c_str());
  210. // 发送单信号;
  211. if ( g_sendSignal("HOME", 1, 1000) )
  212. {
  213. TRACE("发送单信号成功\n");
  214. }
  215. else
  216. {
  217. TRACE("发送单信号失败\n");
  218. }
  219. // 发送多信号;
  220. if (g_sendSignals("HOME;right;right;down;up;HOME", 2))
  221. {
  222. TRACE("发送多信号成功\n");
  223. }
  224. else
  225. {
  226. TRACE("发送多信号失败\n");
  227. }
  228. // 发送重复信号;//重复信号必须小于256
  229. if (g_sendRepeatsSignal("right", 2))
  230. {
  231. TRACE("发送多信号成功\n");
  232. }
  233. else
  234. {
  235. TRACE("发送多信号失败\n");
  236. }
  237. g_CloseApp();
  238. FreeLogLibarary();
  239. }
  240. }
  241. }
  242. else
  243. {
  244. // TODO: 更改错误代码以符合需要
  245. wprintf(L"错误: GetModuleHandle 失败\n");
  246. nRetCode = 1;
  247. }
  248. return nRetCode;
  249. }