// lyfzSMSHandle.cpp : 定义应用程序的类行为。 // #include "stdafx.h" #include "lyfzSMSHandle.h" #include "lyfzSMSHandleDlg.h" #include "Global.h" #ifdef _DEBUG #define new DEBUG_NEW #endif HANDLE g_hMutex = NULL; // 全局互斥量; // ClyfzSMSHandleApp BEGIN_MESSAGE_MAP(ClyfzSMSHandleApp, CWinAppEx) ON_COMMAND(ID_HELP, &CWinApp::OnHelp) END_MESSAGE_MAP() // ClyfzSMSHandleApp 构造 ClyfzSMSHandleApp::ClyfzSMSHandleApp() { // TODO: 在此处添加构造代码, // 将所有重要的初始化放置在 InitInstance 中 } // 唯一的一个 ClyfzSMSHandleApp 对象 ClyfzSMSHandleApp theApp; // ClyfzSMSHandleApp 初始化 BOOL ClyfzSMSHandleApp::InitInstance() { g_hMutex = ::CreateMutex(NULL,FALSE,_T("lyfzSMSHandle")); if( GetLastError() == ERROR_ALREADY_EXISTS ) { ::MessageBox(NULL,_T("短信处理程序已经打开!"),_T("温馨提示"),MB_ICONINFORMATION); return FALSE; } // 如果一个运行在 Windows XP 上的应用程序清单指定要 // 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式, //则需要 InitCommonControlsEx()。否则,将无法创建窗口。 INITCOMMONCONTROLSEX InitCtrls; InitCtrls.dwSize = sizeof(InitCtrls); // 将它设置为包括所有要在应用程序中使用的 // 公共控件类。 InitCtrls.dwICC = ICC_WIN95_CLASSES; InitCommonControlsEx(&InitCtrls); CWinAppEx::InitInstance(); AfxEnableControlContainer(); /************************************************************************/ TCHAR szDrive[_MAX_DRIVE]; TCHAR szDir[_MAX_DIR]; ::GetModuleFileName(NULL, g_szModulePath, sizeof(g_szModulePath)/sizeof(TCHAR)); _stprintf_s(g_szModuleFileName,_T("%s"),g_szModulePath); _tsplitpath(g_szModulePath, szDrive, szDir, NULL, NULL); _tcscpy_s(g_szModulePath, szDrive); _tcscat_s(g_szModulePath, szDir); //strPath = CString(szFull); char szFileName[MAX_PATH]; #ifdef UNICODE sprintf_s(szFileName, "%sSMSlogcfg.xml", CW2A(g_szModulePath)); #else sprintf_s(szFileName, "%sSMSlogcfg.xml", g_szModulePath); #endif ///设置日志配置文件名 LOG4C_PARAM_CFG_FILE_NAME(szFileName); ///设置日志名; LOG4C_PARAM_LOG_FILE_NAME("SMSlog"); ///设置日志级别 LOG4C_PARAM_LOG_LEVEL("unknown"); ///设置日志文件大小 LOG4C_PARAM_LOG_FILE_SIZE(2097152); //5M大小; ///设置生成日志文件个数,达到最大个数将自动覆盖最旧的日志 LOG4C_PARAM_LOG_FILE_NUM(10); ///设置每次记录日志都重新读取日志配置文件 LOG4C_PARAM_REREAD_LOG_CFG_FILE(1); ///带参数日志模块初始化,以上所有设置了的参数都将生效,没有设置的采用缺省值 LOG4C_INIT_WITH_PARAM(); LOG4C_NO_FILENUM((LOG_NOTICE,"启动log日志")); /************************************************************************/ // 标准初始化 // 如果未使用这些功能并希望减小 // 最终可执行文件的大小,则应移除下列 // 不需要的特定初始化例程 // 更改用于存储设置的注册表项 // TODO: 应适当修改该字符串, // 例如修改为公司或组织名 SetRegistryKey(_T("应用程序向导生成的本地应用程序")); #if JEFF_TEST_ON if(GetSysIniInfo() == -1) { // 若没有找到Server.ini文件,则默认没有放在DBServer.exe所有的主机上; if ( GetSysIniInfo2() == -1) { AfxMessageBox(_T("没有找到配置文件")); return FALSE; } // 配置加密狗类型; g_nVersion = g_dwEncryType; } else { _tcscpy_s(g_szSMSServer,_T("liyafangzhou.eicp.net")); g_dwTCPSMSPort = 8600; if(GetSoftWareVersion() == -1) { AfxMessageBox(_T("没有找到加密狗,请确认是否有加密狗!")); return FALSE; } } WSADATA WSAData = { 0 }; if(0 != WSAStartup(MAKEWORD(2, 2), &WSAData)) { AfxMessageBox(_T("网络环境初始化失败!")); return FALSE; } else { DWORD dwServerIP = 0; #ifdef UNICODE char szHost[MAX_PATH] = {0}; strcpy_s(szHost,CW2A(g_szSMSServer)); HOSTENT *host = gethostbyname(szHost); // Jeff.所有本机的网络适配器; #else HOSTENT *host = gethostbyname(g_szSMSServer); // Jeff.所有本机的网络适配器; #endif struct in_addr addr; if (host != NULL) { // Jeff.遍历本机所有适配器的IP地址; CString strSvrIP = _T(""); for (int i = 0; host->h_addr_list[i] != NULL; i++) { memset(&addr, 0, sizeof(addr)); memcpy(&addr.S_un.S_addr, host->h_addr_list[i], host->h_length); dwServerIP = ntohl(addr.S_un.S_addr); BYTE* pIP = (BYTE*)&dwServerIP; g_strServerIP.Format(_T("%d.%d.%d.%d"), pIP[3], pIP[2], pIP[1], pIP[0]); #ifdef UNICODE LOG4C_NO_FILENUM((LOG_NOTICE,"域名IP:%s",(char*)CW2A(g_strServerIP))); #else LOG4C_NO_FILENUM((LOG_NOTICE,"域名IP:%s",g_strServerIP)); #endif break; } } else { LOG4C_NO_FILENUM((LOG_NOTICE,"DNS服务器解析域名IP失败,有可能是服务器DNS异常,请使用360等工具修复!")); } } #endif ClyfzSMSHandleDlg dlg; m_pMainWnd = &dlg; INT_PTR nResponse = dlg.DoModal(); if (nResponse == IDOK) { // TODO: 在此放置处理何时用 // “确定”来关闭对话框的代码 } else if (nResponse == IDCANCEL) { // TODO: 在此放置处理何时用 // “取消”来关闭对话框的代码 } // 由于对话框已关闭,所以将返回 FALSE 以便退出应用程序, // 而不是启动应用程序的消息泵。 return FALSE; } int ClyfzSMSHandleApp::ExitInstance() { // TODO: 在此添加专用代码和/或调用基类 LOG4C_NO_FILENUM((LOG_NOTICE,"退出log日志")); LOG4C_FINI(); CloseHandle(g_hMutex); return CWinAppEx::ExitInstance(); }