lyfzSMSHandle.cpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. // lyfzSMSHandle.cpp : 定义应用程序的类行为。
  2. //
  3. #include "stdafx.h"
  4. #include "lyfzSMSHandle.h"
  5. #include "lyfzSMSHandleDlg.h"
  6. #include "Global.h"
  7. #ifdef _DEBUG
  8. #define new DEBUG_NEW
  9. #endif
  10. HANDLE g_hMutex = NULL; // 全局互斥量;
  11. // ClyfzSMSHandleApp
  12. BEGIN_MESSAGE_MAP(ClyfzSMSHandleApp, CWinAppEx)
  13. ON_COMMAND(ID_HELP, &CWinApp::OnHelp)
  14. END_MESSAGE_MAP()
  15. // ClyfzSMSHandleApp 构造
  16. ClyfzSMSHandleApp::ClyfzSMSHandleApp()
  17. {
  18. // TODO: 在此处添加构造代码,
  19. // 将所有重要的初始化放置在 InitInstance 中
  20. }
  21. // 唯一的一个 ClyfzSMSHandleApp 对象
  22. ClyfzSMSHandleApp theApp;
  23. // ClyfzSMSHandleApp 初始化
  24. BOOL ClyfzSMSHandleApp::InitInstance()
  25. {
  26. g_hMutex = ::CreateMutex(NULL,FALSE,_T("lyfzSMSHandle"));
  27. if( GetLastError() == ERROR_ALREADY_EXISTS )
  28. {
  29. ::MessageBox(NULL,_T("短信处理程序已经打开!"),_T("温馨提示"),MB_ICONINFORMATION);
  30. return FALSE;
  31. }
  32. // 如果一个运行在 Windows XP 上的应用程序清单指定要
  33. // 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
  34. //则需要 InitCommonControlsEx()。否则,将无法创建窗口。
  35. INITCOMMONCONTROLSEX InitCtrls;
  36. InitCtrls.dwSize = sizeof(InitCtrls);
  37. // 将它设置为包括所有要在应用程序中使用的
  38. // 公共控件类。
  39. InitCtrls.dwICC = ICC_WIN95_CLASSES;
  40. InitCommonControlsEx(&InitCtrls);
  41. CWinAppEx::InitInstance();
  42. AfxEnableControlContainer();
  43. /************************************************************************/
  44. TCHAR szDrive[_MAX_DRIVE];
  45. TCHAR szDir[_MAX_DIR];
  46. ::GetModuleFileName(NULL, g_szModulePath, sizeof(g_szModulePath)/sizeof(TCHAR));
  47. _stprintf_s(g_szModuleFileName,_T("%s"),g_szModulePath);
  48. _tsplitpath(g_szModulePath, szDrive, szDir, NULL, NULL);
  49. _tcscpy_s(g_szModulePath, szDrive);
  50. _tcscat_s(g_szModulePath, szDir);
  51. //strPath = CString(szFull);
  52. char szFileName[MAX_PATH];
  53. #ifdef UNICODE
  54. sprintf_s(szFileName, "%sSMSlogcfg.xml", CW2A(g_szModulePath));
  55. #else
  56. sprintf_s(szFileName, "%sSMSlogcfg.xml", g_szModulePath);
  57. #endif
  58. ///设置日志配置文件名
  59. LOG4C_PARAM_CFG_FILE_NAME(szFileName);
  60. ///设置日志名;
  61. LOG4C_PARAM_LOG_FILE_NAME("SMSlog");
  62. ///设置日志级别
  63. LOG4C_PARAM_LOG_LEVEL("unknown");
  64. ///设置日志文件大小
  65. LOG4C_PARAM_LOG_FILE_SIZE(2097152); //5M大小;
  66. ///设置生成日志文件个数,达到最大个数将自动覆盖最旧的日志
  67. LOG4C_PARAM_LOG_FILE_NUM(10);
  68. ///设置每次记录日志都重新读取日志配置文件
  69. LOG4C_PARAM_REREAD_LOG_CFG_FILE(1);
  70. ///带参数日志模块初始化,以上所有设置了的参数都将生效,没有设置的采用缺省值
  71. LOG4C_INIT_WITH_PARAM();
  72. LOG4C_NO_FILENUM((LOG_NOTICE,"启动log日志"));
  73. /************************************************************************/
  74. // 标准初始化
  75. // 如果未使用这些功能并希望减小
  76. // 最终可执行文件的大小,则应移除下列
  77. // 不需要的特定初始化例程
  78. // 更改用于存储设置的注册表项
  79. // TODO: 应适当修改该字符串,
  80. // 例如修改为公司或组织名
  81. SetRegistryKey(_T("应用程序向导生成的本地应用程序"));
  82. #if JEFF_TEST_ON
  83. if(GetSysIniInfo() == -1)
  84. {
  85. // 若没有找到Server.ini文件,则默认没有放在DBServer.exe所有的主机上;
  86. if ( GetSysIniInfo2() == -1)
  87. {
  88. AfxMessageBox(_T("没有找到配置文件"));
  89. return FALSE;
  90. }
  91. // 配置加密狗类型;
  92. g_nVersion = g_dwEncryType;
  93. }
  94. else
  95. {
  96. _tcscpy_s(g_szSMSServer,_T("liyafangzhou.eicp.net"));
  97. g_dwTCPSMSPort = 8600;
  98. if(GetSoftWareVersion() == -1)
  99. {
  100. AfxMessageBox(_T("没有找到加密狗,请确认是否有加密狗!"));
  101. return FALSE;
  102. }
  103. }
  104. WSADATA WSAData = { 0 };
  105. if(0 != WSAStartup(MAKEWORD(2, 2), &WSAData))
  106. {
  107. AfxMessageBox(_T("网络环境初始化失败!"));
  108. return FALSE;
  109. }
  110. else
  111. {
  112. DWORD dwServerIP = 0;
  113. #ifdef UNICODE
  114. char szHost[MAX_PATH] = {0};
  115. strcpy_s(szHost,CW2A(g_szSMSServer));
  116. HOSTENT *host = gethostbyname(szHost); // Jeff.所有本机的网络适配器;
  117. #else
  118. HOSTENT *host = gethostbyname(g_szSMSServer); // Jeff.所有本机的网络适配器;
  119. #endif
  120. struct in_addr addr;
  121. if (host != NULL)
  122. {
  123. // Jeff.遍历本机所有适配器的IP地址;
  124. CString strSvrIP = _T("");
  125. for (int i = 0; host->h_addr_list[i] != NULL; i++)
  126. {
  127. memset(&addr, 0, sizeof(addr));
  128. memcpy(&addr.S_un.S_addr, host->h_addr_list[i], host->h_length);
  129. dwServerIP = ntohl(addr.S_un.S_addr);
  130. BYTE* pIP = (BYTE*)&dwServerIP;
  131. g_strServerIP.Format(_T("%d.%d.%d.%d"), pIP[3], pIP[2], pIP[1], pIP[0]);
  132. #ifdef UNICODE
  133. LOG4C_NO_FILENUM((LOG_NOTICE,"域名IP:%s",(char*)CW2A(g_strServerIP)));
  134. #else
  135. LOG4C_NO_FILENUM((LOG_NOTICE,"域名IP:%s",g_strServerIP));
  136. #endif
  137. break;
  138. }
  139. }
  140. else
  141. {
  142. LOG4C_NO_FILENUM((LOG_NOTICE,"DNS服务器解析域名IP失败,有可能是服务器DNS异常,请使用360等工具修复!"));
  143. }
  144. }
  145. #endif
  146. ClyfzSMSHandleDlg dlg;
  147. m_pMainWnd = &dlg;
  148. INT_PTR nResponse = dlg.DoModal();
  149. if (nResponse == IDOK)
  150. {
  151. // TODO: 在此放置处理何时用
  152. // “确定”来关闭对话框的代码
  153. }
  154. else if (nResponse == IDCANCEL)
  155. {
  156. // TODO: 在此放置处理何时用
  157. // “取消”来关闭对话框的代码
  158. }
  159. // 由于对话框已关闭,所以将返回 FALSE 以便退出应用程序,
  160. // 而不是启动应用程序的消息泵。
  161. return FALSE;
  162. }
  163. int ClyfzSMSHandleApp::ExitInstance()
  164. {
  165. // TODO: 在此添加专用代码和/或调用基类
  166. LOG4C_NO_FILENUM((LOG_NOTICE,"退出log日志"));
  167. LOG4C_FINI();
  168. CloseHandle(g_hMutex);
  169. return CWinAppEx::ExitInstance();
  170. }