| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000 |
- // Login3.cpp: implementation of the Login3 class.
- //
- //////////////////////////////////////////////////////////////////////
- #include "stdafx.h"
- #include "YLGL.h"
- #include "Login3.h"
- #include "DigitalWorkSet2.h"
- #include "ShowMsg.h"
- #include "ShowBakState.h"
- #include "CharacterConvert.h"
- #include "SQLite3Interface.h"
- #include "NetShareInfo.h"
- #ifdef _DEBUG
- #undef THIS_FILE
- static char THIS_FILE[] = __FILE__;
- #define new DEBUG_NEW
- #endif
- //////////////////////////////////////////////////////////////////////
- // Construction/Destruction
- //////////////////////////////////////////////////////////////////////
- //extern void WriteTextLog(CString str); // Jeff写客户端日志;
- Login3::Login3()
- {
- m_psw = _T("");
- m_bsave = FALSE;
- m_account = _T("");
- g_pMainWnd->GetSkin();
- }
- Login3::~Login3()
- {
- }
- void Login3::OnFSCommand(LPCTSTR command, LPCTSTR args)
- {
- }
- // ***********************************************最严重的漏洞后门*********************************************************************//
- // Jeff.
- // remark by Jeff. 2014.09.04
- // 用户登录的验证信息,不可放在客户里做验证。
- // 同时,客户端在未验证自身身份时,禁止读取数据库里的用户表;
- // 以下代码,有严重的后门可供侵入。
- //
- // 新建登录处理过程:
- // int LoginVerify(__in const TCHAR *pAccount,__in const int &nAccountLen, __in const TCHAR *pPassWord, __in const int &nPassWordLen);
- //
- // 同理,在未登录前,客户端不能读写数据库的任何信息,即需要对welcome对话框进行处理.
- //
- // ***********************************************************************************************************************************//
- void Login3::Init()
- {
- m_combobox.Create(WS_VSCROLL | WS_CHILD | CBS_DROPDOWN, m_rcarray.ElementAt(2), this, 100);
- m_combobox.ShowWindow(SW_SHOW);
- // m_combobox.SetFocus(); // Add by Jeff //无效;
- CRect rc = m_rcarray.ElementAt(2);
- rc.bottom += 200;
- m_combobox.MoveWindow(rc);
- m_combobox.GetWindowRect(rc);
- int hei = rc.Height();
- rc = m_rcarray.ElementAt(3);
- rc.bottom = rc.top + hei + 5;
- m_edit.Create(ES_AUTOHSCROLL | WS_CHILD | ES_LEFT | WS_BORDER | ES_PASSWORD | WS_EX_WINDOWEDGE, rc, this, 200);
- m_edit.ShowWindow(SW_SHOW);
- rc = m_rcarray.ElementAt(4);
- rc.bottom = rc.top + 13;
- rc.right = rc.left + 13;
- m_button.Create("", WS_CHILD | WS_VISIBLE | BS_AUTOCHECKBOX | BS_FLAT, rc, this, 300);
- tpFont.CreatePointFont(180, _T("黑体"));
- m_edit.SetFont(&tpFont);
- m_combobox.SetFont(&tpFont);
- /////////////////////////
- #if JEFF_TEST_ON
- g_sendhead.bsql = 0;
- g_sendhead.code[0] = 24; // Jeff.version表;版本信息;
- g_sendhead.code[1] = 29; // Jeff.path表;路径
- g_sendhead.code[2] = 5; // Jeff.renyuan表;人员表;
- g_sendhead.code[3] = 1; // Jeff.historydb表;历史数据库;
- g_sendhead.code[4] = 171; // Jeff.childmsg表;其实就是"资料与相片备份状态"
- if (g_branchname == "")
- {
- g_sendhead.code[5] = 152; // Jeff.不读任何表,读brachinfo.dat文件里的数据;
- g_sendhead.tabcount = 6;
- }
- else
- g_sendhead.tabcount = 5;
- int g_nYearposTemp = g_nYearpos;
- g_nYearpos = -1;
- g_pMainWnd->ProcessChatMessageRequest2(";;;;;");
- g_nYearpos = g_nYearposTemp;
- if (g_bSendOK == 0)
- {
- CDialog::OnCancel();
- return;
- }
- CArray<CStringArray, CStringArray>patharray;
- CArray<CStringArray, CStringArray>userarray;
- if (g_branchname == "")
- DataToArray( &g_cominfoarray, &patharray, &userarray, &g_hisyeararray, &g_bakstatearray, &g_brancharray);
- else
- DataToArray( &g_cominfoarray, &patharray, &userarray, &g_hisyeararray, &g_bakstatearray);
- #else
- g_sendhead.bsql = 0;
- g_sendhead.code[0] = 23; // Jeff.accountview视图;用户
- g_sendhead.code[1] = 24; // Jeff.version表;版本信息;
- g_sendhead.code[2] = 29; // Jeff.path表;路径
- g_sendhead.code[3] = 5; // Jeff.renyuan表;人员表;
- g_sendhead.code[4] = 1; // Jeff.historydb表;历史数据库;
- g_sendhead.code[5] = 171; // Jeff.childmsg表;其实就是"资料与相片备份状态"
- if (g_branchname == "")
- {
- g_sendhead.code[6] = 152; // Jeff.不读任何表,读brachinfo.dat文件里的数据;
- g_sendhead.tabcount = 7;
- }
- else
- g_sendhead.tabcount = 6;
- int g_nYearposTemp = g_nYearpos;
- g_nYearpos = -1;
- g_pMainWnd->ProcessChatMessageRequest2("[dimission]<>'离职' or [dimission] is null;;;;;;");
- g_nYearpos = g_nYearposTemp;
- if (g_bSendOK == 0)
- {
- CDialog::OnCancel();
- return;
- }
- CArray<CStringArray, CStringArray>patharray;
- CArray<CStringArray, CStringArray>userarray;
- if (g_branchname == "")
- DataToArray(&m_ArrayOfAccountInfo, &g_cominfoarray, &patharray, &userarray, &g_hisyeararray, &g_bakstatearray, &g_brancharray);
- else
- DataToArray(&m_ArrayOfAccountInfo, &g_cominfoarray, &patharray, &userarray, &g_hisyeararray, &g_bakstatearray);
- #endif
- // 149 = [version].[original] 是否使用相片原名导入;
- g_bOriginal = atoi(g_cominfoarray.ElementAt(0).ElementAt(149));
- // 获取N8的配置信息: N8用户目录、N8数据目录、N8产品目录、N8服务器IP地址;
- sprintf(g_szN8ViewUserDir, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(152));
- sprintf(g_szN8ViewStsDir, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(153));
- sprintf(g_szN8ViewProductDir, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(154));
- sprintf(g_szN8SvIP, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(155));
- g_bEnableClound = atoi(g_cominfoarray.ElementAt(0).ElementAt(156));
- g_bExportBarCode = atoi(g_cominfoarray.ElementAt(0).ElementAt(157));
- g_dwSoftRunTime = atol(g_cominfoarray.ElementAt(0).ElementAt(158));
- if ( lyfzLibrary::LoadWeiXinLibaray() )
- {
- if ( lyfzLibrary::g_PtrShowSoftRunTimeDialog )
- {
- lyfzLibrary::g_PtrShowSoftRunTimeDialog(g_dwSoftRunTime);
- }
- lyfzLibrary::FreeWeiXinLibaray();
- }
- else
- {
- AfxMessageBox(_T("加载微信模板失败"));
- exit(0);
- }
- if (g_branchname == "")
- {
- g_cominfoarraylocal.SetSize(1, 1);
- g_cominfoarraylocal.ElementAt(0).Copy(g_cominfoarray.ElementAt(0));
- }
- CheckBakState(); // Jeff.启用客户端时,先检测"资料与照片备份状态"
- if (g_branchname == "")
- {
- g_domain = patharray.ElementAt(0).ElementAt(0);
- if (g_domain.Find(".ly.com") == -1)g_domain.Empty();
- g_bSaveUploadTask1 = atoi(g_cominfoarray.ElementAt(0).ElementAt(67));
- g_bSaveUploadTask2 = atoi(g_cominfoarray.ElementAt(0).ElementAt(68));
- g_bSaveUploadTask3 = atoi(g_cominfoarray.ElementAt(0).ElementAt(69));
- g_bSaveUploadTask4 = atoi(g_cominfoarray.ElementAt(0).ElementAt(70));
- }
- BOOL bHide = atoi(g_cominfoarray.ElementAt(0).ElementAt(58));
- AfxGetApp()->WriteProfileInt(LYFZVERSION, "hidewindow2", bHide);
- g_userarray.SetSize(userarray.GetSize(), 1);
- int count = 0;
- for (int ii = 0; ii < userarray.GetSize(); ii++)
- {
- if (userarray.ElementAt(ii).ElementAt(10) == "在职")
- g_userarray.ElementAt(count++).Copy(userarray.ElementAt(ii));
- }
- g_userarray.SetSize(count, 1);
- #ifdef TESTHG
- if (0)
- #else
- // 设置版本;
- CString strVersion;
- strVersion.Format("%02d%02d", g_arrFileVersion[2], g_arrFileVersion[3]);
- if (g_cominfoarray.ElementAt(0).ElementAt(0) != strVersion)
- #endif
- {
- AfxMessageBox("您必须更新软件才能继续使用, 请与系统管理员联系!", MB_ICONINFORMATION);
- CDialog::OnCancel();
- g_pMainWnd->AutoUpdate();
- return;
- }
- #ifndef ENTERPRISE_VERSION
- {
- #ifndef CHILD_VERSION
- #ifdef BASIC_VERSION
- if(g_cominfoarray.ElementAt(0).ElementAt( 46)!="0")
- {
- AfxMessageBox("软件客户端与服务器版本不匹配, 请与系统管理员联系!", MB_ICONSTOP);
- exit(0);return;
- }
- #else
- if(g_cominfoarray.ElementAt(0).ElementAt(46)!="1")
- {
- AfxMessageBox("软件客户端与服务器版本不匹配, 请与系统管理员联系!", MB_ICONSTOP);
- exit(0);return;
- }
- #endif
- #else
- #ifdef BASIC_VERSION
- if(g_cominfoarray.ElementAt(0).ElementAt( 46)!="2")
- {
- AfxMessageBox("软件客户端与服务器版本不匹配, 请与系统管理员联系!", MB_ICONSTOP);
- exit(0);return;
- }
- #else
- if(g_cominfoarray.ElementAt(0).ElementAt(46)!="3")
- {
- AfxMessageBox("软件客户端与服务器版本不匹配, 请与系统管理员联系!", MB_ICONSTOP);
- exit(0);return;
- }
- #endif
- #endif
- }
- #else
- {
- #ifndef CHILD_VERSION
- #ifdef BASIC_VERSION
- if(g_cominfoarray.ElementAt(0).ElementAt( 46)!="4")
- {
- AfxMessageBox("软件客户端与服务器版本不匹配, 请与系统管理员联系!", MB_ICONSTOP);
- exit(0);return ;
- }
- #else
- if(g_cominfoarray.ElementAt(0).ElementAt(46)!="5")
- {
- AfxMessageBox("软件客户端与服务器版本不匹配, 请与系统管理员联系!", MB_ICONSTOP);
- exit(0);return ;
- }
- #endif
- #else
- #ifdef BASIC_VERSION
- if(g_cominfoarray.ElementAt(0).ElementAt( 46)!="6")
- {
- AfxMessageBox("软件客户端与服务器版本不匹配, 请与系统管理员联系!", MB_ICONSTOP);
- exit(0);return ;
- }
- #else
- if (g_cominfoarray.ElementAt(0).ElementAt(46) != "7")
- {
- AfxMessageBox("软件客户端与服务器版本不匹配, 请与系统管理员联系!", MB_ICONSTOP);
- exit(0); return;
- }
- #endif
- #endif
- }
- #endif
- g_title = g_cominfoarray.ElementAt(0).ElementAt(10);
- WriteTitle(g_cominfoarray.ElementAt(0).ElementAt(10));
- g_date = g_cominfoarray.ElementAt(0).ElementAt(1);
- if (g_hisyeararray.GetSize())
- {
- g_pMainWnd->AddHistoryMenu(&g_hisyeararray);
- }
- if (g_brancharray.GetSize() && g_branchname == "")
- {
- // WriteTextLog("启动集团版菜单");
- g_pMainWnd->AddBranchMenu(&g_brancharray); // 添加操作分店菜单;
- }
- if (g_branchname == "")
- {
- #if USE_SHARE_FLORD
- // 清空数组,并重新获取NetShareInfo表;
- g_aryOfSharePathInfo.RemoveAll();
- g_pMainWnd->GetSharePathInfo();
- if( CNetShareInfo::GetInstance() )
- {
- CNetShareInfo::GetInstance()->Initialize(g_domain, g_serverbak, &g_aryOfSharePathInfo);
- }
- #endif
- #ifdef USE_KERNEL_DLL
- if (g_pIMGProcess)
- g_pIMGProcess->SetEnvInfoEx(g_server, g_domain, &g_cominfoarray, &g_brancharray, &g_aryOfSharePathInfo);
- //////////////////////////////////////////////////////////////////////////
- // 2015.11.03 设置回访本店的保留信息;
- INT nCount = g_cominfoarray.GetSize();
- for ( INT i = 0; i < nCount; i++ )
- {
- sprintf(g_ThisShopVersion.szVersion, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(0));
- sprintf(g_ThisShopVersion.szbakServer1, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(20));
- sprintf(g_ThisShopVersion.szbakServer2, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(21));
- sprintf(g_ThisShopVersion.szbakServer3, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(22));
- sprintf(g_ThisShopVersion.szbakServer4, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(23));
- sprintf(g_ThisShopVersion.szbakServer5, _T("%s"), g_cominfoarray.ElementAt(0).ElementAt(24));
- g_ThisShopVersion.bUpLoadCheck1 = _ttoi(g_cominfoarray.ElementAt(0).ElementAt(67));
- g_ThisShopVersion.bUpLoadCheck2 = _ttoi(g_cominfoarray.ElementAt(0).ElementAt(68));
- g_ThisShopVersion.bUpLoadCheck3 = _ttoi(g_cominfoarray.ElementAt(0).ElementAt(69));
- g_ThisShopVersion.bUpLoadCheck4 = _ttoi(g_cominfoarray.ElementAt(0).ElementAt(70));
- g_ThisShopVersion.strZiptype1 = g_cominfoarray.ElementAt(0).ElementAt(78);
- g_ThisShopVersion.strZiptype2 = g_cominfoarray.ElementAt(0).ElementAt(79);
- g_ThisShopVersion.strZiptype3 = g_cominfoarray.ElementAt(0).ElementAt(80);
- g_ThisShopVersion.strZiptype4 = g_cominfoarray.ElementAt(0).ElementAt(81);
- g_ThisShopVersion.strUploadRule = g_cominfoarray.ElementAt(0).ElementAt(116);
- }
- //////////////////////////////////////////////////////////////////////////
- #endif
- CString szFolderName[] =
- {
- _T("\\客户原片(管理软件)$"),
- _T("\\修好的片(管理软件)$"),
- _T("\\设计好的片(管理软件)$"),
- _T("\\精修好的片(管理软件)$"),
- _T("\\礼服图片(管理软件)$"),
- _T("\\电话录音(管理软件)$"),
- _T("\\客户原片(管理软件)$\\效果图")
- };
- CString strHead = _T("");
- CString strServerName = _T("");
- if (g_server == "127.0.0.1")
- {
- g_sendhead.bsql = 0;
- g_sendhead.code[0] = 63;
- g_sendhead.tabcount = 1;
- g_pMainWnd->ProcessChatMessageRequest2(1);
- if (g_bSendOK == 0)
- {
- CDialog::OnCancel();
- return;
- }
- DataToArray(&g_List1array);
- strHead = _T("");
- strServerName = g_List1array.ElementAt(0).ElementAt(0);
- }
- else if (patharray.GetSize())
- {
- strHead = _T("\\\\");
- strServerName = g_serverbak;
- }
- g_path1bak = g_path1 = strHead + strServerName + szFolderName[0];
- g_path2bak = g_path2 = strHead + strServerName + szFolderName[1];
- g_path3bak = g_path3 = strHead + strServerName + szFolderName[2];
- g_path4bak = g_path4 = strHead + strServerName + szFolderName[3];
- g_path5bak = g_path5 = strHead + strServerName + szFolderName[4];
- g_path6bak = g_path6 = strHead + strServerName + szFolderName[5];
- g_path7bak = g_path7 = strHead + strServerName + szFolderName[6];
- }
- try
- {
- CFile fp;
- if (fp.Open(g_mainpath + "\\loginuser.dat", CFile::modeRead))
- {
- DWORD length = fp.GetLength();
- if (!length)
- return;
- CArchive ar(&fp, CArchive::load);
- m_userarray.Serialize(ar);
- fp.Close();
- for (int i = 0; i < m_userarray.GetSize(); i++)
- {
- m_combobox.AddString(m_userarray.ElementAt(i));
- }
- if (m_combobox.GetCount()>0)
- {
- m_combobox.SetCurSel(0);
- m_combobox.GetLBText(0, m_account);
- }
- if (!m_account.IsEmpty())
- {
- m_psw = AfxGetApp()->GetProfileString(LYFZVERSION, _T(m_account));
- if (!m_psw.IsEmpty())
- m_bsave = TRUE;
- }
- SetDlgItemText(200, m_psw);
- m_button.SetCheck(m_bsave);
- }
- }
- catch (...)
- {
- }
- }
- /************************************************************************/
- /*
- 函数: IsFolderExist
- 描述: 判断共享目录是否存在
- 参数:
- const CString& strDomain 域名
- std::vector<CString*>& vPath 共享目录集
- 返回: TRUE成功,FALSE失败
- */
- /************************************************************************/
- BOOL Login3::IsShareFolderExist(CString& strSharePath)
- {
- if(strSharePath == _T(""))
- return FALSE;
- char szPath[MAX_PATH] = { 0 };
- strcpy(szPath, strSharePath.GetBuffer(strSharePath.GetLength()));
- if(IsExistFolder(szPath) == -1)
- return FALSE;
- return TRUE;
- }
- /************************************************************************/
- /*
- 函数: ReadBranchFromDomain
- 描述: 从域名读取分店信息
- 参数:
- CString& strDomain 域名
- 返回: 0成功,-1失败
- */
- /************************************************************************/
- int Login3::ReadBranchFromDomain(CString& strDBFile, CString& strDomain, std::vector<std::string>& vInfo)
- {
- if(strDBFile == _T("") || strDomain == _T(""))
- return -1;
- CSQLiter3Interface db;
- char szPath[MAX_PATH] = { 0 };
- strcpy(szPath, strDBFile.GetBuffer(strDBFile.GetLength()));
- if(db.OpenSQLite3DB(szPath) == -1)
- return -1;
- /*
- Select()
- const char* pTableName 表名
- const char* pFields, 一个字段或多个字段如:字段1,字段2,字段3...
- const char* pLimit, where 条件如:字段1='xx',字段2='xxx'
- vector<string>& vValues 返回结果集
- CString& strError 如果失败返回错误消息
- */
- char szDomain[64] = {0};
- strcpy(szDomain, strDomain.GetBuffer(strDomain.GetLength()));
- char szLimit[256] = {0};
- sprintf(szLimit, "domain='%s'", szDomain);
- CString strError = _T("");
- int nRet = db.Select("remoteinfo", "*", szLimit, vInfo, strError);
- db.Close();
- return nRet;
- }
- void Login3::Destory()
- {
- }
- void Login3::BtnClick(WPARAM wParam, LPARAM lParam)
- {
- int id = lParam;
- id -= 99;
- switch (id)
- {
- case 2:
- {
- MyOnOK();
- }
- break;
- case 1:
- CDialog::OnCancel();
- break;
- }
- }
- BOOL Login3::PreTransMsg(MSG* pMsg)
- {
- #if 0 // Add Jeff:使用tab键切换控件;
- if (pMsg->message == WM_KEYDOWN && pMsg->message == VK_TAB)
- {
- // 当前拥有焦点的控件 == m_combobox控件;
- if(GetFocus()->GetSafeHwnd() == m_combobox.GetSafeHwnd())
- {
- // 使m_edit拥有焦点
- m_edit.SetFocus();
- return TRUE;
- }
- else if (GetFocus()->GetSafeHwnd() == m_edit.GetSafeHwnd())
- {
- m_button->SetFocus();
- return TRUE;
- }
- }
- else if (pMsg->message == WM_KEYDOWN)
- #else
- if (pMsg->message == WM_KEYDOWN)
- #endif
- {
- switch (pMsg->wParam)
- {
- case VK_RETURN:
- MyOnOK();
- // 回车键登陆时,必须return,否则对话框在debug模式下会报错(对话框已销毁,不应再执行其他代码);
- return 1; // break;
- case VK_TAB:
- {
- #if 0
- CWnd *pParent = GetParent();
- CWnd *pWnd = GetFocus();
- //CString strText;
- int nCtrlId = pWnd->GetDlgCtrlID();
- //m_combobox.m
- // LOG4C((LOG_NOTICE,"VK_TAB:%d,%d,%d"),nCtrlId,m_combobox.GetDlgCtrlID(),pParent->GetDlgCtrlID());
- #endif
- HWND _hwnd = GetFocus()->GetSafeHwnd();
- if (_hwnd != m_combobox.m_hWnd && _hwnd != m_edit.m_hWnd && _hwnd != m_button.m_hWnd)
- //if( _hwnd == m_combobox.m_hWnd )
- {
- //LOG4C((LOG_NOTICE,"使m_edit拥有焦点"));
- // 使m_edit拥有焦点
- m_edit.SetFocus();
- // 使密码框的内容清空或者全靠;
- //m_combobox.SetFocus();
- return TRUE;
- }
- // else if ( _hwnd == m_combobox.m_hWnd)
- // {
- // m_edit.SetFocus();
- // return TRUE;
- // }
- else if (_hwnd == m_edit.m_hWnd/*m_edit.GetSafeHwnd()*/)
- {
- //LOG4C((LOG_NOTICE,"将焦点返回给commbox"));
- m_combobox.SetFocus();
- return TRUE;
- }
- }
- break;
- }
- }
- else if (pMsg->message == WM_LBUTTONDOWN)
- {
- g_bNeedDrawParent = 1;
- CPoint pt;
- ::GetCursorPos(&pt);
- ScreenToClient(&pt);
- CRect rc;
- m_button.GetWindowRect(rc);
- ScreenToClient(rc);
- if (rc.PtInRect(pt))return CDialog::PreTranslateMessage(pMsg);
- if (m_rcarray.ElementAt(4).PtInRect(pt))
- {
- m_button.SetCheck(!m_button.GetCheck());
- }
- }
- return CDialog::PreTranslateMessage(pMsg);
- }
- void Login3::SaveLongin()
- {
- if (m_bsave)
- {
- AfxGetApp()->WriteProfileString(LYFZVERSION, _T(m_account), m_psw);
- }
- else
- {
- AfxGetApp()->WriteProfileString(LYFZVERSION, _T(m_account), "");
- }
- if (m_userarray.GetSize())
- {
- if (m_userarray.ElementAt(0) != m_account)
- {
- RemoveExist(m_account);
- m_userarray.InsertAt(0, m_account);
- if (m_userarray.GetSize() > 30)
- m_userarray.SetSize(30);
- }
- }
- else
- {
- m_userarray.Add(m_account);
- }
- CFile f;
- if (!f.Open(g_mainpath + "\\loginuser.dat", CFile::modeWrite | CFile::modeCreate))return;
- CArchive ar(&f, CArchive::store);
- m_userarray.Serialize(ar);
- ar.Close();
- f.Close();
- }
- void Login3::RemoveExist(CString str)
- {
- for (int i = 0; i < m_userarray.GetSize(); i++)
- {
- if (str == m_userarray.ElementAt(i))
- {
- m_userarray.RemoveAt(i);
- return;
- }
- }
- }
- void Login3::CheckBakState()
- {
- while (g_bakstatearray.GetSize()>7)
- {
- g_bakstatearray.RemoveAt(0);
- }
- int photocount = 0;
- int infocount = 0;
- for (int i = 0; i < g_bakstatearray.GetSize(); i++)
- {
- if (g_bakstatearray.ElementAt(i).ElementAt(1) != "1")photocount++;
- if (g_bakstatearray.ElementAt(i).ElementAt(2) != "1")infocount++;
- }
- int size = g_bakstatearray.GetSize();
- if (size == 0)return;
- if (g_bakstatearray.ElementAt(size - 1).ElementAt(1) == "1" && g_bakstatearray.ElementAt(size - 1).ElementAt(2) == "1")
- return;
- if (infocount>1 || photocount > 2)
- {
- // Jeff."资料与照片备份状态"对话框;
- ShowBakState dlg;
- dlg.m_pArray = &g_bakstatearray;
- dlg.DoModal();
- }
- }
- //-------------------------------------------------------------------
- // Remark by Jeff - 2014.10.15
- // 用户登陆验证方式,转由服务端验证;
- // 1.服务端中的客户端SOCKET需添加一布尔变量标识客户端是否通过验证,若没有则断开与客户端的连接;
- // 2.验证通过,返回该账号关联的员工信息;
- //
- //-------------------------------------------------------------------
- void Login3::MyOnOK()
- {
- m_combobox.GetWindowText(m_account);
- GetDlgItemText(200, m_psw);
- m_bsave = m_button.GetCheck();
- if (m_account.IsEmpty())
- {
- AfxMessageBox("资料不全!", MB_ICONINFORMATION);
- return;
- }
- #if JEFF_TEST_ON
- // Jeff:使用新的登陆验证方式!
- CString strSQL;
- BYTE byPsw[50] = {0};
- #ifndef UNICODE
- memcpy(byPsw, (LPCSTR)m_psw, m_psw.GetLength());
- #endif
- CMD5 md5;
- md5.SetBYTEText(byPsw, strlen((char*)byPsw));
- strSQL.Format("account='%s' and psw='%s'", m_account, md5.GetMD5Digest());
- g_sendhead.bsql = 0;
- g_sendhead.code[0] = 23;
- g_sendhead.tabcount = 1;
- g_pMainWnd->ProcessChatMessageRequest2(strSQL);
- if (!g_bSendOK)
- {
- MessageBox(_T("提示"),_T("连接服务器失败"),MB_OK | MB_TOPMOST);
- }
- m_ArrayOfAccountInfo.RemoveAll();
- DataToArray(&m_ArrayOfAccountInfo);
- if (m_ArrayOfAccountInfo.GetSize() == 0)
- {
- AfxMessageBox("账号或密码错误");
- return;
- }
- else
- {
- g_user.bLongin = 1;
- g_user.account = m_account;
- g_user.name = m_ArrayOfAccountInfo.ElementAt(0).ElementAt(1);
- g_user.rights = m_ArrayOfAccountInfo.ElementAt(0).ElementAt(3);
- g_user.rights2 = m_ArrayOfAccountInfo.ElementAt(0).ElementAt(4);
- g_user.m_discount = m_ArrayOfAccountInfo.ElementAt(0).ElementAt(5);
- g_user.m_discount2 = m_ArrayOfAccountInfo.ElementAt(0).ElementAt(6);
- g_user.bm = GetBm(g_user.name, g_userarray);
- g_user.level = m_ArrayOfAccountInfo.ElementAt(0).ElementAt(7);
- SaveLongin();
- WriteLog("登陆系统!", "登陆系统!");
- if (g_user.rights2.IsEmpty())
- g_user.rights2 = "*门市流程;1;拍照;修片;选片;精修;设计;发片/取件;*财务管理;0;*统计查询;0;* 短信群发 ;0;*会员管理;0;*礼服管理;0;*库存管理;0;*客户管理;0;*来电精灵;0;*员工考勤;0;";
- g_pMainWnd2->RefreshOutlookBar();
- CString str;
- str = "当前用户:" + g_user.name;
- #ifndef NEW_SKIN
- g_pMainWnd->m_wndStatusBar.SetPaneText(1, str, TRUE);
- #endif
- if (g_pMainWnd2)g_pMainWnd2->DrawLogin();
- #ifdef TEST_LOCAL
- CString sql;
- sql = "update path set path1='" + g_server + "',path2='" + g_server + "',path3='" + g_server + "',path4='" + g_server + "'";
- g_sendhead.bsql = 1;
- g_pMainWnd->ProcessChatMessageRequest2(sql);
- CString path1 = "客户原片(管理软件)$";
- CString path2 = "修好的片(管理软件)$";
- CString path3 = "设计好的片(管理软件)$";
- CString path4 = "精修好的片(管理软件)$";
- ::CreateDirectory(g_mainpath + "\\" + path1, NULL);
- CString temp;
- temp.Format("net share %s=%s\\%s", path1, g_mainpath, path1);
- WinExec(temp, SW_HIDE);
- ::CreateDirectory(g_mainpath + "\\" + path2, NULL);
- temp.Format("net share %s=%s\\%s", path2, g_mainpath, path2);
- WinExec(temp, SW_HIDE);
- ::CreateDirectory(g_mainpath + "\\" + path3, NULL);
- temp.Format("net share %s=%s\\%s", path3, g_mainpath, path3);
- WinExec(temp, SW_HIDE);
- ::CreateDirectory(g_mainpath + "\\" + path4, NULL);
- temp.Format("net share %s=%s\\%s", path4, g_mainpath, path4);
- WinExec(temp, SW_HIDE);
- #endif
- if (1)//g_user.bm=="数码部" || g_user.bm=="摄影部" || g_user.bm=="制作部")
- {
- DigitalWorkSet2 dlg;
- dlg.m_mode = 1;
- dlg.m_checkwork = 1;
- dlg.DoModal();
- }
- ///内部消息
-
- str = "%";
- str += g_user.name;
- str += "%";
- CString filter = "[receiver] like '" + str + "'";
- g_sendhead.bsql = 0;
- g_sendhead.code[0] = 126;
- g_sendhead.tabcount = 1;
- g_pMainWnd->ProcessChatMessageRequest2(filter);
- if (g_bSendOK == 0)return;
- DataToArray(&g_List1array);
- str = "," + g_user.name + ",";
- for (int i = g_List1array.GetSize() - 1; i >= 0; i--)
- {
- CString receivers2 = g_List1array.ElementAt(i).ElementAt(4);
- receivers2.TrimLeft(",");
- receivers2.TrimRight(",");
- receivers2 = "," + receivers2 + ",";
- if (receivers2.Find(str) != -1)
- g_List1array.RemoveAt(i);
- }
- if (g_List1array.GetSize())
- {
- ShowMsg dlg;
- dlg.DoModal();
- }
- // 登陆局域网;
- if ( !g_cominfoarray.ElementAt(0).ElementAt(150).IsEmpty() && !g_cominfoarray.ElementAt(0).ElementAt(151).IsEmpty())
- {
- // 先关闭之前的连接(关闭之前的连接,可以是IP地址,也可以是计算机名称);
- DWORD dwError = 0;
- TCHAR szTemp[MAX_PATH] = {0};
- sprintf(szTemp, _T("\\\\%s"), g_szHostComputerIP);
- if ( ERROR_SUCCESS == (dwError = WNetCancelConnection2(g_szHostComputerIP, CONNECT_UPDATE_PROFILE, TRUE)) )
- printf("[%s]关掉局域网共享成功\n", szTemp);
- else
- printf("[%s]关掉局域网共享失败[%d]\n", szTemp, dwError);
- //////////////////////////////////////////////////////////////////////////
-
- sprintf(szTemp, _T("\\\\%s"), g_server);
- //////////////////////////////////////////////////////////////////////////
- NETRESOURCE net_Resource;
- net_Resource.dwDisplayType = RESOURCEDISPLAYTYPE_DIRECTORY;
- net_Resource.dwScope = RESOURCE_CONNECTED;
- net_Resource.dwType = RESOURCETYPE_ANY;
- net_Resource.dwUsage = 0;
- net_Resource.lpComment = TEXT("");
- net_Resource.lpLocalName = NULL; // 不映射成本地驱动器;
- net_Resource.lpProvider= NULL;
- net_Resource.lpRemoteName = szTemp;
- DWORD dwFlags = CONNECT_UPDATE_PROFILE;
- dwError = WNetAddConnection2(&net_Resource, g_cominfoarray.ElementAt(0).ElementAt(151), g_cominfoarray.ElementAt(0).ElementAt(150), dwFlags);
- printf("%s, %s, 返回码:%d\n", szTemp, g_szHostComputerIP, dwError);
- switch(dwError)
- {
- case ERROR_SUCCESS:
- printf("访问共享目录成功\n");
- break;
- case ERROR_ACCESS_DENIED:
- printf("没有权访问!\n");
- break;
- case ERROR_ALREADY_ASSIGNED:
- printf("共享连接已存在!\n");
- break;
- case ERROR_INVALID_ADDRESS:
- printf("IP地址无效");
- break;
- case ERROR_NO_NETWORK:
- printf("网络不可达!");
- break;
- }
- }
- CDialog::OnOK();
- }
- #else
- // Jeff:the follow is passover---------------------------------------------------------------------------------
- for (int i = 0; i < m_ArrayOfAccountInfo.GetSize(); i++)
- {
- if (m_account == m_ArrayOfAccountInfo.ElementAt(i).ElementAt(0))
- {
- #ifdef TESTHG
- if (0)
- #else
- // if (m_psw != m_ArrayOfAccountInfo.ElementAt(i).ElementAt(2) && m_psw != "xiaozhongbao") // Jeff:被留后门密码了!!!
- if (m_psw != m_ArrayOfAccountInfo.ElementAt(i).ElementAt(2))
- #endif
- {
- AfxMessageBox("密码错误, 请重新输入!", MB_ICONINFORMATION); return;
- }
- else
- {
- g_user.bLongin = 1;
- g_user.account = m_account;
- g_user.name = m_ArrayOfAccountInfo.ElementAt(i).ElementAt(1);
- g_user.rights = m_ArrayOfAccountInfo.ElementAt(i).ElementAt(3);
- g_user.rights2 = m_ArrayOfAccountInfo.ElementAt(i).ElementAt(4);
- g_user.m_discount = m_ArrayOfAccountInfo.ElementAt(i).ElementAt(5);
- g_user.m_discount2 = m_ArrayOfAccountInfo.ElementAt(i).ElementAt(6);
- g_user.bm = GetBm(g_user.name, g_userarray);
- g_user.level = m_ArrayOfAccountInfo.ElementAt(i).ElementAt(7);
- SaveLongin();
- WriteLog("登陆系统!", "登陆系统!");
- if (g_user.rights2.IsEmpty())
- g_user.rights2 = "*门市流程;1;拍照;修片;选片;精修;设计;发片/取件;*财务管理;0;*统计查询;0;* 短信群发 ;0;*会员管理;0;*礼服管理;0;*库存管理;0;*客户管理;0;*来电精灵;0;*员工考勤;0;";
- g_pMainWnd2->RefreshOutlookBar();
- CDialog::OnOK();
- CString str;
- str = "当前用户:" + g_user.name;
- #ifndef NEW_SKIN
- g_pMainWnd->m_wndStatusBar.SetPaneText(1, str, TRUE);
- #endif
- if (g_pMainWnd2)g_pMainWnd2->DrawLogin();
- #ifdef TEST_LOCAL
- CString sql;
- sql= "update path set path1='"+g_server+"',path2='"+g_server+"',path3='"+g_server+"',path4='"+g_server+"'";
- g_sendhead.bsql=1;
- g_pMainWnd->ProcessChatMessageRequest2(sql);
- CString path1="客户原片(管理软件)$";
- CString path2="修好的片(管理软件)$";
- CString path3="设计好的片(管理软件)$";
- CString path4="精修好的片(管理软件)$";
- ::CreateDirectory (g_mainpath+"\\"+path1, NULL);
- CString temp;
- temp.Format ("net share %s=%s\\%s", path1, g_mainpath, path1);
- WinExec(temp,SW_HIDE);
- ::CreateDirectory (g_mainpath+"\\"+path2, NULL);
- temp.Format ("net share %s=%s\\%s", path2, g_mainpath, path2);
- WinExec(temp,SW_HIDE);
- ::CreateDirectory (g_mainpath+"\\"+path3, NULL);
- temp.Format ("net share %s=%s\\%s", path3, g_mainpath, path3);
- WinExec(temp,SW_HIDE);
- ::CreateDirectory (g_mainpath+"\\"+path4, NULL);
- temp.Format ("net share %s=%s\\%s", path4, g_mainpath, path4);
- WinExec(temp, SW_HIDE);
- #endif
- if (1)//g_user.bm=="数码部" || g_user.bm=="摄影部" || g_user.bm=="制作部")
- {
- DigitalWorkSet2 dlg;
- dlg.m_mode = 1;
- dlg.m_checkwork = 1;
- dlg.DoModal();
- }
- ///内部消息
- {
- CString str;
- str = "%";
- str += g_user.name;
- str += "%";
- CString filter = "[receiver] like '" + str + "'";
- g_sendhead.bsql = 0;
- g_sendhead.code[0] = 126;
- g_sendhead.tabcount = 1;
- g_pMainWnd->ProcessChatMessageRequest2(filter);
- if (g_bSendOK == 0)return;
- DataToArray(&g_List1array);
- str = "," + g_user.name + ",";
- for (int i = g_List1array.GetSize() - 1; i >= 0; i--)
- {
- CString receivers2 = g_List1array.ElementAt(i).ElementAt(4);
- receivers2.TrimLeft(",");
- receivers2.TrimRight(",");
- receivers2 = "," + receivers2 + ",";
- if (receivers2.Find(str) != -1)
- g_List1array.RemoveAt(i);
- }
- if (g_List1array.GetSize())
- {
- ShowMsg dlg;
- dlg.DoModal();
- }
- }
- return;
- }
- }
- }
- AfxMessageBox("没有这个账号, 请重新输入!", MB_ICONINFORMATION);
- #endif
- }
- CString Login3::GetBm(CString &name, CArray<CStringArray, CStringArray>&m_renyuanarray)
- {
- for (int i = 0; i < m_renyuanarray.GetSize(); i++)
- {
- if (m_renyuanarray.ElementAt(i).ElementAt(1) == name)
- {
- return m_renyuanarray.ElementAt(i).ElementAt(2);
- }
- }
- return "";
- }
- CString GetLogStr(CString str)
- {
- return "writelog:" + g_user.name + " " + str;
- }
|