123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 |
- // 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(GetSysIniInfo() == -1)
- {
- // 若没有找到Server.ini文件,则默认没有放在DBServer.exe所有的主机上;
- if ( GetSysIniInfo2() == -1)
- {
- AfxMessageBox(_T("没有找到配置文件"));
- return FALSE;
- }
- // 配置加密狗类型;
- g_nVersion = g_dwEncryType;
- }
- if(GetSoftWareVersion() == -1)
- {
- AfxMessageBox(_T("没有找到加密狗,请确认是否有加密狗!"));
- return FALSE;
- }
- #ifndef NONE
- BOOL bValue = FALSE;
- for (BYTE i = 1; i < 255; i++)
- {
- if ( 0 == SMSProcess::SMS_INIT(
- i, // 串口号;
- 9600, // 波特率;
- 8, // 数据位;
- 0, // 校验码;
- 1, // 停止位;
- 1, // 起始地址;
- 1000, // 间隔时间;
- 70)) // 短信猫一条短信最大支持的字符个数;
- {
- bValue = TRUE;
- break;
- }
- Sleep(100);
- }
- if ( bValue == FALSE )
- {
- AfxMessageBox(_T("未找到任务短信猫设计"));
- return FALSE;
- }
- LOG4C_NO_FILENUM((LOG_NOTICE, "打开短信猫成功"));
- #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();
- }
|