IDE.cpp 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790
  1. // IDE.cpp : 定义应用程序的类行为。
  2. //
  3. #include "stdafx.h"
  4. //#include <vld.h>
  5. #include "IDE.h"
  6. #include "MainFrm.h"
  7. #include "ChildFrm.h"
  8. #include "IDEDoc.h"
  9. #include "IDEView.h"
  10. #include "SysLib.h"
  11. #include ".\ide.h"
  12. #include "StartupDlg.h"
  13. #include "Login.h"
  14. #include "gooddc.h"
  15. #include "public.h"
  16. #include "md5class.h"
  17. //#include "conv.h"
  18. #ifdef _DEBUG
  19. #define new DEBUG_NEW
  20. #endif
  21. HANDLE g_hScriptThread = NULL; //线程对象
  22. #if IS_MULTHREAD_REQUEST
  23. HANDLE *g_pFreshVarThread = NULL;
  24. #else
  25. HANDLE g_hFreshVarThread = NULL;
  26. HANDLE g_hFreshVarCurPicThread = NULL;
  27. #endif
  28. HANDLE g_hReConnectSrvThread = NULL;
  29. INT g_nFreshVarThreadCount = 0;
  30. DWORD WINAPI FreshVarThread( void *pData );
  31. DWORD WINAPI FreshVarCurPicThread( void *pData );
  32. DWORD WINAPI ReConnectSrvThread( void *pData );
  33. extern CRITICAL_SECTION g_CSLimit;
  34. // CIDEApp
  35. BEGIN_MESSAGE_MAP(CIDEApp, CWinApp)
  36. ON_COMMAND(ID_APP_ABOUT, OnAppAbout)
  37. // 基于文件的标准文档命令
  38. ON_COMMAND(ID_FILE_NEW, CWinApp::OnFileNew)
  39. ON_COMMAND(ID_FILE_OPEN, CWinApp::OnFileOpen)
  40. // 标准打印设置命令
  41. ON_COMMAND(ID_FILE_PRINT_SETUP, CWinApp::OnFilePrintSetup)
  42. ON_COMMAND(ID_APP_EXIT, OnAppExit)
  43. END_MESSAGE_MAP()
  44. // CIDEApp 构造
  45. CIDEApp::CIDEApp()
  46. {
  47. // TODO: 在此处添加构造代码,
  48. // 将所有重要的初始化放置在 InitInstance 中
  49. }
  50. // 唯一的一个 CIDEApp 对象
  51. CIDEApp theApp;
  52. CMainFrame *g_pMainFrm = NULL;
  53. int InitClientTTS()
  54. {
  55. CHAR strFile[MAX_FILE_LENGTH + 1] = "";
  56. wsprintf(strFile, "%s\\TTSDll.dll", g_strDirectory);
  57. //wsprintf(strFile, "E:\\Work\\version\\new_server\\dll\\TTSDll.dll");
  58. g_hTTSModule = AfxLoadLibrary(strFile);
  59. if (NULL != g_hTTSModule)
  60. {
  61. pStoneUDllRegisterTTS = (MySTONEU_DLLRegisterTTS)::GetProcAddress(g_hTTSModule, "STONEU_DLLRegisterTTS");
  62. pStoneUDllUnRegisterTTS = (MySTONEU_DLLUnRegisterTTS)::GetProcAddress(g_hTTSModule, "STONEU_DLLUnRegisterTTS");
  63. pStoneUDLLTxtToWav = (MySTONEU_DLLTxtToWav)::GetProcAddress(g_hTTSModule, "STONEU_DLLTxtToWav");
  64. }
  65. if( ( NULL != g_hTTSModule ) && ( NULL != pStoneUDllRegisterTTS ) )
  66. {
  67. pStoneUDllRegisterTTS();
  68. }
  69. else
  70. {
  71. FreeLibrary( g_hTTSModule );
  72. g_hTTSModule = NULL;
  73. }
  74. return 0;
  75. }
  76. int UnInitClientTTS()
  77. {
  78. if( NULL != g_hTTSModule && NULL != pStoneUDllUnRegisterTTS )
  79. {
  80. pStoneUDllUnRegisterTTS();
  81. AfxFreeLibrary( g_hTTSModule );
  82. g_hTTSModule = NULL;
  83. }
  84. return 0;
  85. }
  86. // CIDEApp 初始化
  87. HANDLE hMutex;
  88. BOOL CIDEApp::InitInstance()
  89. {
  90. // 如果一个运行在 Windows XP 上的应用程序清单指定要
  91. // 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
  92. //则需要 InitCommonControls()。否则,将无法创建窗口。
  93. CString StrName="Runner Monitor";
  94. hMutex=OpenMutex(MUTEX_ALL_ACCESS,FALSE,StrName);
  95. if(hMutex==NULL)
  96. {
  97. hMutex=::CreateMutex(NULL,NULL,StrName);
  98. }
  99. else
  100. {
  101. MessageBox(NULL,"运行器已经打开!","温馨提示",MB_ICONINFORMATION);
  102. return FALSE;
  103. }
  104. InitializeCriticalSection(&g_CSLimit);
  105. InitCommonControls();
  106. CoInitialize( NULL );
  107. CWinApp::InitInstance();
  108. //// 初始化 OLE 库
  109. if (!AfxOleInit())
  110. {
  111. AfxMessageBox(IDP_OLE_INIT_FAILED);
  112. return FALSE;
  113. }
  114. AfxEnableControlContainer();
  115. // 标准初始化
  116. // 如果未使用这些功能并希望减小
  117. // 最终可执行文件的大小,则应移除下列
  118. // 不需要的特定初始化例程
  119. // 更改用于存储设置的注册表项
  120. // TODO: 应适当修改该字符串,
  121. // 例如修改为公司或组织名
  122. SetRegistryKey(g_strAppwizardCreateApp);
  123. LoadStdProfileSettings(4); // 加载标准 INI 文件选项(包括 MRU)
  124. // START GDI+ SUB SYSTEM
  125. GdiplusStartup(&m_gdiplusToken, &m_gdiplusStartupInput, NULL);
  126. MTVERIFY( g_hRunObject = ::CreateEvent(
  127. NULL, /* Security */
  128. TRUE, /* Manual event */
  129. 0, /* Clear on creation */
  130. 0 ));//"IDE::g_hRunObject") );
  131. //InitPrintQueue();
  132. GetSysData();
  133. if( !g_FindProcess( "ShortCut.exe" ) )
  134. {
  135. CString sTemp;
  136. sTemp = g_strDirectory;
  137. sTemp += "\\ShortCut.exe";//
  138. ShellExecute( NULL, NULL, sTemp,0,NULL, SW_SHOWNORMAL );
  139. }
  140. CString strFileName;
  141. strFileName.Format("%s\\log4crc", g_strDirectory);
  142. ///设置日志配置文件名
  143. LOG4C_PARAM_CFG_FILE_NAME(strFileName);
  144. ///设置日志级别
  145. LOG4C_PARAM_LOG_LEVEL("unknown");
  146. ///设置日志文件大小
  147. LOG4C_PARAM_LOG_FILE_SIZE(10240);
  148. ///设置生成日志文件个数,达到最大个数将自动覆盖最旧的日志
  149. LOG4C_PARAM_LOG_FILE_NUM(5);
  150. ///设置每次记录日志都重新读取日志配置文件
  151. LOG4C_PARAM_REREAD_LOG_CFG_FILE(1);
  152. ///带参数日志模块初始化,以上所有设置了的参数都将生效,没有设置的采用缺省值
  153. LOG4C_INIT_WITH_PARAM();
  154. LOG4C((LOG_NOTICE, "系统成功启动!"));
  155. LOG4C((LOG_NOTICE, "【ver:%s】",g_strVersion ));
  156. #if 0 // 已经去掉资源使用;
  157. CHAR strFile[MAX_FILE_LENGTH + 1] = "";
  158. if( strcmp(g_strLanguage, "CHS") == 0 )
  159. {
  160. //wsprintf(strFile, "%s\\ChineseRes.dll", g_strDirectory);
  161. wsprintf(strFile, "%s\\cn.dll", g_strDirectory);
  162. }
  163. else if( strcmp(g_strLanguage, "CHT") == 0 )
  164. {
  165. wsprintf(strFile, "%s\\TaiwanRes.dll", g_strDirectory);
  166. }
  167. else if( strcmp(g_strLanguage, "ENG") == 0 )
  168. {
  169. wsprintf(strFile, "%s\\EnglishRes.dll", g_strDirectory);
  170. }
  171. g_hLangDLL = ::LoadLibrary(strFile);
  172. AfxSetResourceHandle(g_hLangDLL);
  173. #endif
  174. GetResourceString();
  175. if( g_nIsDemo == 0 )
  176. {
  177. try
  178. {
  179. int nCount=0;
  180. while( 1 )
  181. {
  182. if( !CDBConnection::GetInstancePtr()->OpenDataBase(g_strConnectString) )
  183. {
  184. if( !g_iAutoRunSystem )
  185. {
  186. MessageBox(NULL,g_strMsgDBConnectionFail, g_strTip, MB_ICONWARNING);
  187. return FALSE;
  188. }
  189. if( nCount++>=50 )
  190. {
  191. MessageBox(NULL,g_strMsgDBConnectionFail, g_strTip, MB_ICONWARNING);
  192. return FALSE;
  193. }
  194. Sleep( 5000 );
  195. }
  196. else
  197. break;
  198. }
  199. CDBConnection::GetInstancePtr()->DBConnectionCheckThreadStart();
  200. CDBInterface::GetInstancePtr()->SetDBType(g_strDBType);
  201. }
  202. catch( ... )
  203. {
  204. CString str;
  205. str.Format( "连接数据库失败,可能原因是没有添加数据库 %s",g_strConnectString );
  206. MessageBox(NULL,str, g_strTip, MB_ICONWARNING);
  207. return FALSE;
  208. }
  209. }
  210. CStartupDlg dlg;
  211. dlg.Create(IDD_STARTUP);
  212. char* lpBmpFile = "Bitmap\\home.bmp";
  213. BITMAPFILEHEADER bf;
  214. BITMAPINFOHEADER bi;
  215. FILE* fp = fopen(lpBmpFile,"rb");
  216. if (fp)
  217. {
  218. fread(&bf,sizeof(bf),1,fp);
  219. fread(&bi,sizeof(bi),1,fp);
  220. fclose(fp);
  221. int nCX = GetSystemMetrics(SM_CXSCREEN);
  222. int nCY = GetSystemMetrics(SM_CYSCREEN);
  223. int nW = bi.biWidth;
  224. int nH = bi.biHeight;
  225. dlg.MoveWindow((nCX-nW)/2,(nCY-nH)/2,nW,nH);
  226. }
  227. dlg.ShowWindow(TRUE);
  228. CDC* pDC = dlg.GetDC();
  229. CRect rect;
  230. dlg.GetClientRect(rect);
  231. int screenx=GetSystemMetrics(SM_CXSCREEN);
  232. int screeny=GetSystemMetrics(SM_CYSCREEN);
  233. DisplayBMP(pDC, 0, 0, rect.Width(), rect.Height(), lpBmpFile, FALSE);
  234. dlg.ReleaseDC(pDC);
  235. Sleep(3000);
  236. dlg.ShowWindow(FALSE);
  237. PMS_InitSDK();
  238. CDBInterface::GetInstancePtr()->AddGroupToDll();
  239. CDBInterface::GetInstancePtr()->AddUserToDll();
  240. #if 0 // 暂时不使用登陆框 [8/29/2013 hero]
  241. if( g_nIsDemo == 0 )
  242. {
  243. // 登录
  244. //int nRet = IsNoDlgLogin();
  245. //if( nRet==-1 )
  246. {
  247. CLogin udlg;
  248. if( udlg.DoModal() != IDOK )
  249. {
  250. return FALSE;
  251. }
  252. CString sContent;
  253. sContent.Format("用戶< %s >登录",udlg.m_sUserID );
  254. CDBInterface::GetInstancePtr()->InsertLogRecord( LOG_LOGIN,0,"",(char *)(LPCTSTR)sContent );
  255. }
  256. }
  257. #else
  258. g_Login();
  259. #endif
  260. if( g_nIsDemo == 0 )
  261. {
  262. if( g_nAlarmModeIsSound == 1 )
  263. {
  264. InitClientTTS();
  265. }
  266. }
  267. // 注册应用程序的文档模板。文档模板
  268. // 将用作文档、框架窗口和视图之间的连接
  269. CMultiDocTemplate* pDocTemplate;
  270. pDocTemplate = new CMultiDocTemplate(IDR_MAINFRAME,
  271. RUNTIME_CLASS(CIDEDoc),
  272. RUNTIME_CLASS(CChildFrame), // 自定义 MDI 子框架
  273. RUNTIME_CLASS(CIDEView));
  274. AddDocTemplate(pDocTemplate);
  275. // 创建主 MDI 框架窗口
  276. CMainFrame* pMainFrame = new CMainFrame;
  277. pMainFrame->m_pDoc = (CIDEDoc *)pDocTemplate->CreateNewDocument();
  278. if ( !pMainFrame )
  279. {
  280. MessageBox(NULL,"pMainFrame == NULL", g_strTip, MB_ICONWARNING);
  281. return FALSE;
  282. }
  283. if ( !pMainFrame->LoadFrame(IDR_MAINFRAME) )
  284. {
  285. MessageBox(NULL,"资源文件不对1", g_strTip, MB_ICONWARNING);
  286. return FALSE;
  287. }
  288. m_pMainWnd = pMainFrame;
  289. // 仅当具有后缀时才调用 DragAcceptFiles
  290. // 在 MDI 应用程序中,这应在设置 m_pMainWnd 之后立即发生
  291. // 分析标准外壳命令、DDE、打开文件操作的命令行
  292. CCommandLineInfo cmdInfo;
  293. ParseCommandLine(cmdInfo);
  294. // 调度在命令行中指定的命令。如果
  295. // 用 /RegServer、/Register、/Unregserver 或 /Unregister 启动应用程序,则返回 FALSE。
  296. cmdInfo.m_nShellCommand = CCommandLineInfo::FileNothing;
  297. if (!ProcessShellCommand(cmdInfo))
  298. {
  299. MessageBox(NULL,"资源文件不对2", g_strTip, MB_ICONWARNING);
  300. return FALSE;
  301. }
  302. // 主窗口已初始化,因此显示它并对其进行更新
  303. m_pMainWnd->SetWindowText(g_strStoneuIspcms);
  304. pMainFrame->ShowWindow(m_nCmdShow);
  305. //if( g_bFullScreen )
  306. //{
  307. // m_pMainWnd->ShowWindow(SW_SHOWMAXIMIZED);//窗口最大化 关于全屏
  308. //}
  309. pMainFrame->UpdateWindow();
  310. g_pMainFrm = pMainFrame;
  311. if( g_nIsDemo == 0 && g_bStartRun==1 )
  312. {
  313. MTVERIFY( g_hFreshVarCurPicThread =
  314. ::CreateThread(
  315. NULL,
  316. 0,
  317. FreshVarCurPicThread,
  318. 0,
  319. 0,
  320. 0) );
  321. MTVERIFY( g_hReConnectSrvThread = ::CreateThread(NULL, 0, ReConnectSrvThread, 0, 0, 0) );
  322. DWORD thredid;
  323. g_hScriptThread = (HANDLE) ::CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)ScriptRunProc,NULL,0,&thredid); //脚本处理
  324. }
  325. return TRUE;
  326. }
  327. int CIDEApp::ExitInstance()
  328. {
  329. // TODO: 在此添加专用代码和/或调用基类
  330. LOG4C((LOG_NOTICE, "ExitInstance!"));
  331. GdiplusShutdown( m_gdiplusToken );
  332. if( g_hRunObject )
  333. MTVERIFY( SetEvent( g_hRunObject ) );
  334. if( pDevicesManager != NULL )
  335. {
  336. if( g_nIsDemo == 0 )
  337. {
  338. //if (g_bStartRun)
  339. {
  340. for( int iPortIndex=0;iPortIndex<2;iPortIndex++ )
  341. {
  342. CString sPortTemp;
  343. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  344. pDevicesManager->DisConnection(sPortTemp);
  345. }
  346. }
  347. }
  348. }
  349. if( g_nIsDemo == 0 )
  350. {
  351. if( g_nAlarmModeIsSound == 1 )
  352. {
  353. UnInitClientTTS();
  354. }
  355. if( g_hScriptThread != NULL )
  356. {
  357. if( g_hScriptThread )
  358. {
  359. MTVERIFY( WaitForSingleObject( g_hScriptThread, INFINITE ) != WAIT_FAILED );
  360. MTVERIFY( CloseHandle(g_hScriptThread) );
  361. }
  362. g_hScriptThread = NULL;
  363. // 清除脚本队列
  364. POSITION pos = g_ScriptParamList.GetHeadPosition();
  365. while (pos != NULL)
  366. {
  367. POSITION tmpPos = pos;
  368. ScriptParam* pScriptParam = g_ScriptParamList.GetNext( pos );
  369. g_ScriptParamList.RemoveAt( tmpPos );
  370. delete pScriptParam;
  371. }
  372. }
  373. #if IS_MULTHREAD_REQUEST
  374. for( int i = 0; i < g_nFreshVarThreadCount; i++ )
  375. {
  376. if( g_pFreshVarThread[i] != NULL )
  377. {
  378. MTVERIFY( WaitForSingleObject( g_pFreshVarThread[i], INFINITE ) != WAIT_FAILED );
  379. MTVERIFY( CloseHandle( g_pFreshVarThread[i] ) );
  380. g_pFreshVarThread[i] = NULL;
  381. }
  382. }
  383. if( g_pFreshVarThread )
  384. {
  385. delete []g_pFreshVarThread;
  386. g_pFreshVarThread = NULL;
  387. }
  388. #else
  389. if( g_hFreshVarThread != NULL )
  390. {
  391. MTVERIFY( WaitForSingleObject( g_hFreshVarThread, INFINITE ) != WAIT_FAILED );
  392. MTVERIFY( CloseHandle( g_hFreshVarThread ) );
  393. g_hFreshVarThread = NULL;
  394. }
  395. if( g_hFreshVarCurPicThread != NULL )
  396. {
  397. MTVERIFY( WaitForSingleObject( g_hFreshVarCurPicThread, INFINITE ) != WAIT_FAILED );
  398. MTVERIFY( CloseHandle( g_hFreshVarCurPicThread ) );
  399. g_hFreshVarCurPicThread = NULL;
  400. }
  401. #endif
  402. if( g_hReConnectSrvThread != NULL )
  403. {
  404. MTVERIFY( WaitForSingleObject( g_hReConnectSrvThread, INFINITE ) != WAIT_FAILED );
  405. MTVERIFY( CloseHandle( g_hReConnectSrvThread ) );
  406. g_hReConnectSrvThread = NULL;
  407. }
  408. }
  409. if( pDevicesManager != NULL )
  410. {
  411. //chn mem
  412. for( int iPortIndex=0;iPortIndex<2;iPortIndex++ )
  413. {
  414. CString sPortTemp;
  415. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  416. pDevicesManager->Release( sPortTemp );
  417. }
  418. delete pDevicesManager;
  419. pDevicesManager = NULL;
  420. }
  421. if( pVariantsManager != NULL )
  422. {
  423. delete pVariantsManager;
  424. pVariantsManager = NULL;
  425. }
  426. if( pEventServer != NULL )
  427. {
  428. delete pEventServer;
  429. pEventServer = NULL;
  430. }
  431. if( g_hRunObject )
  432. MTVERIFY( CloseHandle( g_hRunObject ) );
  433. //chn mem
  434. CDBInterface::GetInstancePtr()->Release();
  435. //UninitPrintQueue();
  436. //if( g_nIsDemo == 0 )
  437. {
  438. CDBConnection::GetInstancePtr()->DBConnectionCheckThreadStop();
  439. CDBConnection::GetInstancePtr()->CloseDataBase();
  440. //DBConnectionThreadEnd();
  441. //chn mem
  442. CDBConnection::GetInstancePtr()->Release();
  443. }
  444. if(g_hLangDLL)
  445. {
  446. AfxFreeLibrary(g_hLangDLL);
  447. }
  448. LOG4C((LOG_NOTICE, "系统成功退出!"));
  449. ///关闭日志模块防止内存/资源泄漏
  450. LOG4C_FINI();
  451. // Shutdown GDI+ subystem
  452. GdiplusShutdown(m_gdiplusToken);
  453. //释放权限所占的内存
  454. PMS_UnInitSDK();
  455. ::CloseHandle( hMutex );
  456. hMutex = NULL;
  457. DeleteCriticalSection( &g_CSLimit );
  458. CoUninitialize();
  459. return CWinApp::ExitInstance();
  460. }
  461. void CIDEApp::OnAppExit()
  462. {
  463. // TODO: 在此添加命令处理程序代码
  464. CMainFrame *pMainFrm=(CMainFrame*)m_pMainWnd;
  465. pMainFrm->m_nViewCount = 0;
  466. pMainFrm->OnSuperEnd();
  467. }
  468. // 用于应用程序“关于”菜单项的 CAboutDlg 对话框
  469. class CAboutDlg : public CDialog
  470. {
  471. public:
  472. CAboutDlg();
  473. // 对话框数据
  474. enum { IDD = IDD_ABOUTBOX };
  475. protected:
  476. virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
  477. // 实现
  478. protected:
  479. DECLARE_MESSAGE_MAP()
  480. public:
  481. virtual BOOL OnInitDialog();
  482. };
  483. CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
  484. {
  485. }
  486. void CAboutDlg::DoDataExchange(CDataExchange* pDX)
  487. {
  488. CDialog::DoDataExchange(pDX);
  489. }
  490. BOOL CAboutDlg::OnInitDialog()
  491. {
  492. CDialog::OnInitDialog();
  493. // TODO: 在此添加额外的初始化
  494. CString str;
  495. str.Format("【ver:%s】",g_strVersion );
  496. GetDlgItem(IDC_STA_VERSION)->SetWindowText(str);
  497. return TRUE; // return TRUE unless you set the focus to a control
  498. // 异常: OCX 属性页应返回 FALSE
  499. }
  500. BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
  501. END_MESSAGE_MAP()
  502. // 用于运行对话框的应用程序命令
  503. void CIDEApp::OnAppAbout()
  504. {
  505. CAboutDlg aboutDlg;
  506. aboutDlg.DoModal();
  507. }
  508. DWORD WINAPI FreshVarThread( void *pData )
  509. {
  510. #if IS_MULTHREAD_REQUEST
  511. CString strUid = CString((char *)pData);
  512. #else
  513. CString strUid = "";
  514. #endif
  515. do
  516. {
  517. if (g_bStartRun)
  518. {
  519. if( g_bRun )
  520. {
  521. //TRACE("设备Uid=%s\r\n", strUid);
  522. pVariantsManager->Fresh(strUid);
  523. }
  524. }
  525. Sleep(10);
  526. }while( WaitForSingleObject( g_hRunObject, 10L ) == WAIT_TIMEOUT );
  527. return 0;
  528. }
  529. //读取当前画面的变量
  530. DWORD WINAPI FreshVarCurPicThread( void *pData )
  531. {
  532. CString strUid = "";
  533. do
  534. {
  535. if (g_bStartRun)
  536. {
  537. if( g_bRun )
  538. {
  539. //TRACE("设备Uid=%s\r\n", strUid);
  540. //if( !pVariantsManager->m_bIsChangeView )
  541. //{
  542. // EnterCriticalSection( &g_CSLimit );
  543. pVariantsManager->FreshCurPic( );
  544. // LeaveCriticalSection( &g_CSLimit );
  545. //}
  546. }
  547. }
  548. Sleep(10);
  549. }while( WaitForSingleObject( g_hRunObject, 10L ) == WAIT_TIMEOUT );
  550. return 0;
  551. }
  552. DWORD WINAPI ReConnectSrvThread( void *pData )
  553. {
  554. do
  555. {
  556. //if (g_bStartRun)
  557. {
  558. for( int iPortIndex=0;iPortIndex<2;iPortIndex++ )
  559. {
  560. CString sPortTemp;
  561. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  562. if( FALSE == pDevicesManager->GetSocketStatus(sPortTemp) )
  563. {
  564. pVariantsManager->SetSysComunicationVar( 1.0 );
  565. if( pDevicesManager->GetOpenStatus(sPortTemp) == TRUE )
  566. {
  567. pDevicesManager->DisConnection(sPortTemp);
  568. }
  569. if( !pDevicesManager->Connection(g_strServerIP, sPortTemp) )
  570. {
  571. pDevicesManager->SetSocketStatus(FALSE,sPortTemp);
  572. }
  573. else
  574. {
  575. pVariantsManager->SetSysComunicationVar( 0.0 );
  576. pDevicesManager->SetSocketStatus(TRUE,sPortTemp);
  577. //从新连接上IOServer时清空报警列表
  578. if( iPortIndex==0 && g_pMainFrm->m_dlgEvent )
  579. {
  580. g_pMainFrm->m_dlgEvent->DeleteAllNotice();
  581. }
  582. if( iPortIndex==0 )
  583. pDevicesManager->GetServerVer( sPortTemp );
  584. }
  585. }
  586. }
  587. }
  588. //Sleep(2000);
  589. }while( WaitForSingleObject( g_hRunObject, 125L ) == WAIT_TIMEOUT );
  590. return 0;
  591. }
  592. // CIDEApp 消息处理程序
  593. int CIDEApp::IsNoDlgLogin()//自动登录 -1:不是 0:失败 1:成功
  594. {
  595. int nRet = -1;
  596. CHAR strFile[MAX_FILE_LENGTH + 1] = "";
  597. wsprintf(strFile, "%s\\set.ini", g_strDirectory);
  598. char RUN[MAX_PATH] = {0};
  599. memset(RUN, 0, sizeof(RUN));
  600. ////是否是没对话框登录
  601. //if ( GetPrivateProfileString("User", "NoDlgLogin","",RUN, 10, strFile) != 0)
  602. //{
  603. // if( RUN[0] == '0' )
  604. // return nRet;
  605. //}
  606. //WritePrivateProfileString("User", "NoDlgLogin", "0", strFile);
  607. if( g_iAutoRunSystem==0 )
  608. return nRet;
  609. GetPrivateProfileString("User", "UserID","", g_strLoginUserID,sizeof(g_strLoginUserID), strFile );
  610. memset(g_strDefaultUserID, 0, sizeof(g_strDefaultUserID) );
  611. strcpy(g_strDefaultUserID, g_strLoginUserID);
  612. GetPrivateProfileString("User", "UserPwd","", g_strLoginPwd,sizeof(g_strLoginPwd), strFile );
  613. memset(g_strDefaultUserPwd, 0, sizeof(g_strDefaultUserPwd) );
  614. strcpy(g_strDefaultUserPwd, g_strLoginPwd);
  615. CString sUserID,sUserPwd;
  616. sUserID = g_strLoginUserID;
  617. sUserPwd = g_strLoginPwd;
  618. if( sUserID=="" || sUserPwd=="" )
  619. return nRet;
  620. ///////////////////////////////////////////////////////////////////////////////
  621. char Path[_MAX_PATH] = {0};
  622. strcat(Path, g_strDirectory);
  623. strcat(Path,"\\");
  624. strcat(Path, _PROJECTDIR);
  625. strcat(Path,"\\");
  626. strcat(Path, "runpara.ini");
  627. //CString str;
  628. if ( GetPrivateProfileString("RUNPARA", "STARTRUN","",RUN, 10, Path) != 0)
  629. {
  630. g_bStartRun = (RUN[0] == '1' ? true:false);
  631. }
  632. if ( GetPrivateProfileString("RUNPARA", "FULLSCREEN","",RUN, 10, Path) != 0)
  633. {
  634. g_bFullScreen = RUN[0] == '1' ? true:false;
  635. }
  636. CMD5 md5;
  637. md5.setPlainText( (char *)(LPCTSTR)sUserPwd );
  638. if( ( ( strcmp(g_strDefaultUserPwd, "") != 0 ) && (strcmp(g_strLoginUserID, (char*)(LPCTSTR)sUserID) != 0 ) ) ||
  639. ( strcmp(g_strDefaultUserPwd, "") == 0 ) ||
  640. (strcmp(g_strLoginUserID, (char*)(LPCTSTR)sUserID) != 0 ) ||
  641. ( strcmp(g_strDefaultUserPwd, sUserPwd) != 0 ) ||
  642. (strcmp(g_strLoginUserID, "") == 0) )
  643. {
  644. sUserPwd = CString(md5.getMD5Digest());
  645. }
  646. nRet = CDBInterface::GetInstancePtr()->ValidateUser((char*)(LPCTSTR)sUserID, (char *)(LPCTSTR)sUserPwd);
  647. //LOG4C((LOG_NOTICE, "ValidateUser return %d", nRet));
  648. if( nRet < 1 )
  649. {
  650. MessageBox(NULL,g_strMsgUserInvalid, g_strTip, MB_ICONWARNING);
  651. return 0;
  652. }
  653. CHAR chStatus[MAX_STATUS_LENGTH + 1] = {0};
  654. CDBInterface::GetInstancePtr()->ValidateUserEnable( (char*)(LPCTSTR)sUserID, chStatus );
  655. if( atoi(chStatus) == 1 )
  656. {
  657. MessageBox(NULL,g_strMsgUserDisable, g_strTip, MB_ICONWARNING);
  658. return 0;
  659. }
  660. //cHn add
  661. CDBInterface::GetInstancePtr()->GetUserIDByName( sUserID,g_nUserID );
  662. if( g_bStartRun==0 && -1==PMS_VerifyUserPermit( g_nUserID,PMS_EDIT_STATUS_MANAGE,"" ) )
  663. {
  664. MessageBox(NULL,g_strNoPermit, g_strTip, MB_ICONWARNING);
  665. return 0;
  666. }
  667. return 1;
  668. }