SATService.cpp 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. // SATService.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #include "SATService.h"
  5. #include "SATExecutor.h"
  6. #include "SATDevices.h"
  7. #include "SATTCPServer.h"
  8. #ifdef _DEBUG
  9. #define new DEBUG_NEW
  10. #endif
  11. // 唯一的应用程序对象
  12. CWinApp theApp;
  13. using namespace std;
  14. extern int test();
  15. // 工作启动回调函数;
  16. void CALLBACK WorkStart()
  17. {
  18. WindowsService::GetDebugPriv();
  19. // 启用SAT执行器;
  20. CSATExecutor::GetInstance()->StartWork();
  21. // 启动SAT TCP服务端;
  22. CSATTCPServer::GetInstance()->LoadSocketLib();
  23. CSATTCPServer::GetInstance()->Start(GLOBAL::g_stSATConfig.dwTCPSvrPort);
  24. // 启动设备扫描器;
  25. CSATDevices::GetInstance()->StartWork();
  26. }
  27. // 工作结束回调函数;
  28. void CALLBACK WorkEndof()
  29. {
  30. GLOBAL::WriteTextLog(GLOBAL::SAT_NOR, "SATService goto end");
  31. CSATTCPServer::GetInstance()->Stop();
  32. CSATTCPServer::GetInstance()->UnloadSocketLib();
  33. CSATDevices::GetInstance()->EndofWork();
  34. CSATExecutor::GetInstance()->EndofWork();
  35. GLOBAL::WriteTextLog(GLOBAL::SAT_NOR, "SATService work end!");
  36. }
  37. int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
  38. {
  39. int nRetCode = 0;
  40. // 直接获得前景窗口的句柄;
  41. HWND hwnd = GetForegroundWindow();
  42. SendMessage(hwnd , WM_SETICON, ICON_SMALL, (LPARAM)LoadIcon(NULL,MAKEINTRESOURCE(IDI_MICON)));
  43. HMODULE hModule = ::GetModuleHandle(NULL);
  44. // 初始化 MFC 并在失败时显示错误
  45. if (!AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0))
  46. {
  47. // TODO: 更改错误代码以符合您的需要
  48. _tprintf(_T("错误: MFC 初始化失败\n"));
  49. nRetCode = 1;
  50. }
  51. else
  52. {
  53. // TODO: 在此处为应用程序的行为编写代码。
  54. GLOBAL::GetIniInfo();
  55. //GLOBAL::Python27Dir(); // 放到GetIniInfo中执行;
  56. GLOBAL::GetMacAddress();
  57. GLOBAL::GetLocalAddress();
  58. GLOBAL::WriteTextLog(GLOBAL::SAT_TCP, "SATService goto start, tcp port = %ld", GLOBAL::g_stSATConfig.dwTCPSvrPort);
  59. #if defined RTEST || defined _DEBUG
  60. printf("服务端TCP端口号=%ld\n", GLOBAL::g_stSATConfig.dwTCPSvrPort);
  61. WorkStart();
  62. // 指定时间停止;
  63. ULONGLONG ulTickCount = GetTickCount64();
  64. while (GetTickCount64() - ulTickCount < 1800000 )
  65. //while(1)
  66. {
  67. //printf("倒计时:%ld\n",GetTickCount64() - ulTickCount);
  68. Sleep(1000);
  69. }
  70. // 关闭TCP服务;
  71. WorkEndof();
  72. return 0;
  73. #endif
  74. // 进程存在,直接退出;
  75. TCHAR szExeName[MAX_PATH] = {0};
  76. TCHAR szDrive[_MAX_DRIVE] = { 0 };
  77. TCHAR szDir[_MAX_DIR] = { 0 };
  78. TCHAR szFna[_MAX_FNAME] = { 0 };
  79. TCHAR szExt[_MAX_EXT] = { 0 };
  80. _tsplitpath_s(GLOBAL::g_szCurModuleFileName, szDrive, szDir, szFna, szExt);
  81. _stprintf_s(szExeName, _T("%s%s"), szFna, szExt);
  82. if ( GLOBAL::FindProcessCount(szExeName) > 1)
  83. {// 进程计数大于1,退出;
  84. return 0;
  85. }
  86. // 设置服务名和描述;
  87. _stprintf_s(WindowsService::g_szSvcName, _T("SAT Service"));
  88. _stprintf_s(WindowsService::g_szlpSvrDescription, _T("SAT自动化服务"));
  89. // 1.先判断服务是否存在;
  90. if ( WindowsService::IsSvcInstalled())
  91. {
  92. // 卸载服务;
  93. if ( argc > 1)
  94. {
  95. if (_tcscmp((TCHAR *)argv[1], _T("/uninstall")) == 0)
  96. WindowsService::DoDeleteSvc(WindowsService::g_szSvcName);
  97. else
  98. _tprintf_s(_T("未有卸载服务参数行\n"));
  99. return 0;
  100. }
  101. else
  102. {
  103. WindowsService::InitSvcVar();
  104. WindowsService::SetCallBack(WorkStart, WorkEndof);
  105. SERVICE_TABLE_ENTRY st[] =
  106. {
  107. { WindowsService::g_szSvcName, (LPSERVICE_MAIN_FUNCTION)WindowsService::ServiceMain },
  108. { NULL, NULL }
  109. };
  110. if (!::StartServiceCtrlDispatcher(st)) // 在直接双击.exe时,这步会运行失败;
  111. {
  112. //LOG4C((LOG_NOTICE,"服务已安装,须系统运行控制"));
  113. WindowsService::SvcReportEvent(_T("Register Service Main Function Error!"));
  114. return 0;
  115. }
  116. }
  117. }
  118. // 2.不存在,安装服务;
  119. WindowsService::InitSvcVar();
  120. #if 0 // 若服务不存在,无须执行主程序;
  121. WindowsService::SetCallBack(WorkStart, WorkEndof);
  122. SERVICE_TABLE_ENTRY st[] =
  123. {
  124. { WindowsService::g_szSvcName, (LPSERVICE_MAIN_FUNCTION)WindowsService::ServiceMain },
  125. { NULL, NULL }
  126. };
  127. #endif
  128. WindowsService::SvcInstall();
  129. }
  130. return nRetCode;
  131. }