Global.cpp 81 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313
  1. // Global.cpp : 应用程序的全局变量、函数源文件
  2. //
  3. // 代码生成在 2014年9月25日, 09:55
  4. #include "StdAfx.h"
  5. #include "Global.h"
  6. #include <io.h> // _access_s头文件;
  7. #include "afxcoll.h"
  8. #include "afxtempl.h"
  9. #include "atlconv.h"
  10. #include <tlhelp32.h>
  11. #include <WinSock.h>
  12. #include "..\\lzari.h"
  13. #include "..\helper\ffsco.h"
  14. //#include <WS2tcpip.h>
  15. // 升级包版本号;
  16. DWORD g_arrFileVersion[4] = { 0 };
  17. TCHAR g_szLoginUser[MAX_PATH] = _T(""); // 当前软件的登陆用户名;
  18. TCHAR g_szLoginPsw[MAX_PATH] = _T(""); // 当前软件的登陆密码;
  19. TCHAR g_szModulePath[MAX_PATH] = _T(""); // 软件目录;
  20. TCHAR g_szModuleFileName[MAX_PATH] = _T(""); // 软件全名称;
  21. TCHAR g_szConnectString[MAX_PATH] = _T(""); // DB连接串;
  22. // 主机信息;
  23. TCHAR g_szHostComputerIP[MAX_PATH] = _T(""); // 服务端主机名称;
  24. DWORD g_dwCSPort = 5678; // 服务端主机通信TCP端口;
  25. // 数据库信息;
  26. TCHAR g_szDBSource[MAX_PATH] = _T(""); // 数据库源(服务所在IP或计算机名);
  27. TCHAR g_szDBSourcePort[MAX_PATH] = _T(""); // 数据库源端口;
  28. DWORD g_dwDBServerPort = 0; // 数据库源端口;
  29. TCHAR g_szDBAccount[MAX_PATH] = _T(""); // 数据库登录用户;
  30. TCHAR g_szDBPassWord[MAX_PATH] = _T(""); // 数据库登录密码;
  31. TCHAR g_szDBName[MAX_PATH] = _T(""); // 数据库名称;
  32. // 相片存储目录;
  33. TCHAR g_szShareHost[MAX_PATH] = _T(""); // 共享主机名;
  34. TCHAR g_szOriginalFolder[MAX_PATH] = _T(""); // 原片目录;
  35. TCHAR g_szOriginalBkFolder[MAX_PATH] = _T(""); // 原片备份目录;
  36. TCHAR g_szEarlyRepairFolder[MAX_PATH] = _T(""); // 初修片目录;
  37. TCHAR g_szEarlyRepairBkFolder[MAX_PATH] = _T(""); // 初修片备份目录;
  38. TCHAR g_szFurtherRepairFolder[MAX_PATH] = _T(""); // 精修片目录;
  39. TCHAR g_szFurtherRepairBkFolder[MAX_PATH] = _T(""); // 精修片备份目录;
  40. TCHAR g_szDesignFolder[MAX_PATH] = _T(""); // 设计片目录;
  41. TCHAR g_szDesignBkFolder[MAX_PATH] = _T(""); // 设计片备份目录;
  42. TCHAR g_szTelRecordingFolder[MAX_PATH] = _T(""); // 电话录音目录;
  43. TCHAR g_szFullDressImageFolder[MAX_PATH] = _T(""); // 礼服图片目录;
  44. // 软件所用加密狗是否已注册; // Jeff,应该放在SoftKey做为静态变量使用;
  45. BOOL g_bSoftWareReg = FALSE;
  46. // 加密狗中的字符信息S1:如 201409062003558789.ly.com
  47. // 该全局变量在旧软件名称是:g_sdomain;
  48. // 该变量在数据库表字段[path].[path1]中存储;
  49. CString g_strDogMainInfo = "";
  50. // 未知用途;
  51. // 该全局变量在旧软件中名称是:CString g_bMain;
  52. // 与集团版有关联性;
  53. // 有可能是主店名称;
  54. CString g_strMain = "";
  55. // 分店名称数组;旧软件中名称:g_branchnamearray
  56. CStringArray g_strArrayOfBranchName;
  57. // ??
  58. CStringArray g_strArrayOfBranchName2;
  59. // 分店IP地址数组;
  60. CStringArray g_strArrayOfBranchIPAdress;
  61. // 分店的加密狗S1信息数组;
  62. CStringArray g_strArrayOfBranchDogMainInfo;
  63. // 座席版允许连接数(从加密狗中获取);
  64. unsigned int g_nCountOfAllowToConn = 0;
  65. DWORD g_nLeng = 0;
  66. BYTE *g_pData = NULL;
  67. DWORD g_nLeng2 = 0;
  68. BYTE *g_pData2 = NULL;
  69. SENDHEAD g_sendhead;
  70. BOOL g_bRedSkin = 0;
  71. COLORREF g_gridcol1 = RGB(204, 204, 204);
  72. COLORREF g_gridcol2 = RGB(190, 190, 190);
  73. COLORREF g_bkcol = RGB(184, 184, 184);
  74. // 红;
  75. COLORREF g_grid_red = RGB(210,0,0);
  76. // 蓝;
  77. COLORREF g_grid_blue = RGB(0,128,255);
  78. // 黄;
  79. COLORREF g_grid_yellow = RGB(255,255,128);
  80. // 绿;
  81. COLORREF g_grid_green = RGB(0,168,0);
  82. CString g_date;
  83. CString g_title;
  84. CArray<CStringArray, CStringArray>g_AryStaff;
  85. CArray<CStringArray, CStringArray>g_cominfoarray;
  86. CArray<CStringArray, CStringArray>g_cominfoarraylocal;
  87. CArray<DWORD, DWORD>g_lengarray;
  88. CArray<DWORD, DWORD>g_btnlengarray;
  89. CArray<BYTE*, BYTE*>g_pointerarray;
  90. CBrush g_editbkbrush;
  91. DWORD g_btnleng[8];
  92. int g_btnlengpos = -1;
  93. int g_nYearpos = -1;
  94. CString g_branchname = ""; // Jeff.集团版:????本分店名称;
  95. CString g_branchip = "";
  96. CString g_branchip2 = "";
  97. BOOL g_bBranchModify = 0;
  98. BOOL g_bShowOK = 0; // Jeff:?
  99. BOOL g_bStaffAchievementShow = 0; // 此机用于员工业绩查看;
  100. BOOL g_bSaveUploadTask1 = 0;
  101. BOOL g_bSaveUploadTask2 = 0;
  102. BOOL g_bSaveUploadTask3 = 0;
  103. BOOL g_bSaveUploadTask4 = 0;
  104. BOOL g_bSearchFilter = 0;
  105. CString g_waiter1;
  106. CString g_waiter2;
  107. CString g_waiter3;
  108. CString g_waiter4;
  109. CString g_waiter5;
  110. CString g_filterdate1;
  111. CString g_filterdate2;
  112. CString g_filterdate3;
  113. CString g_filterdate4;
  114. CString g_filterdate5;
  115. CString g_filterdate6;
  116. CString g_filterbranch;
  117. USER g_user;
  118. CString g_mainpath; // 软件目录
  119. CString g_id; //
  120. CString g_server; // 服务端地址
  121. CStringArray g_serverarray; //
  122. CString g_serverbak; //
  123. CString g_path1; /* 共享目录 <客户原片(管理软件)$> 如:"\\lyfz-pc\客户原片(管理软件)$" */
  124. CString g_path2; /* 共享目录 <修好的片(管理软件)$> 如:"\\lyfz-pc\修好的片(管理软件)$" */
  125. CString g_path3; /* 共享目录 <设计好的片(管理软件$)> 如:""> */
  126. CString g_path4; /* 共享目录 <精修好的片(管理软件$)> 如:""> */
  127. CString g_path5; /* 共享目录 <礼服图片(管理软件$)> 如:""> */
  128. CString g_path6; /* 共享目录 <电话录音(管理软件$)> 如:""> */
  129. CString g_path7; /* 共享目录 <客户原片(管理软件$)\效果图> 如:""> */
  130. CString g_path1bak;
  131. CString g_path2bak;
  132. CString g_path3bak;
  133. CString g_path4bak;
  134. CString g_path5bak;
  135. CString g_path6bak;
  136. CString g_path7bak;
  137. CDatabase g_db;
  138. DWORD g_ncount;
  139. CFont g_titlefont;
  140. DWORD g_nSendCode = 0;
  141. BOOL g_bSendOK = 0;
  142. CString g_temp;
  143. CArray<CStringArray, CStringArray>g_hisyeararray;
  144. CArray<CStringArray, CStringArray>g_brancharray;
  145. CArray<CStringArray, CStringArray>g_oldclientarray; // client表;
  146. BOOL g_bNoConnDlg = 0;
  147. BOOL g_bInSkin = 0;
  148. BOOL g_bGenBranchData = 0;
  149. BOOL g_bSortAscending = FALSE;
  150. CFont g_listctrlfont;
  151. float g_fscalex; // x坐标刻度
  152. float g_fscaley; // y坐标刻度
  153. int g_screenwid; // 桌面宽
  154. int g_screenhei; // 桌面高
  155. float g_WidthScale2 = 1;
  156. float g_HeightScale2 = 1;
  157. RESDATA2 g_resdata2;
  158. BOOL g_bAlphaWnd = 0;
  159. BYTE g_bNeedDrawParent = 0;
  160. BOOL g_bAllBranch = 0;
  161. CString g_domain;
  162. CString g_sInfo;
  163. int g_ncot = 0; // Jeff:订单总数(包含历史订单在内),该变量作用是当订单总数大于1000时,向公司服务器发送数据;
  164. int g_conpos = 0;
  165. int g_nAutoShowStaffAchievement = -1;
  166. BOOL g_bShowBar = 1;
  167. int g_bookingtype = 0;
  168. BOOL g_bNoLoginLia = 0;
  169. BOOL g_bConnLYFZ = 0;
  170. BOOL g_bSendLYFZ = 0;
  171. int g_ntimeout = 30000; // 客户端超时值;
  172. float g_WidthScale;
  173. float g_HeightScale;
  174. int g_dx = 0;
  175. int g_dy = 0;
  176. BOOL g_bNeedCoon = 1; // remark by Jeff:是否需要重新连接服务端;
  177. CStringArray g_menubranchname;
  178. CArray<CStringArray, CStringArray>g_List1array;
  179. // 屏幕区域;
  180. CRect g_rcScreen;
  181. // 对话框背景颜色;
  182. COLORREF g_clr_dlg;
  183. // ini文件路径;
  184. TCHAR g_szIniFile[MAX_PATH];
  185. /************************************************************************/
  186. /*
  187. Jeff:g_conntype
  188. g_conntype == 0 :表示正常连接?(或是连接本地服务器?)
  189. g_conntype == 1 :表示连接公司服务器(http://lijiafz.vicp.net)
  190. g_conntype == 2 :http://www.lyfz.net/download/ip.txt
  191. g_conntype == 3 :http://photo.bjlyfz.com/download/ip.txt
  192. g_conntype == 4 :
  193. */
  194. /************************************************************************/
  195. int g_conntype = 0;//正常
  196. //0 正常
  197. //1 连接1
  198. //2 连接2
  199. //3 连接3
  200. //4 连接4
  201. //************************************//
  202. // 数据库地址;
  203. // 数据库端口;
  204. // 数据库管理员账号;
  205. // 数据库管理员密码;
  206. // 数据库名称;
  207. //
  208. // [函数]:GetIniInfo
  209. // [描述]:获取指定ini信息;
  210. // [参数]:
  211. // szPath:ini所在目录;
  212. // szIniName:ini名;
  213. // [返回]:void
  214. //************************************//
  215. int GetSysIniInfo(const char *szPath, const char *szIniName)
  216. {
  217. TCHAR szDrive[_MAX_DRIVE] = { 0 };
  218. TCHAR szDir[_MAX_DIR] = { 0 };
  219. TCHAR szFna[_MAX_DIR] = { 0 };
  220. TCHAR szExt[_MAX_DIR] = { 0 };
  221. ::GetModuleFileName(NULL, g_szModuleFileName, sizeof(g_szModuleFileName) / sizeof(TCHAR));
  222. sprintf(g_szModulePath, _T("%s"), g_szModuleFileName);
  223. _tsplitpath(g_szModulePath, szDrive, szDir, szFna, szExt);
  224. _tcscpy(g_szModulePath, szDrive);
  225. _tcscat(g_szModulePath, szDir);
  226. if (szPath != NULL && szIniName != NULL)
  227. wsprintf(g_szIniFile, _T("%s\\%s"), szPath, szIniName);
  228. else
  229. wsprintf(g_szIniFile, _T("%s\\HostInfo.ini"), g_szModulePath);
  230. TRACE("szFile =%s\n", g_szIniFile);
  231. OFSTRUCT ofStruct;
  232. OpenFile(g_szIniFile, &ofStruct, OF_EXIST); // Jeff 这是为了兼容16位系统遗留的函数,不应该使用;
  233. if (ERROR_FILE_NOT_FOUND == GetLastError())
  234. {
  235. // 如果没找到,使用默认连接;
  236. strcpy(g_szHostComputerIP, _T("."));
  237. g_dwCSPort = 5678;
  238. // 不存在则创建;
  239. CFile fp;
  240. if( fp.Open(g_szIniFile,CFile::modeCreate|CFile::modeWrite) )
  241. {
  242. fp.Close();
  243. }
  244. WritePrivateProfileString(_T("NetWorkInfo"),_T("Host"),_T("127.0.0.1"),g_szIniFile);
  245. WritePrivateProfileString(_T("NetWorkInfo"),_T("CSPort"),_T("5678"),g_szIniFile);
  246. }
  247. // 获取服务器端TCP信息;
  248. GetPrivateProfileString(_T("NetWorkInfo"), _T("Host"), _T(""), g_szHostComputerIP, MAX_PATH, g_szIniFile);
  249. g_dwCSPort = GetPrivateProfileInt(_T("NetWorkInfo"), _T("CSPort"), 0, g_szIniFile);
  250. g_ntimeout = GetPrivateProfileInt(_T("NetWorkInfo"), _T("TimeOut"), 30000, g_szIniFile);
  251. // 对话框背景颜色;
  252. int r = 202,g = 202,b =202;
  253. r = GetPrivateProfileInt(_T("DialogColor"), _T("dlg_r"), 200, g_szIniFile);
  254. g = GetPrivateProfileInt(_T("DialogColor"), _T("dlg_g"), 200, g_szIniFile);
  255. b = GetPrivateProfileInt(_T("DialogColor"), _T("dlg_b"), 200, g_szIniFile);
  256. g_clr_dlg = RGB(r,g,b);
  257. return 0;
  258. }
  259. //----------------------------------------------------------
  260. // 函数:IsFileExist
  261. // 描述:判断某文件是否存在;
  262. // 参数:
  263. // pFileFullName: 指定的文件名;
  264. // 返回:TRUE表示文件存在;
  265. //----------------------------------------------------------
  266. BOOL IsFileExist(const TCHAR *pFileFullName)
  267. {
  268. int err = 0;
  269. // Check for existence.
  270. if ((err = _access(pFileFullName, 0)) == 0)
  271. {
  272. //printf_s( "File crt_access_s.c exists.\n" );
  273. // Check for write permission.
  274. if ((err = _access(pFileFullName, 2)) == 0)
  275. {
  276. //printf_s( "File crt_access_s.c does have ""write permission.\n" );
  277. }
  278. else
  279. {
  280. //printf_s( "File crt_access_s.c does not have ""write permission.\n" );
  281. }
  282. }
  283. else
  284. {
  285. //printf_s( "File crt_access_s.c does not exist.\n" );
  286. return FALSE;
  287. }
  288. return TRUE;
  289. }
  290. // Pump messages while waiting for event
  291. //----------------------------------------------------------
  292. // 函数:WaitWithMessageLoop
  293. // 描述:等待某内核事件触发;
  294. // 参数:
  295. // hEvent: 被等待响应的内核事件对象;
  296. // nTimeout: 超时值;
  297. // 返回:TRUE返回触发成功;
  298. //----------------------------------------------------------
  299. BOOL WaitWithMessageLoop(HANDLE hEvent, int nTimeout)
  300. {
  301. DWORD dwRet = 0;
  302. while (1)
  303. {
  304. // wait for event or message, if it's a message, process it and return to waiting state
  305. dwRet = MsgWaitForMultipleObjects(1, &hEvent, FALSE, nTimeout, QS_ALLINPUT);
  306. if (dwRet == WAIT_OBJECT_0)
  307. {
  308. TRACE0("WaitWithMessageLoop() event triggered.\n");
  309. return TRUE;
  310. }
  311. else
  312. if (dwRet == WAIT_OBJECT_0 + 1)
  313. {
  314. // process window messages
  315. AfxGetApp()->PumpMessage();
  316. }
  317. else
  318. if (dwRet == WAIT_TIMEOUT)
  319. {
  320. // timed out !
  321. return FALSE;
  322. }
  323. else
  324. {
  325. // WAIT_ABANDONED_0 ...
  326. return TRUE;
  327. }
  328. }
  329. }
  330. //----------------------------------------------------------
  331. // 函数:DeleteDirectory
  332. // 描述:删除指定目录下的所有文件;
  333. // 参数:strDir:指定要删除的文件目录;
  334. // 返回:;
  335. //----------------------------------------------------------
  336. void DeleteDirectory(CString strDir)
  337. {
  338. try
  339. {
  340. // 首先删除文件及子文件夹
  341. CFileFind ff;
  342. BOOL bFound = ff.FindFile(strDir + "\\*", 0);
  343. while (bFound)
  344. {
  345. bFound = ff.FindNextFile();
  346. if (ff.GetFileName() == "." || ff.GetFileName() == "..")
  347. continue;
  348. // 去掉文件(夹)只读等属性
  349. SetFileAttributes(ff.GetFilePath(), FILE_ATTRIBUTE_NORMAL);
  350. if (ff.IsDirectory())
  351. { // 递归删除子文件夹
  352. DeleteDirectory(ff.GetFilePath());
  353. RemoveDirectory(ff.GetFilePath());
  354. }
  355. else
  356. {
  357. DeleteFile(ff.GetFilePath()); // 删除文件
  358. }
  359. }
  360. ff.Close();
  361. // 然后删除该文件夹
  362. RemoveDirectory(strDir);
  363. }
  364. catch (...)
  365. {
  366. //WriteLogin("出错在函数deldir中");
  367. }
  368. // int SHFileOperation( LPSHFILEOPSTRUCT lpFileOp );
  369. }
  370. // Jeff.注册控件函数;2014.09.11
  371. //----------------------------------------------------------
  372. // 函数:RegisterOcx
  373. // 描述:注册指定的组件文件;
  374. // 参数:ocxfile指定要注册的组件文件名;
  375. // 返回:TRUE表示注册成功;
  376. //----------------------------------------------------------
  377. BOOL RegisterOcx(LPCTSTR ocxfile)
  378. {
  379. HKEY hKey;
  380. bool bRet;
  381. USES_CONVERSION;
  382. ITypeLib* pTypeLib;
  383. CString CLSIDStr;
  384. CLSID clsid;
  385. LPOLESTR wRes = NULL;
  386. if (LoadTypeLib(T2OLE(ocxfile), &pTypeLib) == S_OK)
  387. {
  388. TLIBATTR tlibAttr, *ptlibAttr;
  389. ptlibAttr = &tlibAttr;
  390. pTypeLib->GetLibAttr(&ptlibAttr);
  391. clsid = ptlibAttr->guid;
  392. pTypeLib->Release();
  393. }
  394. ::StringFromCLSID(clsid, &wRes);
  395. CLSIDStr = OLE2CT(wRes);
  396. if ((RegOpenKeyEx(HKEY_CLASSES_ROOT, "CLSID\\" + CLSIDStr, 0, KEY_READ, &hKey) == ERROR_SUCCESS) || (RegOpenKeyEx(HKEY_CLASSES_ROOT, "Wow6432Node\\TypeLib\\" + CLSIDStr, 0, KEY_READ, &hKey) == ERROR_SUCCESS))
  397. {
  398. return true;
  399. }
  400. else
  401. {
  402. HINSTANCE hLib = LoadLibrary(ocxfile);
  403. if (hLib < (HINSTANCE)HINSTANCE_ERROR)
  404. {
  405. MessageBox(0, "权限不足,不能载入OCX文件!无法注册控件!", "结果", MB_OK);
  406. bRet = false;
  407. }
  408. else
  409. {
  410. FARPROC lpDllEntryPoint;
  411. lpDllEntryPoint = GetProcAddress(hLib, _T("DllRegisterServer"));
  412. if (lpDllEntryPoint != NULL)
  413. {
  414. if (FAILED((*lpDllEntryPoint)()))
  415. {
  416. MessageBox(0, "调用注册函数(DllRegisterServer)失败!无法注册控件!", "结果", MB_OK);
  417. bRet = false;
  418. }
  419. else
  420. bRet = true;
  421. }
  422. else
  423. {
  424. MessageBox(0, "调用注册函数(DllRegisterServer)失败!无法注册控件!", "结果", MB_OK);
  425. bRet = false;
  426. }
  427. }
  428. FreeLibrary(hLib);
  429. return bRet;
  430. }
  431. }
  432. // Jeff.Hacker. WINDOWS NT 以上的内核需要提权,才能对系统进行高级管理;
  433. //----------------------------------------------------------
  434. // 函数:GetDebugPriv
  435. // 描述:对程序提权;
  436. // 参数:
  437. // 返回:TRUE表示程序提权成功;
  438. //----------------------------------------------------------
  439. BOOL GetDebugPriv()
  440. {
  441. // 返回的访问令牌指针;
  442. HANDLE hToken;
  443. // 接收所返回的制定特权名称的信息;
  444. LUID sedebugnameValue;
  445. // 新特权信息的指针(结构体);
  446. TOKEN_PRIVILEGES tkp;
  447. DWORD dwCurProcId = GetCurrentProcessId();
  448. // 要修改访问权限的进程句柄;
  449. HANDLE hCurProc;
  450. hCurProc = ::OpenProcess(PROCESS_ALL_ACCESS, FALSE, dwCurProcId);
  451. if (!::OpenProcessToken(hCurProc, TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
  452. {
  453. ShowSystemErrorInfo(CString("提权OpenProcessToken失败。"), GetLastError());
  454. return FALSE;
  455. }
  456. if (!::LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &sedebugnameValue))
  457. {
  458. ShowSystemErrorInfo(CString("提权LookupPrivilegeValue失败。"), GetLastError());
  459. CloseHandle(hToken);
  460. return FALSE;
  461. }
  462. tkp.PrivilegeCount = 1;
  463. tkp.Privileges[0].Luid = sedebugnameValue;
  464. tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
  465. if (!::AdjustTokenPrivileges(hToken, FALSE, &tkp, sizeof tkp, NULL, NULL))
  466. {
  467. ShowSystemErrorInfo(CString("提权AdjustTokenPrivileges失败。"), GetLastError());
  468. CloseHandle(hToken);
  469. return FALSE;
  470. }
  471. CloseHandle(hCurProc);
  472. CloseHandle(hToken);
  473. return TRUE;
  474. }
  475. //----------------------------------------------------------
  476. // 函数:GetFileVersion
  477. // 描述:获取指定模块的文件版本信息
  478. // 参数:
  479. // hModule: 指定的模块(如果为NULL,表示获取自身文件版本信息);
  480. // pBuffer: 返回的文件版本信息;
  481. //
  482. // 返回:TRUE表示获取模块文件版本信息成功;
  483. //----------------------------------------------------------
  484. bool GetFileVersion(HMODULE hModule, WORD *pBuffer)
  485. {
  486. TCHAR fname[MAX_PATH];
  487. VS_FIXEDFILEINFO *pVi;
  488. DWORD dwHandle;
  489. std::string str;
  490. if (::GetModuleFileName(hModule, fname, MAX_PATH))
  491. {
  492. int size = GetFileVersionInfoSize(fname, &dwHandle);
  493. if (size > 0)
  494. {
  495. BYTE *buffer = new BYTE[size];
  496. memset(buffer, 0, size);
  497. if (GetFileVersionInfo(fname, dwHandle, size, buffer))
  498. {
  499. if (VerQueryValue(buffer, _T("\\"), (LPVOID *)&pVi, (PUINT)&size))
  500. {
  501. pBuffer[0] = HIWORD(pVi->dwFileVersionMS);
  502. pBuffer[1] = LOWORD(pVi->dwFileVersionMS);
  503. pBuffer[2] = HIWORD(pVi->dwFileVersionLS);
  504. pBuffer[3] = LOWORD(pVi->dwFileVersionLS);
  505. delete buffer;
  506. return true;
  507. }
  508. }
  509. delete buffer;
  510. }
  511. }
  512. return false;
  513. }
  514. /************************************************************************/
  515. /*
  516. 函数:GetProductVersion
  517. 描述:获取可执行文件的产品版号;
  518. 参数:
  519. hModule[IN] 可执行文件模块句柄;
  520. dwArray[OUT] 返回的产品版本号;
  521. 返回:
  522. 成功返回TRUE,失败返回FALSE;
  523. 注意:
  524. 当hModule为空时,表示要获取的可执行文件为本程序的产品版本号;
  525. */
  526. /************************************************************************/
  527. BOOL GetProductVersion(IN HMODULE hModule, IN DWORD (&dwArray)[4] )
  528. {
  529. TCHAR fname[MAX_PATH];
  530. VS_FIXEDFILEINFO *pVi;
  531. DWORD dwHandle;
  532. if (::GetModuleFileName(hModule, fname, MAX_PATH))
  533. {
  534. INT nSize = GetFileVersionInfoSize(fname, &dwHandle);
  535. if (nSize > 0)
  536. {
  537. BYTE *pBuffer = new BYTE[nSize];
  538. memset(pBuffer, 0, nSize);
  539. if (GetFileVersionInfo(fname, dwHandle, nSize, pBuffer))
  540. {
  541. if (VerQueryValue(pBuffer, "\\", (LPVOID *)&pVi, (PUINT)&nSize))
  542. {
  543. dwArray[0] = HIWORD(pVi->dwProductVersionMS);
  544. dwArray[1] = LOWORD(pVi->dwProductVersionMS);
  545. dwArray[2] = HIWORD(pVi->dwProductVersionLS);
  546. dwArray[3] = LOWORD(pVi->dwProductVersionLS);
  547. if(pBuffer)
  548. delete[]pBuffer;
  549. return TRUE;
  550. }
  551. }
  552. if(pBuffer)
  553. delete[]pBuffer;
  554. }
  555. }
  556. return FALSE;
  557. }
  558. //----------------------------------------------------------
  559. // 函数:CheckInternalIP
  560. // 描述:判断IP(网络字节序)地址是否为外网地址;
  561. // 参数:ip_addr:主机IP(必须为网络字节序);
  562. //
  563. // 返回:TRUE表示主机IP为外网IP; FALSE表示内网IP;
  564. //----------------------------------------------------------
  565. BOOL CheckInternalIPV4(const unsigned int &ip_addr)
  566. {
  567. // 三段保留IP段,做为私有地址,不在在公网上使用,只作内网IP;
  568. // A类:10.0.0.0 ~ 10.255.255.255 = 0A.00.00.00 ~ 0A.FF.FF.FF
  569. // B类:172.16.0.0 ~ 172.31.255.255 = AC.10.00.00 ~ AC.1F.FF.FF
  570. // C类:192.168.0.0 ~ 192.168.255.255 = C0.A8.00.00 ~ C0.A8.FF.FF
  571. // D类:127.0.0.0 ~ 127.255.255.255 = 7F.00.00.00 ! 7F.FF.FF.FF (环回地址)
  572. #if 0
  573. //检查3类地址是否属于公网;
  574. if ((ip_addr >= 0x0A000000 && ip_addr <= 0x0AFFFFFF) ||
  575. (ip_addr >= 0xAC100000 && ip_addr <= 0xAC1FFFFF) ||
  576. (ip_addr >= 0xC0A80000 && ip_addr <= 0xC0A8FFFF)
  577. )
  578. {
  579. return FALSE;
  580. }
  581. return TRUE;
  582. #endif
  583. #if 0
  584. //检查3类地址是否属于内网;
  585. // 0xa -- "10.0.0.0">>24;
  586. // 0xc0a8--"192.168.0.0.">>16;
  587. // 0x2b0--"127.17.0.1">>22
  588. if ((ip_addr >> 24 == 0xa) || (ip_addr >> 16 == 0xc0a8) || (ip_addr >> 22 == 0x2b0))
  589. return FALSE;
  590. else
  591. return TRUE;
  592. #endif
  593. #if 1
  594. // 回环地址也算进去!
  595. if ((ip_addr >> 24 == 0x0A) || (ip_addr >> 20 == 0xAC1) || (ip_addr >> 16 == 0xC0A8) || (ip_addr >> 26 == 0x7))
  596. return FALSE;
  597. else
  598. return TRUE;
  599. #endif
  600. }
  601. //----------------------------------------------------------
  602. // 函数:IsValidIPV4
  603. // 描述:判断字符串是否是有效的IPV4;
  604. // 参数:szIP:主机IP;
  605. //
  606. // 返回:TRUE表示字符串为有效的IPV4;
  607. //----------------------------------------------------------
  608. BOOL IsValidIPV4(const TCHAR *szIP)
  609. {
  610. int nIndex = 0;
  611. int nPointCount = 0; // "."IPV4有3个;
  612. int nLen = strlen(szIP);
  613. for (int i = 0; i < nLen; i++)
  614. {
  615. if (szIP[i] == '.')
  616. {
  617. if (i == 0 || i == nLen - 1)
  618. {
  619. return FALSE;
  620. }
  621. else
  622. {
  623. if (++nIndex != i)
  624. {
  625. nIndex = i;
  626. nPointCount++;
  627. }
  628. else
  629. return FALSE;
  630. }
  631. continue;
  632. }
  633. if (isdigit(szIP[i]) == 0)
  634. return FALSE;
  635. }
  636. if (nPointCount != 3)
  637. return FALSE;
  638. return TRUE;
  639. }
  640. //----------------------------------------------------------
  641. // 函数:GetHostAllOfIP
  642. // 描述:返回指定主机名称的所有IPV4地址;
  643. // 参数:
  644. // pHostName: 主机名;
  645. // vtHostIPV4:指定主机名的所有IPV4地址;
  646. //
  647. // 返回:TRUE表示字符串为有效的IPV4;
  648. //----------------------------------------------------------
  649. int GetHostAllOfIP(const TCHAR *pHostName, std::vector<std::string> &vtHostIPV4)
  650. {
  651. #if 0
  652. WSADATA wsa = { 0 };
  653. WSAStartup(MAKEWORD(2, 2), &wsa);
  654. #endif
  655. #if 0 // YLGL项目使用不了,因为包含了旧的系统头文件;
  656. addrinfo hint, *answer, *curr;
  657. memset(&hint, 0, sizeof(addrinfo));
  658. hint.ai_family = AF_INET;
  659. hint.ai_socktype = SOCK_STREAM;
  660. int nRet = GetAddrInfo(pHostName, NULL, &hint, &answer);
  661. //int nRet = GetAddrInfo(pHostName, "5678", &hint, &answer);
  662. if (nRet != 0)
  663. {
  664. DWORD dwError = GetLastError();
  665. return;
  666. }
  667. TCHAR szIP[MAX_PATH];
  668. for (curr = answer; curr != NULL; curr = curr->ai_next)
  669. {
  670. //std::string ipstr;
  671. memset(szIP, 0, MAX_PATH);
  672. inet_ntop(AF_INET, &(((sockaddr_in*)(curr->ai_addr))->sin_addr), szIP, MAX_PATH);
  673. vtHostIPV4.push_back(szIP);
  674. }
  675. freeaddrinfo(answer);
  676. #endif
  677. return 0;
  678. }
  679. void DataToArray(CArray<CStringArray, CStringArray>*pArrayOfString, int datapos)
  680. {
  681. try
  682. {
  683. pArrayOfString->RemoveAll();
  684. if (g_nLeng == 0)
  685. {
  686. return;
  687. }
  688. // 1.code[0]数组:用作发送时,存储着操作指令;用作接收时,存储着接收数据大小???;
  689. if (g_sendhead.code[0])
  690. {
  691. // 1.1.将g_pData全局变量里保存的数据进行解压,并存储在lpszOut数组里;
  692. BYTE *lpszOut = NULL;
  693. int nOutSize = 0;
  694. LZARI Lzari;
  695. #if defined(VC70) || defined(VC60)
  696. Lzari.UnCompress(g_pData, g_nLeng, lpszOut, nOutSize);
  697. #else
  698. Lzari.UnCompress(g_pData, g_nLeng, (const BYTE*&)lpszOut, nOutSize);
  699. #endif
  700. // 1.2.将解压后的数据lpszOut附加到内存文件里;
  701. CMemFile memfile;
  702. memfile.Attach(lpszOut, nOutSize);
  703. // 1.3.将内存文件序列化保存到CArchive对象里;
  704. CArchive ar(&memfile, CArchive::load);
  705. pArrayOfString->SetSize(g_sendhead.count[0]);
  706. // 1.4.将CArchive对象里的数据,序列化到指定的CArray对象里;
  707. for (int ii = 0; ii < pArrayOfString->GetSize(); ii++)
  708. {
  709. pArrayOfString->ElementAt(ii).Serialize(ar);
  710. }
  711. // 1.5.完成数据的导出任务,释放内存;
  712. ar.Close();
  713. Lzari.Release();
  714. memfile.Detach();
  715. }
  716. else
  717. {
  718. CMemFile memfile;
  719. memfile.Attach(g_pData, g_nLeng);
  720. CArchive ar(&memfile, CArchive::load);
  721. pArrayOfString->SetSize(g_sendhead.count[0]);
  722. for (int ii = 0; ii < pArrayOfString->GetSize(); ii++)
  723. {
  724. pArrayOfString->ElementAt(ii).Serialize(ar);
  725. }
  726. ar.Close();
  727. memfile.Detach();
  728. }
  729. }
  730. catch (...)
  731. {
  732. }
  733. }
  734. void DataToArray(
  735. CArray<CStringArray, CStringArray>*pArrayOfString1,
  736. CArray<CStringArray, CStringArray>*pArrayOfString2,
  737. int datapos)
  738. {
  739. try
  740. {
  741. CArray<CStringArray, CStringArray>*parray[2] = { pArrayOfString1, pArrayOfString2 };
  742. DWORD bytereads = 0;
  743. for (int i = 0; i < 2; i++)
  744. {
  745. parray[i]->RemoveAll();
  746. if (g_sendhead.length[i] == 0)
  747. continue;
  748. if (g_sendhead.code[i])
  749. {
  750. // 1.1.将g_pData全局变量里保存的数据进行解压,并存储在lpszOut数组里;
  751. BYTE *lpszOut = NULL;
  752. int nOutSize = 0;
  753. LZARI Lzari;
  754. //Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  755. #ifdef VC60
  756. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  757. #else
  758. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  759. #endif
  760. // 1.2.将解压后的数据lpszOut附加到内存文件里;
  761. CMemFile memfile;
  762. memfile.Attach(lpszOut, nOutSize);
  763. // 1.3.将内存文件序列化保存到CArchive对象里;
  764. bytereads += g_sendhead.length[i];
  765. CArchive ar(&memfile, CArchive::load);
  766. parray[i]->SetSize(g_sendhead.count[i]);
  767. // 1.4.将CArchive对象里的数据,序列化到指定的CArray对象里;
  768. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  769. {
  770. parray[i]->ElementAt(ii).Serialize(ar);
  771. }
  772. // 1.5.完成数据的导出任务,释放内存;
  773. ar.Close();
  774. Lzari.Release();
  775. memfile.Detach();
  776. }
  777. else
  778. {
  779. CMemFile memfile;
  780. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  781. bytereads += g_sendhead.length[i];
  782. CArchive ar(&memfile, CArchive::load);
  783. parray[i]->SetSize(g_sendhead.count[i]);
  784. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  785. {
  786. parray[i]->ElementAt(ii).Serialize(ar);
  787. }
  788. ar.Close();
  789. memfile.Detach();
  790. }
  791. }
  792. }
  793. catch (...)
  794. {
  795. }
  796. }
  797. void DataToArray(
  798. CArray<CStringArray, CStringArray>*pArrayOfString1,
  799. CArray<CStringArray, CStringArray>*pArrayOfString2,
  800. CArray<CStringArray, CStringArray>*pArrayOfString3,
  801. int datapos)
  802. {
  803. try
  804. {
  805. CArray<CStringArray, CStringArray>*parray[3] = { pArrayOfString1, pArrayOfString2, pArrayOfString3 };
  806. DWORD bytereads = 0;
  807. for (int i = 0; i < 3; i++)
  808. {
  809. parray[i]->RemoveAll(); if (g_sendhead.length[i] == 0)continue;
  810. if (g_sendhead.code[i])
  811. {
  812. BYTE *lpszOut = NULL;
  813. int nOutSize = 0;
  814. LZARI Lzari;
  815. //Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  816. #ifdef VC60
  817. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  818. #else
  819. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  820. #endif
  821. CMemFile memfile;
  822. memfile.Attach(lpszOut, nOutSize);
  823. bytereads += g_sendhead.length[i];
  824. CArchive ar(&memfile, CArchive::load);
  825. parray[i]->SetSize(g_sendhead.count[i]);
  826. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  827. {
  828. parray[i]->ElementAt(ii).Serialize(ar);
  829. }
  830. ar.Close();
  831. Lzari.Release();
  832. memfile.Detach();
  833. }
  834. else
  835. {
  836. CMemFile memfile;
  837. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  838. bytereads += g_sendhead.length[i];
  839. CArchive ar(&memfile, CArchive::load);
  840. parray[i]->SetSize(g_sendhead.count[i]);
  841. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  842. {
  843. parray[i]->ElementAt(ii).Serialize(ar);
  844. }
  845. ar.Close();
  846. memfile.Detach();
  847. }
  848. }
  849. }
  850. catch (...)
  851. {
  852. }
  853. }
  854. void DataToArray(
  855. CArray<CStringArray, CStringArray>*pArrayOfString1,
  856. CArray<CStringArray, CStringArray>*pArrayOfString2,
  857. CArray<CStringArray, CStringArray>*pArrayOfString3,
  858. CArray<CStringArray, CStringArray>*pArrayOfString4,
  859. int datapos)
  860. {
  861. try
  862. {
  863. CArray<CStringArray, CStringArray>*parray[4] =
  864. {
  865. pArrayOfString1,
  866. pArrayOfString2,
  867. pArrayOfString3,
  868. pArrayOfString4
  869. };
  870. DWORD bytereads = 0;
  871. for (int i = 0; i < 4; i++)
  872. {
  873. parray[i]->RemoveAll(); if (g_sendhead.length[i] == 0)continue;
  874. if (g_sendhead.code[i])
  875. {
  876. BYTE *lpszOut = NULL;
  877. int nOutSize = 0;
  878. LZARI Lzari;
  879. //Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  880. #ifdef VC60
  881. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  882. #else
  883. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  884. #endif
  885. CMemFile memfile;
  886. memfile.Attach(lpszOut, nOutSize);
  887. bytereads += g_sendhead.length[i];
  888. CArchive ar(&memfile, CArchive::load);
  889. parray[i]->SetSize(g_sendhead.count[i]);
  890. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  891. {
  892. parray[i]->ElementAt(ii).Serialize(ar);
  893. }
  894. ar.Close();
  895. Lzari.Release();
  896. memfile.Detach();
  897. }
  898. else
  899. {
  900. CMemFile memfile;
  901. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  902. bytereads += g_sendhead.length[i];
  903. CArchive ar(&memfile, CArchive::load);
  904. parray[i]->SetSize(g_sendhead.count[i]);
  905. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  906. {
  907. parray[i]->ElementAt(ii).Serialize(ar);
  908. }
  909. ar.Close();
  910. memfile.Detach();
  911. }
  912. }
  913. }
  914. catch (...)
  915. {
  916. }
  917. }
  918. void DataToArray(
  919. CArray<CStringArray, CStringArray>*pArrayOfString1,
  920. CArray<CStringArray, CStringArray>*pArrayOfString2,
  921. CArray<CStringArray, CStringArray>*pArrayOfString3,
  922. CArray<CStringArray, CStringArray>*pArrayOfString4,
  923. CArray<CStringArray, CStringArray>*pArrayOfString5,
  924. int datapos)
  925. {
  926. try
  927. {
  928. CArray<CStringArray, CStringArray>*parray[5] =
  929. {
  930. pArrayOfString1,
  931. pArrayOfString2,
  932. pArrayOfString3,
  933. pArrayOfString4,
  934. pArrayOfString5
  935. };
  936. DWORD bytereads = 0;
  937. for (int i = 0; i < 5; i++)
  938. {
  939. parray[i]->RemoveAll();
  940. if (g_sendhead.length[i] == 0)
  941. continue;
  942. if (g_sendhead.code[i])
  943. {
  944. BYTE *lpszOut = NULL;
  945. int nOutSize = 0;
  946. LZARI Lzari;
  947. //Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  948. #ifdef VC60
  949. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  950. #else
  951. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  952. #endif
  953. CMemFile memfile;
  954. memfile.Attach(lpszOut, nOutSize);
  955. bytereads += g_sendhead.length[i];
  956. CArchive ar(&memfile, CArchive::load);
  957. parray[i]->SetSize(g_sendhead.count[i]);
  958. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  959. {
  960. parray[i]->ElementAt(ii).Serialize(ar);
  961. }
  962. ar.Close();
  963. Lzari.Release();
  964. memfile.Detach();
  965. }
  966. else
  967. {
  968. CMemFile memfile;
  969. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  970. bytereads += g_sendhead.length[i];
  971. CArchive ar(&memfile, CArchive::load);
  972. parray[i]->SetSize(g_sendhead.count[i]);
  973. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  974. {
  975. parray[i]->ElementAt(ii).Serialize(ar);
  976. }
  977. ar.Close();
  978. memfile.Detach();
  979. }
  980. }
  981. }
  982. catch (...)
  983. {
  984. }
  985. }
  986. void DataToArray(
  987. CArray<CStringArray, CStringArray>*pArrayOfString1,
  988. CArray<CStringArray, CStringArray>*pArrayOfString2,
  989. CArray<CStringArray, CStringArray>*pArrayOfString3,
  990. CArray<CStringArray, CStringArray>*pArrayOfString4,
  991. CArray<CStringArray, CStringArray>*pArrayOfString5,
  992. CArray<CStringArray, CStringArray>*pArrayOfString6,
  993. int datapos)
  994. {
  995. try
  996. {
  997. CArray<CStringArray, CStringArray>*parray[6] =
  998. {
  999. pArrayOfString1,
  1000. pArrayOfString2,
  1001. pArrayOfString3,
  1002. pArrayOfString4,
  1003. pArrayOfString5,
  1004. pArrayOfString6
  1005. };
  1006. DWORD bytereads = 0;
  1007. for (int i = 0; i < 6; i++)
  1008. {
  1009. parray[i]->RemoveAll();
  1010. if (g_sendhead.length[i] == 0)continue;
  1011. if (g_sendhead.code[i])
  1012. {
  1013. BYTE *lpszOut = NULL;
  1014. int nOutSize = 0;
  1015. LZARI Lzari;
  1016. //Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  1017. #ifdef VC60
  1018. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  1019. #else
  1020. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  1021. #endif
  1022. CMemFile memfile;
  1023. memfile.Attach(lpszOut, nOutSize);
  1024. bytereads += g_sendhead.length[i];
  1025. CArchive ar(&memfile, CArchive::load);
  1026. parray[i]->SetSize(g_sendhead.count[i]);
  1027. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  1028. {
  1029. parray[i]->ElementAt(ii).Serialize(ar);
  1030. }
  1031. ar.Close();
  1032. Lzari.Release();
  1033. memfile.Detach();
  1034. }
  1035. else
  1036. {
  1037. CMemFile memfile;
  1038. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  1039. bytereads += g_sendhead.length[i];
  1040. CArchive ar(&memfile, CArchive::load);
  1041. parray[i]->SetSize(g_sendhead.count[i]);
  1042. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  1043. {
  1044. parray[i]->ElementAt(ii).Serialize(ar);
  1045. }
  1046. ar.Close();
  1047. memfile.Detach();
  1048. }
  1049. }
  1050. }
  1051. catch (...)
  1052. {
  1053. }
  1054. }
  1055. void DataToArray(
  1056. CArray<CStringArray, CStringArray>*pArrayOfString1,
  1057. CArray<CStringArray, CStringArray>*pArrayOfString2,
  1058. CArray<CStringArray, CStringArray>*pArrayOfString3,
  1059. CArray<CStringArray, CStringArray>*pArrayOfString4,
  1060. CArray<CStringArray, CStringArray>*pArrayOfString5,
  1061. CArray<CStringArray, CStringArray>*pArrayOfString6,
  1062. CArray<CStringArray, CStringArray>*pArrayOfString7,
  1063. int datapos)
  1064. {
  1065. try
  1066. {
  1067. CArray<CStringArray, CStringArray>*parray[7] =
  1068. {
  1069. pArrayOfString1,
  1070. pArrayOfString2,
  1071. pArrayOfString3,
  1072. pArrayOfString4,
  1073. pArrayOfString5,
  1074. pArrayOfString6,
  1075. pArrayOfString7
  1076. };
  1077. DWORD bytereads = 0;
  1078. for (int i = 0; i < 7; i++)
  1079. {
  1080. parray[i]->RemoveAll();
  1081. if (g_sendhead.length[i] == 0)continue;
  1082. if (g_sendhead.code[i])
  1083. {
  1084. BYTE *lpszOut = NULL;
  1085. int nOutSize = 0;
  1086. LZARI Lzari;
  1087. //Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  1088. #ifdef VC60
  1089. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  1090. #else
  1091. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  1092. #endif
  1093. CMemFile memfile;
  1094. memfile.Attach(lpszOut, nOutSize);
  1095. bytereads += g_sendhead.length[i];
  1096. CArchive ar(&memfile, CArchive::load);
  1097. parray[i]->SetSize(g_sendhead.count[i]);
  1098. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  1099. {
  1100. parray[i]->ElementAt(ii).Serialize(ar);
  1101. }
  1102. ar.Close();
  1103. Lzari.Release();
  1104. memfile.Detach();
  1105. }
  1106. else
  1107. {
  1108. CMemFile memfile;
  1109. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  1110. bytereads += g_sendhead.length[i];
  1111. CArchive ar(&memfile, CArchive::load);
  1112. parray[i]->SetSize(g_sendhead.count[i]);
  1113. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  1114. {
  1115. parray[i]->ElementAt(ii).Serialize(ar);
  1116. }
  1117. ar.Close();
  1118. memfile.Detach();
  1119. }
  1120. }
  1121. }
  1122. catch (...)
  1123. {
  1124. }
  1125. }
  1126. void DataToArray(
  1127. CArray<CStringArray, CStringArray>*pArrayOfString1,
  1128. CArray<CStringArray, CStringArray>*pArrayOfString2,
  1129. CArray<CStringArray, CStringArray>*pArrayOfString3,
  1130. CArray<CStringArray, CStringArray>*pArrayOfString4,
  1131. CArray<CStringArray, CStringArray>*pArrayOfString5,
  1132. CArray<CStringArray, CStringArray>*pArrayOfString6,
  1133. CArray<CStringArray, CStringArray>*pArrayOfString7,
  1134. CArray<CStringArray, CStringArray>*pArrayOfString8,
  1135. int datapos)
  1136. {
  1137. try
  1138. {
  1139. CArray<CStringArray, CStringArray>*parray[8] =
  1140. {
  1141. pArrayOfString1,
  1142. pArrayOfString2,
  1143. pArrayOfString3,
  1144. pArrayOfString4,
  1145. pArrayOfString5,
  1146. pArrayOfString6,
  1147. pArrayOfString7,
  1148. pArrayOfString8
  1149. };
  1150. DWORD bytereads = 0;
  1151. for (int i = 0; i < 8; i++)
  1152. {
  1153. parray[i]->RemoveAll();
  1154. if (g_sendhead.length[i] == 0)continue;
  1155. if (g_sendhead.code[i])
  1156. {
  1157. BYTE *lpszOut = NULL;
  1158. int nOutSize = 0;
  1159. LZARI Lzari;
  1160. //Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  1161. #ifdef VC60
  1162. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  1163. #else
  1164. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  1165. #endif
  1166. CMemFile memfile;
  1167. memfile.Attach(lpszOut, nOutSize);
  1168. bytereads += g_sendhead.length[i];
  1169. CArchive ar(&memfile, CArchive::load);
  1170. parray[i]->SetSize(g_sendhead.count[i]);
  1171. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  1172. {
  1173. parray[i]->ElementAt(ii).Serialize(ar);
  1174. }
  1175. ar.Close();
  1176. Lzari.Release();
  1177. memfile.Detach();
  1178. }
  1179. else
  1180. {
  1181. CMemFile memfile;
  1182. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  1183. bytereads += g_sendhead.length[i];
  1184. CArchive ar(&memfile, CArchive::load);
  1185. parray[i]->SetSize(g_sendhead.count[i]);
  1186. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  1187. {
  1188. parray[i]->ElementAt(ii).Serialize(ar);
  1189. }
  1190. ar.Close();
  1191. memfile.Detach();
  1192. }
  1193. }
  1194. }
  1195. catch (...)
  1196. {
  1197. }
  1198. }
  1199. void DataToArray(
  1200. CArray<CStringArray, CStringArray>*pArrayOfString1,
  1201. CArray<CStringArray, CStringArray>*pArrayOfString2,
  1202. CArray<CStringArray, CStringArray>*pArrayOfString3,
  1203. CArray<CStringArray, CStringArray>*pArrayOfString4,
  1204. CArray<CStringArray, CStringArray>*pArrayOfString5,
  1205. CArray<CStringArray, CStringArray>*pArrayOfString6,
  1206. CArray<CStringArray, CStringArray>*pArrayOfString7,
  1207. CArray<CStringArray, CStringArray>*pArrayOfString8,
  1208. CArray<CStringArray, CStringArray>*pArrayOfString9,
  1209. CArray<CStringArray, CStringArray>*pArrayOfString10,
  1210. int datapos)
  1211. {
  1212. try
  1213. {
  1214. CArray<CStringArray, CStringArray>*parray[10] =
  1215. {
  1216. pArrayOfString1,
  1217. pArrayOfString2,
  1218. pArrayOfString3,
  1219. pArrayOfString4,
  1220. pArrayOfString5,
  1221. pArrayOfString6,
  1222. pArrayOfString7,
  1223. pArrayOfString8,
  1224. pArrayOfString9,
  1225. pArrayOfString10
  1226. };
  1227. DWORD bytereads = 0;
  1228. for (int i = 0; i < 10; i++)
  1229. {
  1230. parray[i]->RemoveAll();
  1231. if (g_sendhead.length[i] == 0)continue;
  1232. if (g_sendhead.code[i])
  1233. {
  1234. BYTE *lpszOut = NULL;
  1235. int nOutSize = 0;
  1236. LZARI Lzari;
  1237. //Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  1238. #ifdef VC60
  1239. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], lpszOut, nOutSize);
  1240. #else
  1241. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  1242. #endif
  1243. CMemFile memfile;
  1244. memfile.Attach(lpszOut, nOutSize);
  1245. bytereads += g_sendhead.length[i];
  1246. CArchive ar(&memfile, CArchive::load);
  1247. parray[i]->SetSize(g_sendhead.count[i]);
  1248. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  1249. {
  1250. parray[i]->ElementAt(ii).Serialize(ar);
  1251. }
  1252. ar.Close();
  1253. Lzari.Release();
  1254. memfile.Detach();
  1255. }
  1256. else
  1257. {
  1258. CMemFile memfile;
  1259. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  1260. bytereads += g_sendhead.length[i];
  1261. CArchive ar(&memfile, CArchive::load);
  1262. parray[i]->SetSize(g_sendhead.count[i]);
  1263. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  1264. {
  1265. parray[i]->ElementAt(ii).Serialize(ar);
  1266. }
  1267. ar.Close();
  1268. memfile.Detach();
  1269. }
  1270. }
  1271. }
  1272. catch (...)
  1273. {
  1274. }
  1275. }
  1276. // 从缓存中加载图片;
  1277. void LoadImageFromBuf(Bitmap **img, BYTE *pData, DWORD leng)
  1278. {
  1279. try
  1280. {
  1281. if (pData == NULL)return;
  1282. if (*img)delete *img;
  1283. *img = NULL;
  1284. // Allocate global memory on which to create stream
  1285. HGLOBAL m_hMem = GlobalAlloc(GMEM_MOVEABLE, leng);
  1286. if (m_hMem == NULL)return;
  1287. BYTE* pmem = (BYTE*)GlobalLock(m_hMem);
  1288. memcpy(pmem, pData, leng);
  1289. IStream* pstm;
  1290. CreateStreamOnHGlobal(m_hMem, TRUE, &pstm);
  1291. // load from stream
  1292. *img = Gdiplus::Bitmap::FromStream(pstm);
  1293. // free/release stuff
  1294. GlobalUnlock(m_hMem);
  1295. pstm->Release();
  1296. }
  1297. catch (...)
  1298. {
  1299. }
  1300. }
  1301. void LoadImageFromFile(Image **img, CString path)
  1302. {
  1303. try
  1304. {
  1305. if (!PathFileExists(path))return;
  1306. if (*img)delete *img;
  1307. *img = NULL;
  1308. BSTR bstr = path.AllocSysString();
  1309. *img = Image::FromFile(bstr);
  1310. SysFreeString(bstr);
  1311. }
  1312. catch (...)
  1313. {
  1314. }
  1315. }
  1316. void LoadImageFromFile(Bitmap **img, CString path)
  1317. {
  1318. try
  1319. {
  1320. if (!PathFileExists(path))return;
  1321. if (*img)delete *img;
  1322. *img = NULL;
  1323. BSTR bstr = path.AllocSysString();
  1324. *img = Bitmap::FromFile(bstr);
  1325. SysFreeString(bstr);
  1326. }
  1327. catch (...)
  1328. {
  1329. }
  1330. }
  1331. void LoadImageFromBuf(Image **img, BYTE *pData, DWORD leng)
  1332. {
  1333. try
  1334. {
  1335. if (pData == NULL)return;
  1336. if (*img)delete *img;
  1337. *img = NULL;
  1338. // Allocate global memory on which to create stream
  1339. HGLOBAL m_hMem = GlobalAlloc(GMEM_MOVEABLE, leng);
  1340. if (m_hMem == NULL)return;
  1341. BYTE* pmem = (BYTE*)GlobalLock(m_hMem);
  1342. memcpy(pmem, pData, leng);
  1343. IStream* pstm;
  1344. CreateStreamOnHGlobal(m_hMem, TRUE, &pstm);
  1345. // load from stream
  1346. *img = Gdiplus::Image::FromStream(pstm);
  1347. // free/release stuff
  1348. GlobalUnlock(m_hMem);
  1349. pstm->Release();
  1350. }
  1351. catch (...)
  1352. {
  1353. }
  1354. }
  1355. void LoadImageFromBuf(Image **img, CString path)
  1356. {
  1357. try
  1358. {
  1359. CFile fp;
  1360. if (fp.Open(path, CFile::modeRead))
  1361. {
  1362. DWORD leng = fp.GetLength();
  1363. BYTE *pData = new BYTE[leng];
  1364. fp.Read(pData, leng);
  1365. fp.Close();
  1366. LoadImageFromBuf(img, pData, leng);
  1367. delete[]pData;
  1368. }
  1369. }
  1370. catch (...)
  1371. {
  1372. }
  1373. }
  1374. void LoadImageFromBuf(Bitmap **img, CString path)
  1375. {
  1376. try
  1377. {
  1378. CFile fp;
  1379. if (fp.Open(path, CFile::modeRead))
  1380. {
  1381. DWORD leng = fp.GetLength();
  1382. BYTE *pData = new BYTE[leng];
  1383. fp.Read(pData, leng);
  1384. fp.Close();
  1385. LoadImageFromBuf(img, pData, leng);
  1386. delete[]pData;
  1387. }
  1388. }
  1389. catch (...)
  1390. {
  1391. }
  1392. }
  1393. void LoadImageFromRes(Image **img, LPCTSTR lpszResourceName, LPCTSTR ResourceType)
  1394. {
  1395. try
  1396. {
  1397. HGLOBAL hGlobal = NULL;
  1398. HRSRC hSource = NULL;
  1399. LPVOID lpVoid = NULL;
  1400. int nSize = 0;
  1401. BOOL bResult = FALSE;
  1402. hSource = FindResource(NULL, lpszResourceName, ResourceType);
  1403. if (hSource == NULL)return;
  1404. hGlobal = LoadResource(NULL, hSource);
  1405. if (hGlobal == NULL)return;
  1406. lpVoid = LockResource(hGlobal);
  1407. if (lpVoid == NULL)return;
  1408. nSize = (UINT)SizeofResource(NULL, hSource);
  1409. LoadImageFromBuf(img, (BYTE*)hGlobal, nSize);
  1410. UnlockResource(hGlobal); // 16Bit Windows Needs This
  1411. FreeResource(hGlobal); // 16Bit Windows Needs This (32Bit - Automatic Release)
  1412. }
  1413. catch (...)
  1414. {
  1415. }
  1416. }
  1417. int GetOrientation(Image *image)
  1418. {
  1419. try
  1420. {
  1421. if (image)
  1422. {
  1423. UINT totalBufferSize;
  1424. UINT numProperties;
  1425. image->GetPropertySize(&totalBufferSize, &numProperties);
  1426. // Allocate the buffer that will receive the property items.
  1427. PropertyItem* pAllItems = (PropertyItem*)malloc(totalBufferSize);
  1428. // Fill the buffer.
  1429. image->GetAllPropertyItems(totalBufferSize, numProperties, pAllItems);
  1430. // Print the id data member of each property item.
  1431. for (UINT j = 0; j < numProperties; ++j)
  1432. {
  1433. if (PropertyTagOrientation == pAllItems[j].id)
  1434. {
  1435. short* ptrLong = (short*)(pAllItems[j].value);
  1436. int ret = (int)*ptrLong;
  1437. free(pAllItems);
  1438. return ret;
  1439. }
  1440. }
  1441. free(pAllItems);
  1442. }
  1443. }
  1444. catch (...)
  1445. {
  1446. }
  1447. return 1;
  1448. }
  1449. int GetEncoderClsid(const WCHAR* format, CLSID* pClsid)
  1450. {
  1451. UINT num = 0; // number of image encoders
  1452. UINT size = 0; // size of the image encoder array in bytes
  1453. ImageCodecInfo* pImageCodecInfo = NULL;
  1454. GetImageEncodersSize(&num, &size);
  1455. if (size == 0)
  1456. return -1; // Failure
  1457. pImageCodecInfo = (ImageCodecInfo*)(malloc(size));
  1458. if (pImageCodecInfo == NULL)
  1459. return -1; // Failure
  1460. GetImageEncoders(num, size, pImageCodecInfo);
  1461. for (UINT j = 0; j < num; ++j)
  1462. {
  1463. if (wcscmp(pImageCodecInfo[j].MimeType, format) == 0)
  1464. {
  1465. *pClsid = pImageCodecInfo[j].Clsid;
  1466. free(pImageCodecInfo);
  1467. return j; // Success
  1468. }
  1469. }
  1470. free(pImageCodecInfo);
  1471. return -1; // FailureFailure
  1472. }
  1473. void SaveImageToFile(Image *img, CString path)
  1474. {
  1475. try
  1476. {
  1477. if (img == NULL)return;
  1478. CLSID encoderClsid;
  1479. BSTR bstr = path.AllocSysString();
  1480. path.MakeLower();
  1481. if (path.Right(3) == "bmp")
  1482. {
  1483. GetEncoderClsid(L"image/bmp", &encoderClsid);
  1484. img->Save(bstr, &encoderClsid, NULL);
  1485. }
  1486. else if (path.Right(3) == "png")
  1487. {
  1488. GetEncoderClsid(L"image/png", &encoderClsid);
  1489. img->Save(bstr, &encoderClsid, NULL);
  1490. }
  1491. else// if(path.Right (3)=="jpg")
  1492. {
  1493. GetEncoderClsid(L"image/jpeg", &encoderClsid);
  1494. EncoderParameters encoderParameters;
  1495. ULONG quality;
  1496. encoderParameters.Count = 1;
  1497. encoderParameters.Parameter[0].Guid = EncoderQuality;
  1498. encoderParameters.Parameter[0].Type = EncoderParameterValueTypeLong;
  1499. encoderParameters.Parameter[0].NumberOfValues = 1;
  1500. // Save the image as a JPEG with quality level 100.
  1501. quality = 100;
  1502. encoderParameters.Parameter[0].Value = &quality;
  1503. img->Save(bstr, &encoderClsid, &encoderParameters);
  1504. }
  1505. SysFreeString(bstr);
  1506. }
  1507. catch (...)
  1508. {
  1509. }
  1510. }
  1511. void SaveImageToFile2(Image *img, CString path, ULONG quality)
  1512. {
  1513. try
  1514. {
  1515. if (img == NULL)return;
  1516. CLSID encoderClsid;
  1517. BSTR bstr = path.AllocSysString();
  1518. path.MakeLower();
  1519. if (path.Right(3) == "bmp")
  1520. {
  1521. GetEncoderClsid(L"image/bmp", &encoderClsid);
  1522. img->Save(bstr, &encoderClsid, NULL);
  1523. }
  1524. else if (path.Right(3) == "png")
  1525. {
  1526. GetEncoderClsid(L"image/png", &encoderClsid);
  1527. img->Save(bstr, &encoderClsid, NULL);
  1528. }
  1529. else// if(path.Right (3)=="jpg")
  1530. {
  1531. GetEncoderClsid(L"image/jpeg", &encoderClsid);
  1532. EncoderParameters encoderParameters;
  1533. encoderParameters.Count = 1;
  1534. encoderParameters.Parameter[0].Guid = EncoderQuality;
  1535. encoderParameters.Parameter[0].Type = EncoderParameterValueTypeLong;
  1536. encoderParameters.Parameter[0].NumberOfValues = 1;
  1537. // Save the image as a JPEG with quality level 100.
  1538. encoderParameters.Parameter[0].Value = &quality;
  1539. img->Save(bstr, &encoderClsid, &encoderParameters);
  1540. }
  1541. SysFreeString(bstr);
  1542. }
  1543. catch (...)
  1544. {
  1545. }
  1546. }
  1547. void IsWaiter2(CString id, CString name, CArray<CStringArray, CStringArray>*waiterarray, BOOL &bWait1, BOOL &bWait2, float &fscale1, float &fscale2, BOOL bCheckDate, CString date1, CString date2)
  1548. {
  1549. for (int i = 0; i < waiterarray->GetSize(); i++)
  1550. {
  1551. if (id == waiterarray->ElementAt(i).ElementAt(0))
  1552. {
  1553. if (bCheckDate)
  1554. {
  1555. if (waiterarray->ElementAt(i).ElementAt(21) < date1 || waiterarray->ElementAt(i).ElementAt(21) > date2 || waiterarray->ElementAt(i).ElementAt(22) != "OK")
  1556. {
  1557. bWait1 = bWait2 = 0;
  1558. return;
  1559. }
  1560. }
  1561. if (name == waiterarray->ElementAt(i).ElementAt(1))
  1562. {
  1563. bWait1 = 1;
  1564. fscale1 = atof(waiterarray->ElementAt(i).ElementAt(5)) / 100.0;
  1565. if (fscale1 == 0)fscale1 = 1;
  1566. }
  1567. else if (name == waiterarray->ElementAt(i).ElementAt(2))
  1568. {
  1569. bWait1 = 1;
  1570. fscale1 = atof(waiterarray->ElementAt(i).ElementAt(6)) / 100.0;
  1571. }
  1572. else if (name == waiterarray->ElementAt(i).ElementAt(3))
  1573. {
  1574. bWait1 = 1;
  1575. fscale1 = atof(waiterarray->ElementAt(i).ElementAt(7)) / 100.0;
  1576. }
  1577. else if (name == waiterarray->ElementAt(i).ElementAt(4))
  1578. {
  1579. bWait1 = 1;
  1580. fscale1 = atof(waiterarray->ElementAt(i).ElementAt(8)) / 100.0;
  1581. }
  1582. ///////////////////////////////////////////////////////////////////////
  1583. if (name == waiterarray->ElementAt(i).ElementAt(9))
  1584. {
  1585. bWait2 = 1;
  1586. fscale2 = atof(waiterarray->ElementAt(i).ElementAt(13)) / 100.0;
  1587. if (fscale2 == 0)fscale2 = 1;
  1588. }
  1589. else if (name == waiterarray->ElementAt(i).ElementAt(10))
  1590. {
  1591. bWait2 = 1;
  1592. fscale2 = atof(waiterarray->ElementAt(i).ElementAt(14)) / 100.0;
  1593. }
  1594. else if (name == waiterarray->ElementAt(i).ElementAt(11))
  1595. {
  1596. bWait2 = 1;
  1597. fscale2 = atof(waiterarray->ElementAt(i).ElementAt(15)) / 100.0;
  1598. }
  1599. else if (name == waiterarray->ElementAt(i).ElementAt(12))
  1600. {
  1601. bWait2 = 1;
  1602. fscale2 = atof(waiterarray->ElementAt(i).ElementAt(16)) / 100.0;
  1603. }
  1604. return;
  1605. }
  1606. }
  1607. return;
  1608. }
  1609. void IsWaiter3(CString id, CString name, CArray<CStringArray, CStringArray>*waiterarray, BOOL &bWait1, BOOL &bWait2, float &fscale1, float &fscale2)
  1610. {
  1611. bWait1 = bWait2 = 0;
  1612. for (int i = 0; i < waiterarray->GetSize(); i++)
  1613. {
  1614. if (id == waiterarray->ElementAt(i).ElementAt(0))
  1615. {
  1616. if (name == waiterarray->ElementAt(i).ElementAt(17))
  1617. {
  1618. bWait1 = 1;
  1619. fscale1 = atof(waiterarray->ElementAt(i).ElementAt(19)) / 100.0;
  1620. if (fscale1 == 0)fscale1 = 1;
  1621. }
  1622. ///////////////////////////////////////////////////////////////////////
  1623. if (name == waiterarray->ElementAt(i).ElementAt(18))
  1624. {
  1625. bWait2 = 1;
  1626. fscale2 = atof(waiterarray->ElementAt(i).ElementAt(20)) / 100.0;
  1627. }
  1628. return;
  1629. }
  1630. }
  1631. return;
  1632. }
  1633. //------------------------------------------------------------------------------
  1634. // Remark by Jeff;
  1635. // 函数:CheckPhoneType
  1636. // 描述:判断手机号属于哪个运营商的;
  1637. // 参数:
  1638. // phoneno: 欲判断的手机号;
  1639. //
  1640. // 返回:返回0表示移动; 1表示联通; 2表示电信; 3表示小灵通; -1表示未知的;
  1641. //
  1642. // 注意:
  1643. // 移动:
  1644. // 139, 138, 137, 136, 135, 134, 159, 158, 152, 151, 150, 157, 188, 187, 144
  1645. // 联通:
  1646. // 130, 131, 132, 155, 156, 186, 185
  1647. // 电信 :
  1648. // 133, 153, 189, 180, 181
  1649. //------------------------------------------------------------------------------
  1650. int CheckPhoneType(CString &phoneno)
  1651. {
  1652. if (phoneno.IsEmpty())
  1653. return -1;
  1654. int i = 0;
  1655. for ( i = 0; i < phoneno.GetLength(); i++)
  1656. {
  1657. if (phoneno.GetAt(i) < '0' || phoneno.GetAt(i) > '9')return -1;
  1658. }
  1659. if (phoneno.GetAt(0) == '1')
  1660. {
  1661. if (phoneno.GetLength() != 11)
  1662. return -1;
  1663. int mobile[] = { 139, 138, 137, 136, 135, 134, 159, 158, 152, 151, 150, 157, 188, 187, 144, 182, 147, 183, 184, 178 };
  1664. int unicom[] = { 130, 131, 132, 155, 156, 186, 185, 176 };
  1665. int telecom[] = { 133, 153, 189, 180, 181, 170, 171,172,173,174,175,176,177,178,179 };
  1666. for (i = 0; i < sizeof(mobile) / sizeof(int); i++)
  1667. {
  1668. if (mobile[i] == atoi(phoneno.Left(3)))
  1669. {
  1670. return 0;
  1671. }
  1672. }
  1673. for (i = 0; i < sizeof(unicom) / sizeof(int); i++)
  1674. {
  1675. if (unicom[i] == atoi(phoneno.Left(3)))
  1676. {
  1677. return 1;
  1678. }
  1679. }
  1680. for (i = 0; i < sizeof(telecom) / sizeof(int); i++)
  1681. {
  1682. if (telecom[i] == atoi(phoneno.Left(3)))
  1683. {
  1684. return 2;
  1685. }
  1686. }
  1687. return -1;
  1688. }
  1689. return -1;
  1690. }
  1691. BOOL CheckDateOK(CString &str)
  1692. {
  1693. if (str.IsEmpty())return 1;
  1694. CString tip;
  1695. int i;
  1696. CString demo = CTime::GetCurrentTime().Format("%Y-%m-%d");
  1697. if (str.GetLength() != demo.GetLength())
  1698. goto ll;
  1699. //2009-01-01
  1700. if (str.GetAt(4) != '-')
  1701. goto ll;
  1702. if (str.GetAt(7) != '-')
  1703. goto ll;
  1704. for (i = 0; i < str.GetLength(); i++)
  1705. {
  1706. if (i == 4 || i == 7)continue;
  1707. if (str.GetAt(i) < '0' || str.GetAt(i) > '9')
  1708. goto ll;
  1709. }
  1710. return 1;
  1711. ll:
  1712. tip.Format("日期:%s格式错误!\r\n样板:%s", str, demo);
  1713. AfxMessageBox(tip, MB_ICONSTOP);
  1714. return 0;
  1715. }
  1716. BOOL CheckBadWords(CString str, BOOL bMsg)
  1717. {
  1718. CString badwords[165] = { \
  1719. "【call5.me】", \
  1720. "您可拨020", \
  1721. "88btt.com热线400611", \
  1722. "400678165", \
  1723. "海王星", \
  1724. "博天堂", \
  1725. "十八大", \
  1726. "钓鱼岛", \
  1727. "无限次数提款", \
  1728. "广东地和", \
  1729. "利来", \
  1730. "抢劫", \
  1731. "fa lun", \
  1732. "强奸", \
  1733. "dafa", \
  1734. "falun", \
  1735. "SIM卡抽奖", \
  1736. "罢工", \
  1737. "罢课", \
  1738. "暴乱", \
  1739. "婊子", \
  1740. "操你", \
  1741. "操你娘", \
  1742. "蠢猪", \
  1743. "达赖", \
  1744. "打倒", \
  1745. "大法", \
  1746. "大纪元", \
  1747. "弹药", \
  1748. "钓鱼岛", \
  1749. "东突", \
  1750. "东突厥斯坦伊斯兰运动", \
  1751. "发抡", \
  1752. "发仑", \
  1753. "发伦", \
  1754. "发囵", \
  1755. "发沦", \
  1756. "发纶", \
  1757. "发轮", \
  1758. "发论", \
  1759. "法 轮 功", \
  1760. "法.轮.功", \
  1761. "法抡", \
  1762. "法仑", \
  1763. "法伦", \
  1764. "法囵", \
  1765. "法沦", \
  1766. "法纶", \
  1767. "法轮", \
  1768. "法论", \
  1769. "反革命", \
  1770. "反日", \
  1771. "分裂", \
  1772. "干你娘", \
  1773. "功友", \
  1774. "古怪歌", \
  1775. "国研新闻邮件", \
  1776. "黑庄", \
  1777. "宏志", \
  1778. "洪志", \
  1779. "胡锦涛", \
  1780. "鸡巴", \
  1781. "鸡毛信文汇", \
  1782. "妓女", \
  1783. "简鸿章", \
  1784. "江八点", \
  1785. "江独裁", \
  1786. "江泽民", \
  1787. "疆独", \
  1788. "教徒", \
  1789. "锦涛", \
  1790. "靖国神社", \
  1791. "九、评", \
  1792. "九.评", \
  1793. "九码", \
  1794. "九-评", \
  1795. "拉丹", \
  1796. "拉登", \
  1797. "李鹏", \
  1798. "联总之声传单", \
  1799. "灵动卡", \
  1800. "六合彩", \
  1801. "六码", \
  1802. "吕秀莲", \
  1803. "绿色环保手机", \
  1804. "美国之音", \
  1805. "猛料", \
  1806. "迷药", \
  1807. "民运", \
  1808. "民猪", \
  1809. "嫖娼", \
  1810. "迫害", \
  1811. "枪支", \
  1812. "强奸", \
  1813. "窃听器", \
  1814. "人民报", \
  1815. "人民报讯", \
  1816. "人民大众时事参考", \
  1817. "人民内情真相", \
  1818. "人民真实报道", \
  1819. "人权", \
  1820. "日你妈", \
  1821. "日他", \
  1822. "三码", \
  1823. "三陪", \
  1824. "色情", \
  1825. "傻B", \
  1826. "涉日", \
  1827. "十六大", \
  1828. "示威", \
  1829. "他妈的", \
  1830. "台*湾", \
  1831. "特等奖", \
  1832. "天葬", \
  1833. "突厥斯坦", \
  1834. "推翻", \
  1835. "王八蛋", \
  1836. "温家宝", \
  1837. "无能", \
  1838. "香港总部", \
  1839. "小鸡鸡", \
  1840. "新华举报", \
  1841. "新华内情", \
  1842. "新闻封锁", \
  1843. "畜生", \
  1844. "玄`机", \
  1845. "压迫", \
  1846. "淫秽", \
  1847. "银行联合管理局", \
  1848. "印尼伊斯兰祈祷团", \
  1849. "游行", \
  1850. "舆论", \
  1851. "造反", \
  1852. "真善忍", \
  1853. "镇压", \
  1854. "正法", \
  1855. "政变", \
  1856. "政治风波", \
  1857. "中俄边界新约", \
  1858. "中国银联", \
  1859. "中华民国", \
  1860. "中奖", \
  1861. "朱容基", \
  1862. "自焚", \
  1863. "自由运动", \
  1864. "达赖", \
  1865. "套牌", \
  1866. "情妇", \
  1867. "监听", \
  1868. "巴南电信", \
  1869. "合川分公司", \
  1870. "合川电信", \
  1871. "死光", \
  1872. "116114", \
  1873. "北京宝诚", \
  1874. "华盛投资", \
  1875. "名门国际", \
  1876. "利博", \
  1877. "赤橙黄绿", \
  1878. "免佣BJL首发", \
  1879. "洗*码优惠", \
  1880. "【俱乐部】", \
  1881. "18266381922", \
  1882. "回拨卡", \
  1883. "号码百事通推出短信订机票!实时" };
  1884. for (int i = 0; i < 165; i++)
  1885. {
  1886. g_temp = badwords[i];
  1887. if (str.Find(g_temp) != -1)
  1888. {
  1889. // AfxMessageBox("信息服务商禁止的非法字符:("+g_temp+")希望您谅解!");
  1890. return 0;
  1891. }
  1892. }
  1893. return 1;
  1894. }
  1895. ///目录是否存在的检查: 支持网络文件夹
  1896. bool CheckFolderFileExist(CString &strPath)
  1897. {
  1898. CString path = strPath;
  1899. CFile fp;
  1900. if (fp.Open(path, CFile::modeRead))
  1901. {
  1902. fp.Close();
  1903. return 1;
  1904. }
  1905. if (strPath.Right(1) != "\\")
  1906. path += "\\";
  1907. path += "zaqw1234.dat";
  1908. ::DeleteFile(path);
  1909. if (fp.Open(path, CFile::modeCreate) == 0)
  1910. return 0;
  1911. fp.Close();
  1912. ::DeleteFile(path);
  1913. return 1;
  1914. }
  1915. int FindArray(CStringArray *pArray, const CString &Str)
  1916. {
  1917. for (int i = 0; i < pArray->GetSize(); i++)
  1918. {
  1919. if (pArray->ElementAt(i) == Str)
  1920. return i;
  1921. }
  1922. return -1;
  1923. }
  1924. void FillLength(CString &str, int length)
  1925. {
  1926. while (str.GetLength() < length)
  1927. str += " ";
  1928. }
  1929. int GetYearPos(int year)
  1930. {
  1931. for (int i = 0; i < g_hisyeararray.GetSize(); i++)
  1932. {
  1933. if (year == atoi(g_hisyeararray.ElementAt(i).ElementAt(0)))
  1934. return i;
  1935. }
  1936. return -1;
  1937. }
  1938. BOOL GIsHalfHZ(const CString &str)
  1939. {
  1940. int len = str.GetLength();
  1941. BOOL IsHalf = FALSE;
  1942. for (int i = 0; i < len; i++)
  1943. {
  1944. if (str.GetAt(i) < 0) IsHalf = !IsHalf;
  1945. }
  1946. return IsHalf;
  1947. }
  1948. void WriteTitle(CString str)
  1949. {
  1950. g_title = str;
  1951. CStdioFile fp;
  1952. fp.Open(g_mainpath + "\\title.txt", CFile::modeWrite | CFile::modeCreate);
  1953. fp.WriteString(str);
  1954. fp.Close();
  1955. }
  1956. CString GetIP(CString branch)
  1957. {
  1958. for (int i = 0; i < g_brancharray.GetSize(); i++)
  1959. {
  1960. if (g_domain == g_brancharray.ElementAt(i).ElementAt(2))
  1961. {
  1962. //if(g_serverbak.Find (".ly.com")!=-1)
  1963. return g_server;
  1964. CString ip = g_serverbak;
  1965. MyGetIPByName(ip);
  1966. return ip;
  1967. }
  1968. if (branch == g_brancharray.ElementAt(i).ElementAt(0))
  1969. {
  1970. return g_brancharray.ElementAt(i).ElementAt(1);
  1971. }
  1972. }
  1973. return "";
  1974. }
  1975. BOOL IsHanZi(CString str)
  1976. {
  1977. TBYTE ucHigh, ucLow;
  1978. for (int i = 0; i < str.GetLength(); i++)
  1979. {
  1980. if ((TBYTE)str[i] < 0x80)
  1981. {
  1982. continue;
  1983. }
  1984. ucHigh = (TBYTE)str[i];
  1985. ucLow = (TBYTE)str[i + 1];
  1986. if (ucHigh < 0xa1 || ucLow < 0xa1)
  1987. {
  1988. continue;
  1989. }
  1990. return 1;
  1991. }
  1992. return 0;
  1993. }
  1994. int GetType(CString str)
  1995. {
  1996. if (IsHanZi(str))return 0;
  1997. BOOL bDigit = 1;
  1998. BOOL bAlpha = 1;
  1999. for (int i = 0; i < str.GetLength(); i++)
  2000. {
  2001. if (!::isdigit(str.GetAt(i)))
  2002. //if(! ((str.GetAt (i)<='0' && str.GetAt (i)>='9' ) ))
  2003. bDigit = 0;
  2004. if (!((str.GetAt(i) <= 'z' && str.GetAt(i) >= 'a') || (str.GetAt(i) <= 'Z' && str.GetAt(i) >= 'A')))
  2005. //else if(!::isalpha ( ((unsigned char)str.GetAt (i))))
  2006. bAlpha = 0;
  2007. if (bDigit == 0 && bAlpha == 0)return 0;
  2008. }
  2009. if (bDigit)
  2010. {
  2011. /*#ifdef SUNRAIN_VERSION
  2012. return 0;
  2013. #else*/
  2014. return 0;
  2015. //#endif
  2016. }
  2017. else if (bAlpha)
  2018. {
  2019. return 2;
  2020. }
  2021. else
  2022. return 0;
  2023. }
  2024. CString FilterBZ(CString &bz)
  2025. {
  2026. bz.Replace("'", "");
  2027. /* int i=bz.GetLength ()-1;
  2028. char c;
  2029. for(;i>=0;i--)
  2030. {
  2031. c=bz.GetAt (i);
  2032. if(c<32)// && c!=10 && c!=13)
  2033. bz.Delete (i);
  2034. }*/
  2035. if (bz.GetLength() > 1023)
  2036. {
  2037. AfxMessageBox("文字太长, 字符串将被截取!", MB_ICONSTOP);
  2038. bz = bz.Left(1023);
  2039. }
  2040. return bz;
  2041. }
  2042. // GetWidth()的长度与CRect的长度是不一样的单位值,需要转换适合的比例;(一个是图片的像素尺寸,一个DC的大小尺寸)
  2043. // 将图片尺寸与设备尺寸进行转换适合的比例;
  2044. void RectFitDes(int width, int height, CRect &rc)
  2045. {
  2046. try
  2047. {
  2048. if (width == 0 || height == 0)return;
  2049. // 图片长宽比例;
  2050. float fscale = (float)width / (float)height;
  2051. // 设备长宽比例;
  2052. float rcscale = ((float)rc.Width()) / ((float)rc.Height());
  2053. int rcwid = rc.Width();
  2054. int rchei = rc.Height();
  2055. int dt = 0;
  2056. // Jeff.如果设备长宽比例 < 图片长宽比例;(即相同长度下,高越大比例值越小,所以此时图片尺寸 与 显示设备的尺寸相比,要显得更长)
  2057. if (rcscale < fscale)
  2058. {
  2059. // Jeff.remarks
  2060. // 调整显示设备的大小,以使之能容纳图片尺寸;(即长宽比例上,要大于或等于图片的长宽比例)
  2061. // 所以有两种方法使得 rcscale >= fscale 表达式成立:
  2062. // -----------------------------------------------
  2063. // 方法1:显示设备宽加x值,计算出下面表达式x的值即可
  2064. // (rc.Width()+x) / rc.Height() >= width/height;
  2065. // 方法2:显示设备高减x值,计算出下面表达式x的值即可
  2066. // (rc.Width()) / (rc.Height()-x) >= width/height;
  2067. //------------------------------------------------
  2068. // 两种方法的最后表达式为:
  2069. // x >= rc.Height() - rcWidth()*(height/width);
  2070. // 即 x >= rc.Height() - rcWidth()/fscale;
  2071. //------------------------------------------------
  2072. dt = (rchei - rcwid / fscale) / 2;
  2073. rc.top += dt;
  2074. rc.bottom -= dt;
  2075. }
  2076. else
  2077. {
  2078. dt = (rcwid - rchei*fscale) / 2;
  2079. rc.left += dt;
  2080. rc.right -= dt;
  2081. }
  2082. }
  2083. catch (...)
  2084. {
  2085. }
  2086. }
  2087. BOOL IsHasRights(int pos)
  2088. {
  2089. return 1;
  2090. if (g_user.rights.GetLength() > pos)
  2091. {
  2092. BOOL ret = atoi(g_user.rights.Mid(pos, 1));
  2093. if (ret == 0)AfxMessageBox("没有相关权限!", MB_ICONINFORMATION);
  2094. return ret;
  2095. }
  2096. AfxMessageBox("没有相关权限!", MB_ICONINFORMATION);
  2097. return 0;
  2098. }
  2099. BOOL IsHasRights2(int pos)
  2100. {
  2101. return 1;
  2102. if (g_user.rights.GetLength() > pos)
  2103. {
  2104. BOOL ret = atoi(g_user.rights.Mid(pos, 1));
  2105. return ret;
  2106. }
  2107. return 0;
  2108. }
  2109. BOOL IsHasRightsnew(int pos)
  2110. {
  2111. if (g_user.rights.GetLength() > pos)
  2112. {
  2113. BOOL ret = atoi(g_user.rights.Mid(pos, 1));
  2114. if (ret == 0)AfxMessageBox("没有相关权限! 请与系统管理员联系!", MB_ICONINFORMATION);
  2115. return ret;
  2116. }
  2117. AfxMessageBox("没有相关权限! 请与系统管理员联系!", MB_ICONINFORMATION);
  2118. return 0;
  2119. }
  2120. BOOL IsHasRights2new(int pos)
  2121. {
  2122. if (g_user.rights.GetLength() > pos)
  2123. {
  2124. BOOL ret = atoi(g_user.rights.Mid(pos, 1));
  2125. return ret;
  2126. }
  2127. return 0;
  2128. }
  2129. /********************************************************************************************
  2130. /* Syntax
  2131. /* void FirstLetter(int nCode, CString& strLetter)
  2132. /* Remarks:
  2133. /* Get the first letter of pinyin according to specified Chinese character code.
  2134. /* Parameters:
  2135. /* nCode - the code of the chinese character.
  2136. /* strLetter - a CString object that is to receive the string of the first letter.
  2137. /* Return Values:
  2138. /* None.
  2139. /* Author:
  2140. /* lixiaosan
  2141. /* Create Date:
  2142. /* 05-26-2006
  2143. /********************************************************************************************/
  2144. void FirstLetter(int nCode, CString& strLetter)
  2145. {
  2146. if (nCode >= 1601 && nCode < 1637) strLetter = _T("A");
  2147. if (nCode >= 1637 && nCode < 1833) strLetter = _T("B");
  2148. if (nCode >= 1833 && nCode < 2078) strLetter = _T("C");
  2149. if (nCode >= 2078 && nCode < 2274) strLetter = _T("D");
  2150. if (nCode >= 2274 && nCode < 2302) strLetter = _T("E");
  2151. if (nCode >= 2302 && nCode < 2433) strLetter = _T("F");
  2152. if (nCode >= 2433 && nCode < 2594) strLetter = _T("G");
  2153. if (nCode >= 2594 && nCode < 2787) strLetter = _T("H");
  2154. if (nCode >= 2787 && nCode < 3106) strLetter = _T("J");
  2155. if (nCode >= 3106 && nCode < 3212) strLetter = _T("K");
  2156. if (nCode >= 3212 && nCode < 3472) strLetter = _T("L");
  2157. if (nCode >= 3472 && nCode < 3635) strLetter = _T("M");
  2158. if (nCode >= 3635 && nCode < 3722) strLetter = _T("N");
  2159. if (nCode >= 3722 && nCode < 3730) strLetter = _T("O");
  2160. if (nCode >= 3730 && nCode < 3858) strLetter = _T("P");
  2161. if (nCode >= 3858 && nCode < 4027) strLetter = _T("Q");
  2162. if (nCode >= 4027 && nCode < 4086) strLetter = _T("R");
  2163. if (nCode >= 4086 && nCode < 4390) strLetter = _T("S");
  2164. if (nCode >= 4390 && nCode < 4558) strLetter = _T("T");
  2165. if (nCode >= 4558 && nCode < 4684) strLetter = _T("W");
  2166. if (nCode >= 4684 && nCode < 4925) strLetter = _T("X");
  2167. if (nCode >= 4925 && nCode < 5249) strLetter = _T("Y");
  2168. if (nCode >= 5249 && nCode < 5590) strLetter = _T("Z");
  2169. }
  2170. /********************************************************************************************
  2171. /* Syntax
  2172. /* GetFirstLetter(CString strName, CString& strFirstLetter)
  2173. /* Remarks:
  2174. /* Get the first letter of pinyin according to specified Chinese character.
  2175. /* Parameters:
  2176. /* strName - a CString object that is to be parsed.
  2177. /* strFirstLetter - a CString object that is to receive the string of the first letter.
  2178. /* Return Values:
  2179. /* None.
  2180. /* Author:
  2181. /* lixiaosan
  2182. /* Create Date:
  2183. /* 05-26-2006
  2184. /********************************************************************************************/
  2185. void GetFirstLetter(CString strName, CString& strFirstLetter)
  2186. {
  2187. TBYTE ucHigh, ucLow;
  2188. int nCode;
  2189. CString strRet;
  2190. strFirstLetter.Empty();
  2191. for (int i = 0; i < strName.GetLength(); i++)
  2192. {
  2193. if ((TBYTE)strName[i] < 0x80)
  2194. {
  2195. strRet = strName.Mid(i, 1);
  2196. strRet.MakeUpper();
  2197. strFirstLetter += strRet;
  2198. continue;
  2199. }
  2200. ucHigh = (TBYTE)strName[i];
  2201. ucLow = (TBYTE)strName[i + 1];
  2202. if (ucHigh < 0xa1 || ucLow < 0xa1)
  2203. continue;
  2204. else
  2205. // Treat code by section-position as an int type parameter,
  2206. // so make following change to nCode.
  2207. nCode = (ucHigh - 0xa0) * 100 + ucLow - 0xa0;
  2208. FirstLetter(nCode, strRet);
  2209. strFirstLetter += strRet;
  2210. i++;
  2211. }
  2212. }
  2213. CString newGUID()
  2214. {
  2215. CString str;
  2216. GUID guid;
  2217. CoInitialize(NULL);
  2218. if (S_OK == ::CoCreateGuid(&guid))
  2219. {
  2220. str.Format(
  2221. "{%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X}",
  2222. guid.Data1,
  2223. guid.Data2,
  2224. guid.Data3,
  2225. guid.Data4[0], guid.Data4[1],
  2226. guid.Data4[2], guid.Data4[3],
  2227. guid.Data4[4], guid.Data4[5],
  2228. guid.Data4[6], guid.Data4[7]);
  2229. }
  2230. CoUninitialize();
  2231. return str.Left(28);
  2232. }
  2233. CString GetNameFromDomain(CString domain)
  2234. {
  2235. for (int i = 0; i < g_brancharray.GetSize(); i++)
  2236. {
  2237. if (domain == g_brancharray.ElementAt(i).ElementAt(2))
  2238. {
  2239. return g_brancharray.ElementAt(i).ElementAt(0);
  2240. }
  2241. }
  2242. return "";
  2243. }
  2244. void ConvertToPrice(CString &str)
  2245. {
  2246. if (str.Find('.') == -1)return;
  2247. str.TrimRight('0');
  2248. str.TrimRight('.');
  2249. }
  2250. int GetLengthEx(CString str)
  2251. {
  2252. wchar_t wstr[500];
  2253. int k = MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, str, strlen(str), wstr, 500);
  2254. return k;
  2255. }
  2256. inline int MultiByteLengthConvertToWideCharLength(/*LPCSTR*/LPCCH lpString)
  2257. {
  2258. return MultiByteToWideChar(CP_ACP, 0, lpString, -1, NULL, 0);
  2259. }
  2260. BOOL myisdigit(CString str)
  2261. {
  2262. for (int i = 0; i < str.GetLength(); i++)
  2263. {
  2264. if (!::isdigit(str.GetAt(i)))
  2265. return 0;
  2266. }
  2267. return 1;
  2268. }
  2269. BOOL IsHasRightsnew2(int pos, CString rights)
  2270. {
  2271. if (rights.GetLength() > pos)
  2272. {
  2273. BOOL ret = atoi(rights.Mid(pos, 1));
  2274. if (ret == 0)AfxMessageBox("没有相关权限! 请与系统管理员联系!", MB_ICONINFORMATION);
  2275. return ret;
  2276. }
  2277. AfxMessageBox("没有相关权限! 请与系统管理员联系!", MB_ICONINFORMATION);
  2278. return 0;
  2279. }
  2280. DWORD FindAppProcessID(CString path)
  2281. {
  2282. try
  2283. {
  2284. HANDLE handle = ::CreateToolhelp32Snapshot(TH32CS_SNAPALL, 0);
  2285. PROCESSENTRY32 Info;
  2286. Info.dwSize = sizeof(PROCESSENTRY32);
  2287. path.MakeLower();
  2288. if (::Process32First(handle, &Info))
  2289. {
  2290. do
  2291. {
  2292. CString ss = Info.szExeFile;
  2293. ss.MakeLower();
  2294. if (ss.Find(path) != -1 || (!ss.CompareNoCase(path)))
  2295. {
  2296. ::CloseHandle(handle);
  2297. return Info.th32ProcessID;
  2298. }
  2299. } while (::Process32Next(handle, &Info));
  2300. ::CloseHandle(handle);
  2301. }
  2302. return -1;
  2303. }
  2304. catch (...)
  2305. {
  2306. }
  2307. }
  2308. BOOL isInnerIP(DWORD a_ip) // Jeff.判断是否是内网?
  2309. {
  2310. BOOL bValid = 0;
  2311. if ((a_ip >> 24 == 0xa) || (a_ip >> 16 == 0xc0a8) || (a_ip >> 22 == 0x2b0))
  2312. {
  2313. bValid = 1;
  2314. }
  2315. return bValid;
  2316. }
  2317. void MyGetIPByName2(CString &name)
  2318. {
  2319. CString strIP = name;
  2320. name.Empty();
  2321. DWORD dwServerIP = 0;
  2322. HOSTENT *host = gethostbyname(strIP);
  2323. struct in_addr addr;
  2324. if (host != NULL)
  2325. {
  2326. for (int i = 0; host->h_addr_list[i] != NULL; i++)
  2327. {
  2328. memset(&addr, 0, sizeof(addr));
  2329. memcpy(&addr.S_un.S_addr, host->h_addr_list[i], host->h_length);
  2330. dwServerIP = ntohl(addr.S_un.S_addr);
  2331. BYTE* pIP = (BYTE*)&dwServerIP;
  2332. name.Format(_T("%d.%d.%d.%d"), pIP[3], pIP[2], pIP[1], pIP[0]);
  2333. }
  2334. }
  2335. }
  2336. void MyGetIPByName(CString &name) // Jeff.根据计算机名称获取IP地址;
  2337. {
  2338. g_serverarray.RemoveAll();
  2339. CString strIP = name;
  2340. name.Empty();
  2341. DWORD dwServerIP = 0;
  2342. HOSTENT *host = gethostbyname(strIP); // Jeff.所有本机的网络适配器;
  2343. struct in_addr addr;
  2344. if (host != NULL)
  2345. {
  2346. // Jeff.遍历本机所有适配器的IP地址;
  2347. for (int i = 0; host->h_addr_list[i] != NULL; i++)
  2348. {
  2349. memset(&addr, 0, sizeof(addr));
  2350. memcpy(&addr.S_un.S_addr, host->h_addr_list[i], host->h_length);
  2351. dwServerIP = ntohl(addr.S_un.S_addr);
  2352. BYTE* pIP = (BYTE*)&dwServerIP;
  2353. name.Format(_T("%d.%d.%d.%d"), pIP[3], pIP[2], pIP[1], pIP[0]);
  2354. g_serverarray.Add(name);
  2355. }
  2356. }
  2357. while (g_serverarray.GetSize() > 1)
  2358. {
  2359. CString name;
  2360. BOOL bFind = 0;
  2361. for (int i = 0; i < g_serverarray.GetSize(); i++)
  2362. {
  2363. DWORD dwServerIP = inet_addr(g_serverarray.ElementAt(i));
  2364. dwServerIP = htonl(dwServerIP);//加了才正确
  2365. if (isInnerIP(dwServerIP) == 0)
  2366. {
  2367. // AfxMessageBox("外部IP");
  2368. g_serverarray.RemoveAt(i);
  2369. bFind = 1;
  2370. break;
  2371. }
  2372. // else
  2373. // AfxMessageBox("内部IP");
  2374. }
  2375. if (bFind == 0)
  2376. {
  2377. break;
  2378. }
  2379. }
  2380. }
  2381. int IsExistFolder(char *szPath)//可判断文件夹和文件的存在;
  2382. {
  2383. if ((_access(szPath, 0)) != -1)
  2384. {
  2385. //printf("Jeff:File %s \t exists \n",szPath );
  2386. /* Check for write permission */
  2387. if ((_access(szPath, 2)) != -1)
  2388. {
  2389. //printf("Jeff:File %s \t has write permission \n",szPath );
  2390. CString str;
  2391. str.Format("共享文件夹<%s>: 存在!\n", szPath);
  2392. WriteClientLog(str);
  2393. return 1;
  2394. }
  2395. // else // 只能判断文件权限,不能判断目录;
  2396. // {
  2397. // CString str;
  2398. // str.Format("共享文件夹<%s>:\t存在,不可写!■■■■■■■\n",szPath);
  2399. // WriteClientLog(str);
  2400. //
  2401. // return 0;
  2402. // }
  2403. }
  2404. else
  2405. {
  2406. //printf("Jeff:\t File %s no exists \n",szPath );
  2407. CString str;
  2408. str.Format("◆共享文件夹<%s>: 不存在,请设置共享或访问权限!◆\n", szPath);
  2409. WriteClientLog(str);
  2410. return -1;
  2411. }
  2412. }
  2413. CString GetW(CString str)
  2414. {
  2415. int x = atoi(str);
  2416. if (x > 9999)
  2417. {
  2418. str.Format("%d", x);
  2419. str = str.Right(5);
  2420. str = str.Left(1);
  2421. return str;
  2422. }
  2423. return "";
  2424. }
  2425. CString GetK(CString str)
  2426. {
  2427. int x = atoi(str);
  2428. if (x > 999)
  2429. {
  2430. str.Format("%d", x);
  2431. str = str.Right(4);
  2432. str = str.Left(1);
  2433. return str;
  2434. }
  2435. return "";
  2436. }
  2437. CString GetB(CString str)
  2438. {
  2439. int x = atoi(str);
  2440. if (x > 99)
  2441. {
  2442. str.Format("%d", x);
  2443. str = str.Right(3);
  2444. str = str.Left(1);
  2445. return str;
  2446. }
  2447. return "";
  2448. }
  2449. CString GetS(CString str)
  2450. {
  2451. int x = atoi(str);
  2452. if (x > 9)
  2453. {
  2454. str.Format("%d", x);
  2455. str = str.Right(2);
  2456. str = str.Left(1);
  2457. return str;
  2458. }
  2459. return "";
  2460. }
  2461. CString GetG(CString str)
  2462. {
  2463. int x = atoi(str);
  2464. if (x > 0)
  2465. {
  2466. str.Format("%d", x);
  2467. str = str.Right(1);
  2468. return str;
  2469. }
  2470. return "";
  2471. }
  2472. CString GetHMoney(CString str)
  2473. {
  2474. if (str.IsEmpty())return "";
  2475. if (str == "0")return "零";
  2476. if (atoi(str) < 1 || atoi(str) > 9)return "";
  2477. CString ret[] = { "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖" };
  2478. return ret[atoi(str) - 1];
  2479. }
  2480. BOOL CheckDateOK2(CString str)
  2481. {
  2482. if (str.IsEmpty())return 0;
  2483. CString tip;
  2484. int i;
  2485. CString demo = CTime::GetCurrentTime().Format("%Y-%m-%d");
  2486. if (str.GetLength() != demo.GetLength())
  2487. goto ll;
  2488. //2009-01-01
  2489. if (str.GetAt(4) != '-')
  2490. goto ll;
  2491. if (str.GetAt(7) != '-')
  2492. goto ll;
  2493. for (i = 0; i < str.GetLength(); i++)
  2494. {
  2495. if (i == 4 || i == 7)continue;
  2496. if (str.GetAt(i) < '0' || str.GetAt(i) > '9')
  2497. goto ll;
  2498. }
  2499. return 1;
  2500. ll:
  2501. return 0;
  2502. }
  2503. CString GetDomainFromBranch(CString branch)
  2504. {
  2505. if (branch.IsEmpty())return "";
  2506. for (int i = 0; i < g_brancharray.GetSize(); i++)
  2507. {
  2508. if (branch == g_brancharray.ElementAt(i).ElementAt(0))
  2509. {
  2510. return g_brancharray.ElementAt(i).ElementAt(2);
  2511. }
  2512. }
  2513. return "";
  2514. }
  2515. CString GetBranchPhotoPath(CString branch)
  2516. {
  2517. if (branch.IsEmpty())return "";
  2518. for (int i = 0; i < g_brancharray.GetSize() - 1; i++)
  2519. {
  2520. if (branch == g_brancharray.ElementAt(i).ElementAt(0))
  2521. {
  2522. return "\\" + g_brancharray.ElementAt(i).ElementAt(2);
  2523. }
  2524. }
  2525. return "";
  2526. }
  2527. CTime GetTmFromStr(CString date)
  2528. {
  2529. try
  2530. {
  2531. CTime tm(atoi(date.Mid(0, 4)), atoi(date.Mid(5, 2)), atoi(date.Mid(8, 2)), 0, 0, 0);
  2532. CString ss;
  2533. ss.Format("%d-%d-%d", tm.GetYear(), tm.GetMonth(), tm.GetDay());
  2534. return tm;
  2535. }
  2536. catch (...)
  2537. {
  2538. date = "1980-01-01";
  2539. CTime tm(atoi(date.Mid(0, 4)), atoi(date.Mid(5, 2)), atoi(date.Mid(8, 2)), 0, 0, 0);
  2540. return tm;
  2541. }
  2542. }
  2543. COleDateTime GetDateTimeByString(CString strDateTime)
  2544. {
  2545. try
  2546. {
  2547. INT nYear = 0, nMonth = 0, nDay =0, nHour = 0, nMinute = 0, nSecond = 0;
  2548. _stscanf(strDateTime, _T("%d-%d-%d %d:%d"), &nYear, &nMonth, &nDay, &nHour, &nMinute);
  2549. COleDateTime tm(nYear, nMonth, nDay, nHour, nMinute, nSecond);
  2550. return tm;
  2551. }
  2552. catch (CException* e)
  2553. {
  2554. strDateTime = _T("1900-01-01 00:00:00");
  2555. INT nYear = 0, nMonth = 0, nDay =0, nHour = 0, nMinute = 0, nSecond = 0;
  2556. _stscanf(strDateTime, _T("%d-%d-%d %d:%d"), &nYear, &nMonth, &nDay, &nHour, &nMinute);
  2557. COleDateTime tm(nYear, nMonth, nDay, nHour, nMinute, nSecond);
  2558. return tm;
  2559. }
  2560. }
  2561. //---------------------------------------------------------------------
  2562. // add by Jeff 2014.10.24
  2563. // 函数:全局函数lyfzCopyFileEx
  2564. // 描述:文件复制。
  2565. // 参数:
  2566. // lpExistingFileName:你要拷贝的源文件名;
  2567. // lpNewFileName: 你要拷贝的目标文件名;
  2568. // bFailIfExists: 如果目标已经存在,不拷贝(True)并重命名,覆盖目标(false)
  2569. // 返回:与CopyFile返回一致;
  2570. //---------------------------------------------------------------------
  2571. BOOL lyfzCopyFileEx(LPCTSTR lpExistingFileName, LPCTSTR lpNewFileName, const BOOL &bFailIfExists)
  2572. {
  2573. // 1.如果是覆盖选项;
  2574. if (!bFailIfExists)
  2575. return CopyFile(lpExistingFileName, lpNewFileName, bFailIfExists);
  2576. // 2.如果不是覆盖选项;
  2577. TCHAR szNewFileName[_MAX_PATH] = { 0 };
  2578. TCHAR szDrive[_MAX_DRIVE] = { 0 };
  2579. TCHAR szDir[_MAX_DIR] = { 0 };
  2580. TCHAR szFna[_MAX_FNAME] = { 0 };
  2581. TCHAR szExt[_MAX_EXT] = { 0 };
  2582. sprintf(szNewFileName, "%s", lpNewFileName);
  2583. _tsplitpath(szNewFileName, szDrive, szDir, szFna, szExt);
  2584. int nIndex = 1;
  2585. while (PathFileExists(szNewFileName))
  2586. {
  2587. sprintf(szNewFileName, "%s%s%s (%d)%s", szDrive, szDir, szFna, nIndex++, szExt);
  2588. }
  2589. return CopyFile(lpExistingFileName, szNewFileName, bFailIfExists);
  2590. }
  2591. //---------------------------------------------------------------------
  2592. // add by Jeff 2014.10.24
  2593. // 函数:全局函数lyfzImportImage,多字节版本,非UNICODE
  2594. // 描述:导入图片。
  2595. // 参数:
  2596. // lpDestDirectory: 文件导入的目标目录;
  2597. // strArrayOfImage: 要导入的图片文件数组;
  2598. // bFailIfExists: 如果目标已经存在,不拷贝(True)并重命名,覆盖目标(false)
  2599. // 返回:
  2600. //
  2601. // 说明:在调用lyfzImportImage前,需要对传递的参数进行有效性验证
  2602. // 1.验证形参lpDestDirectory对应的实参是否是有效的目录(有无创建目录的非法字符存在)
  2603. // 2.验证形参strArrayOfImage对应的实参数组是否大于0;
  2604. // 如果校验没有通过,应该拒绝调lyfzImportImage,以防止错误产生。
  2605. //---------------------------------------------------------------------
  2606. void lyfzImportImage(LPCTSTR lpDestDirectory, CStringArray &strArrayOfImage, const BOOL &bFailIfExists)
  2607. {
  2608. // 传递给lyfzCreateDirectory的参数规范化;
  2609. int nlen = strlen(lpDestDirectory);
  2610. TCHAR szNewFileName[_MAX_PATH] = { 0 };
  2611. TCHAR szTempDirectory[_MAX_PATH] = { 0 };
  2612. if (lpDestDirectory[nlen - 1] != '\\')
  2613. sprintf(szTempDirectory, "%s\\", lpDestDirectory);
  2614. else
  2615. sprintf(szTempDirectory, "%s", lpDestDirectory);
  2616. // 若目录或子目录不存在创建;
  2617. lyfzCreateDirectory(szTempDirectory);
  2618. // 遍历复制;
  2619. CString strImage;
  2620. INT_PTR nSize = strArrayOfImage.GetSize();
  2621. for (INT_PTR i = 0; i < nSize; i++)
  2622. {
  2623. strImage = strArrayOfImage.ElementAt(i);
  2624. strImage = strImage.Mid(strImage.ReverseFind('\\') + 1);
  2625. //strImage = strImage.Left(strImage.ReverseFind('.'));
  2626. sprintf(szNewFileName, "%s%s", szTempDirectory, strImage);
  2627. lyfzCopyFileEx(szNewFileName, strArrayOfImage.ElementAt(i), bFailIfExists);
  2628. }
  2629. }
  2630. //---------------------------------------------------------------------
  2631. // add by Jeff 2014.10.25
  2632. // 函数:全局函数lyfzCreateDirectory,多字节版本,非UNICODE
  2633. // 描述:创建目录及子目录文件夹;
  2634. // 参数:
  2635. // lpDestDirectory:目录,必须是"E:\lyfzdb\数据\"格式,目录最后必须有"\",否则最后一个子目录无法创建!
  2636. // 建议使用系统_tsplitpath来分隔目录,这样会保存最后一个"\"斜杠;
  2637. // 返回:成功创建返回TRUE;
  2638. //---------------------------------------------------------------------
  2639. BOOL lyfzCreateDirectory(LPCTSTR lpDestDirectory)
  2640. {
  2641. BOOL bExists = FALSE;
  2642. TCHAR szNewFileName[_MAX_PATH] = { 0 };
  2643. TCHAR szDrive[_MAX_DRIVE] = { 0 };
  2644. TCHAR szDir[_MAX_DIR] = { 0 };
  2645. TCHAR szFna[_MAX_FNAME] = { 0 };
  2646. TCHAR szExt[_MAX_EXT] = { 0 };
  2647. int nIndex = 0;
  2648. do
  2649. {
  2650. bExists = PathFileExists(lpDestDirectory);
  2651. if (!bExists)
  2652. {
  2653. memset(szDrive, 0, _MAX_DRIVE);
  2654. memset(szDir, 0, _MAX_DIR);
  2655. memset(szFna, 0, _MAX_FNAME);
  2656. memset(szExt, 0, _MAX_EXT);
  2657. lyfzSplitpath(lpDestDirectory, szDrive, szDir, ++nIndex);
  2658. sprintf(szNewFileName, _T("%s%s"), szDrive, szDir);
  2659. CreateDirectory(szNewFileName, NULL);
  2660. //if (FALSE == CreateDirectory(szNewFileName, NULL))
  2661. //{
  2662. //ShowSystemErrorInfo(CString("创建目录出错。"), GetLastError());
  2663. //return FALSE;
  2664. // continue;
  2665. //}
  2666. }
  2667. } while (!bExists);
  2668. return TRUE;
  2669. }
  2670. //---------------------------------------------------------------------
  2671. // add by Jeff 2014.10.24
  2672. // 函数:全局函数tSplitpath,多字节版本,非UNICODE
  2673. // 描述:类系统Windows C++运行库函数_tsplitpath。
  2674. // 参数:
  2675. //
  2676. // 返回:
  2677. //---------------------------------------------------------------------
  2678. void lyfzSplitpath(const char *path, char *drive, char *dir, const int &nTimes)
  2679. {
  2680. int nlen = strlen(path);
  2681. int i = 0;
  2682. int npoint = 0; // '.'
  2683. int nsprit = 0; // '\\'
  2684. int ncolon = 0; // ':'
  2685. int ntimes = -1;
  2686. while (nlen > i++)
  2687. {
  2688. if (path[i] == ':')
  2689. ncolon = i;
  2690. else if (path[i] == '\\')
  2691. {
  2692. if (nTimes == ntimes++) break;
  2693. nsprit = i;
  2694. }
  2695. }
  2696. memcpy(drive, path, ncolon + 1);
  2697. memcpy(dir, &path[ncolon + 1], nsprit - ncolon);
  2698. }
  2699. //---------------------------------------------------------------------
  2700. // Jeff add 2014.06.23;
  2701. // 函数:ShowErrorInfo
  2702. // 描述:
  2703. // 参数:
  2704. // lpszFunction:函数名;
  2705. // dwError:错误码;
  2706. // 返回:
  2707. //---------------------------------------------------------------------
  2708. void ShowSystemErrorInfo(CString &strDescription, const DWORD &dwError)
  2709. {
  2710. #if 0
  2711. LPVOID lpMsgBuf;
  2712. FormatMessage(
  2713. FORMAT_MESSAGE_ALLOCATE_BUFFER |
  2714. FORMAT_MESSAGE_FROM_SYSTEM |
  2715. FORMAT_MESSAGE_IGNORE_INSERTS,
  2716. NULL,
  2717. dwError,
  2718. MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
  2719. (LPTSTR)&lpMsgBuf,
  2720. 0, NULL);
  2721. // Display the error message and exit the process
  2722. CString strDisplay;
  2723. strDisplay.Format("失败错误码=%d,Windows内部描述:%s", dwError, lpMsgBuf);
  2724. strDescription += strDisplay;
  2725. AfxMessageBox(strDescription);
  2726. LocalFree(lpMsgBuf);
  2727. #endif
  2728. LPVOID lpMsgBuf;
  2729. BOOL fOk = FormatMessage(
  2730. FORMAT_MESSAGE_ALLOCATE_BUFFER |
  2731. FORMAT_MESSAGE_FROM_SYSTEM |
  2732. FORMAT_MESSAGE_IGNORE_INSERTS,
  2733. NULL,
  2734. dwError,
  2735. MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
  2736. (LPTSTR)&lpMsgBuf,
  2737. 0, NULL);
  2738. if (!fOk)
  2739. {
  2740. // Is it a network-related error?
  2741. HMODULE hDll = LoadLibraryEx(TEXT("netmsg.dll"), NULL, DONT_RESOLVE_DLL_REFERENCES);
  2742. if (hDll != NULL)
  2743. {
  2744. FormatMessage(
  2745. FORMAT_MESSAGE_FROM_HMODULE |
  2746. FORMAT_MESSAGE_FROM_SYSTEM |
  2747. FORMAT_MESSAGE_IGNORE_INSERTS,
  2748. hDll,
  2749. dwError,
  2750. MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US),
  2751. (LPTSTR)&lpMsgBuf,
  2752. 0,
  2753. NULL);
  2754. FreeLibrary(hDll);
  2755. }
  2756. }
  2757. if (lpMsgBuf != NULL)
  2758. {
  2759. CString strDisplay;
  2760. strDisplay.Format("%s.错误码=%d,Windows描述:%s", strDescription, dwError, (PCTSTR)LocalLock(lpMsgBuf));
  2761. //WriteLogin(strDisplay);
  2762. AfxMessageBox(strDisplay);
  2763. LocalFree(lpMsgBuf);
  2764. }
  2765. else
  2766. {
  2767. //WriteLogin(strDescription);
  2768. AfxMessageBox("未知道错误");
  2769. }
  2770. }
  2771. //---------------------------------------------------------------------
  2772. // Jeff add 2014.06.23;
  2773. // 函数:WriteClientLog
  2774. // 描述:写客户端程序日志。
  2775. // 参数:
  2776. // str:日志内容;
  2777. // 返回:
  2778. //---------------------------------------------------------------------
  2779. void WriteClientLog(const CString &strLogContent)
  2780. {
  2781. try
  2782. {
  2783. CStdioFile fp;
  2784. CString path = g_mainpath + "\\客户端日志.txt";
  2785. if (PathFileExists(path))
  2786. {
  2787. fp.Open(path, CFile::modeWrite);
  2788. int length = fp.GetLength();
  2789. if (length > 5 * 1024 * 1024)
  2790. {
  2791. fp.Close();
  2792. ::DeleteFile(path);
  2793. return;
  2794. }
  2795. fp.SeekToEnd();
  2796. }
  2797. else
  2798. fp.Open(path, CFile::modeCreate | CFile::modeWrite);
  2799. fp.WriteString(CTime::GetCurrentTime().Format("%Y-%m-%d %H:%M:%S") + " " + strLogContent + "\n");
  2800. fp.Close();
  2801. }
  2802. catch (...)
  2803. {
  2804. }
  2805. }
  2806. //---------------------------------------------------------------------
  2807. // add by Jeff 2014.10.27
  2808. // 函数:全局函数IsDirectoryLegitimate,多字节版本,非UNICODE
  2809. // 描述:判断一个目录路径字符串,是否属于合法的、可创建的目录路径。
  2810. // 参数:strDirectory 被验证的路径字符串;
  2811. //
  2812. // 返回:合法路径返回TRUE;
  2813. //---------------------------------------------------------------------
  2814. BOOL IsDirectoryLegitimate(const CString &strDirectory)
  2815. {
  2816. if (strDirectory.Find('/') != -1 ||
  2817. strDirectory.Find('\\') != -1 ||
  2818. strDirectory.Find(':') != -1 ||
  2819. strDirectory.Find('*') != -1 ||
  2820. strDirectory.Find('?') != -1 ||
  2821. strDirectory.Find('\"') != -1 ||
  2822. strDirectory.Find('>') != -1 ||
  2823. strDirectory.Find('<') != -1 ||
  2824. strDirectory.Find('|') != -1
  2825. )
  2826. return FALSE;
  2827. return TRUE;
  2828. }
  2829. //----------------------------------------------------------------------
  2830. // remark by Jeff 2014.11.08
  2831. // 函数:ExportCutImageToFile
  2832. // 描述:导出裁剪图片到指定目录;
  2833. // 参数:
  2834. // lpOrderCutImageInfo:订单号的裁剪相片信息;
  2835. // lpSrcDirectory:原图片路径;
  2836. // lpOrderCutImageInfo格式:相片名|裁剪方案|原片宽|原片高|裁剪left|裁剪top|裁剪bottom|裁剪rigth
  2837. // 225:5X7,1440,900,88,0,1352,900;228:5X7,1440,900,88,0,1352,900;224:5X7,1440,900,88,0,1352,900;227:10寸,1440,900,56,0,1384,900;229:10寸水晶,1440,900,570,232,870,671;
  2838. // lpSaveDirectory:导出相片的保存路径;
  2839. // 返回:无
  2840. //----------------------------------------------------------------------
  2841. void ExportCutImageToFile(LPCCH lpOrderCutImageInfo, LPCCH lpSrcDirectory, LPCCH lpSaveDirectory)
  2842. {
  2843. if (FALSE == lyfzCreateDirectory(lpSaveDirectory))
  2844. return;
  2845. CStringArray saSrcPhoto;
  2846. GetCountOfOrderFolderPhotoFile(lpSrcDirectory, saSrcPhoto);
  2847. CString strImageName; // 相片名;
  2848. CString strCutScheme; // 裁剪方案;
  2849. CRect rtCut; // 要裁剪的区域;
  2850. CString strTemp;
  2851. CString strImageInfo(lpOrderCutImageInfo);
  2852. int nIndex = -1;
  2853. do
  2854. {
  2855. // 225:5X7,1440,900,88,0,1352,900;
  2856. nIndex = strImageInfo.Find(';');
  2857. strTemp = strImageInfo.Left(nIndex);
  2858. strImageInfo = strImageInfo.Mid(nIndex + 1);
  2859. int SrcImageWid;
  2860. int SrcImageHei;
  2861. int ntempIndex = -1;
  2862. if (nIndex != -1)
  2863. {
  2864. if (FALSE == AnalysisImagInfo(saSrcPhoto,lpSrcDirectory, lpSaveDirectory, strTemp, strImageName, strCutScheme, rtCut))
  2865. continue;
  2866. }
  2867. else
  2868. {
  2869. if (strImageInfo.IsEmpty())
  2870. break;
  2871. AnalysisImagInfo(saSrcPhoto,lpSrcDirectory, lpSaveDirectory, strImageInfo, strImageName, strCutScheme, rtCut);
  2872. break;
  2873. }
  2874. } while (nIndex != -1);
  2875. }
  2876. //----------------------------------------------------------------------
  2877. // remark by Jeff 2014.11.08
  2878. // 函数:AnalysisImagInfo
  2879. // 描述:导出裁剪图片到指定目录;
  2880. // 参数:
  2881. // lpOrderCutImageInfo:订单号的裁剪相片信息;
  2882. // lpSrcDirectory:原图片路径;
  2883. // lpOrderCutImageInfo格式:相片名|裁剪方案|原片宽|原片高|裁剪left|裁剪top|裁剪bottom|裁剪rigth
  2884. // 225:5X7,1440,900,88,0,1352,900;
  2885. // lpSaveDirectory:导出相片的保存路径;
  2886. // 返回:无
  2887. //
  2888. // 说明:未对图片进行缩小,直接在原片上裁剪而得。
  2889. //----------------------------------------------------------------------
  2890. BOOL AnalysisImagInfo(CStringArray &saSrcPhoto, LPCCH lpSrcDirectory, LPCCH lpSaveDirectory, CString &strImageInfo, CString &strImageName, CString &strCutScheme, CRect &rtCut)
  2891. {
  2892. int ntempIndex = -1;
  2893. strImageName = strImageInfo.Left(3); // 裁剪相片名;
  2894. strImageInfo.Delete(0, 4);
  2895. CString strSrcImagePath;
  2896. BOOL bExist = FALSE;
  2897. for (int i = 0; i < saSrcPhoto.GetSize(); i++)
  2898. {
  2899. CString strTemp = saSrcPhoto.ElementAt(i);
  2900. strSrcImagePath = strTemp;
  2901. _splitpath((LPCTSTR)saSrcPhoto.ElementAt(i), NULL, NULL, strTemp.GetBuffer(0), NULL);
  2902. strTemp.ReleaseBuffer();
  2903. if ( strTemp == strImageName)
  2904. {
  2905. bExist = TRUE;
  2906. //saSrcPhoto.RemoveAt(i);
  2907. break;
  2908. }
  2909. }
  2910. if (FALSE == bExist)
  2911. return FALSE;
  2912. ntempIndex = strImageInfo.Find(',');
  2913. strCutScheme = strImageInfo.Left(ntempIndex); // 裁剪方案;
  2914. strImageInfo.Delete(0, ntempIndex + 1);
  2915. // 裁剪原图宽;
  2916. ntempIndex = strImageInfo.Find(',');
  2917. LONG SrcImageWid = _ttol(strImageInfo.Left(ntempIndex));
  2918. strImageInfo.Delete(0, ntempIndex + 1);
  2919. // 裁剪原图高;
  2920. ntempIndex = strImageInfo.Find(',');
  2921. LONG SrcImageHei = _ttol(strImageInfo.Left(ntempIndex));
  2922. strImageInfo.Delete(0, ntempIndex + 1);
  2923. // left坐标值;
  2924. ntempIndex = strImageInfo.Find(',');
  2925. rtCut.left = _ttol(strImageInfo.Left(ntempIndex));
  2926. strImageInfo.Delete(0, ntempIndex + 1);
  2927. // top坐标;
  2928. ntempIndex = strImageInfo.Find(',');
  2929. rtCut.top = _ttol(strImageInfo.Left(ntempIndex));
  2930. strImageInfo.Delete(0, ntempIndex + 1);
  2931. // right坐标;
  2932. ntempIndex = strImageInfo.Find(',');
  2933. rtCut.right = _ttol(strImageInfo.Left(ntempIndex));
  2934. strImageInfo.Delete(0, ntempIndex + 1);
  2935. // bottom坐标;
  2936. rtCut.bottom = _ttol(strImageInfo.Left(ntempIndex));
  2937. // 导出裁剪相片到指定目录;
  2938. // 1.加载原图;
  2939. Image *SrcImage = NULL;
  2940. //if (FALSE == PathFileExists(CString(lpSrcDirectory + strImageName + _T(".jpg"))))
  2941. if (FALSE == PathFileExists(strSrcImagePath))
  2942. {
  2943. AfxMessageBox(_T("相片源文件不存在"));
  2944. return FALSE;
  2945. }
  2946. //LoadImageFromBuf(&SrcImage, CString(lpSrcDirectory + strImageName + _T(".jpg")));
  2947. LoadImageFromBuf(&SrcImage, strSrcImagePath);
  2948. if (SrcImage == NULL)
  2949. {
  2950. AfxMessageBox(_T("加载源图片失败"));
  2951. return FALSE;
  2952. }
  2953. int orientation = GetOrientation(SrcImage);
  2954. if (orientation == 8)
  2955. SrcImage->RotateFlip(Rotate270FlipNone);
  2956. else if (orientation == 6)
  2957. SrcImage->RotateFlip(Rotate90FlipNone);
  2958. if (SrcImage->GetWidth() == 0)
  2959. return FALSE;
  2960. float scale = 1.0;
  2961. scale *= (float)SrcImage->GetWidth() / (float)SrcImageWid;
  2962. rtCut.left *= scale;
  2963. rtCut.right *= scale;
  2964. rtCut.top *= scale;
  2965. rtCut.bottom *= scale;
  2966. #if 0 // 保存在原图上画裁剪区域;
  2967. Graphics graph(SrcImage);
  2968. Pen blackPen(Color(255, 255, 0, 0), 1);
  2969. graph.DrawRectangle(&blackPen, rtCut.left, rtCut.top, rtCut.Width(), rtCut.Height());
  2970. SaveImageToFile(SrcImage, CString(lpSaveDirectory + strImageName + _T(".jpg")));
  2971. delete SrcImage;
  2972. #else // 直接保存裁剪后的图片;
  2973. Bitmap bp(rtCut.Width(), rtCut.Height());
  2974. Graphics *graphic = Graphics::FromImage(&bp);
  2975. graphic->Clear(Color(255, 255, 255, 255));
  2976. graphic->SetInterpolationMode(InterpolationModeHighQualityBicubic);
  2977. graphic->SetSmoothingMode(SmoothingModeHighQuality);//SmoothingModeHighSpeed
  2978. graphic->SetPixelOffsetMode(PixelOffsetModeHighQuality);
  2979. graphic->SetCompositingMode(CompositingModeSourceOver);
  2980. graphic->SetCompositingQuality(CompositingQualityHighQuality);
  2981. graphic->SetTextRenderingHint(TextRenderingHintAntiAliasGridFit);
  2982. graphic->DrawImage(SrcImage, RectF(0, 0, rtCut.Width(), rtCut.Height()), rtCut.left, rtCut.top, rtCut.Width(), rtCut.Height(), UnitPixel);
  2983. delete SrcImage;
  2984. //delete graphic;
  2985. //CString strSave;
  2986. //strSave.Format("%s%s:%s.jpg", lpSaveDirectory,strImageName,strCutScheme);
  2987. //SaveImageToFile(&bp, strSave);
  2988. SaveImageToFile(&bp, CString(lpSaveDirectory + strImageName + _T(":") + strCutScheme + _T(".jpg")));
  2989. #endif
  2990. return TRUE;
  2991. }
  2992. // 相片后缀:jpg、raw、cr2、NEF 四种常用后缀
  2993. //--------------------------------------------------------------------------------
  2994. // Remark by Jeff 2014.11.10
  2995. // 函数:GetCountOfOrderFolderPhotoFile
  2996. // 描述:获取订单文件夹下所有相片文件,不含"m"和"s"开头的小图;
  2997. // 参数:pOrderFolder:订单文件路径;
  2998. // 返回:
  2999. //
  3000. //--------------------------------------------------------------------------------
  3001. int GetCountOfOrderFolderPhotoFile( const TCHAR *pOrderFolder, CStringArray &StrPhotoArray)
  3002. {
  3003. CStringArray StrSubFoloderArray;
  3004. using namespace helper_coffs;
  3005. ffsco o;
  3006. o.dirs(1); // Jeff.1:查找子目录;
  3007. o.find(LPCTSTR(pOrderFolder), LPCTSTR(_T("*.*"))); // 可能存在m和s开头的缩略图,需要过滤掉;
  3008. if (o.count() == 0)
  3009. return 0;
  3010. // 获取子目录数;
  3011. ffsco::typeT coo;
  3012. ffsco::typeT::iterator it;
  3013. coo = o.co_dir();
  3014. for (it = coo.begin(); it != coo.end(); it++)
  3015. {
  3016. if (FindArray(&StrSubFoloderArray, (*it).c_str()) == -1)
  3017. StrSubFoloderArray.Add((*it).c_str());
  3018. }
  3019. int nIndex = -1;
  3020. CString strOrderNumberImage;
  3021. // 获取子目录下的文件数;
  3022. //CStringArray StrPhotoArray;
  3023. for (int n = 0; n < StrSubFoloderArray.GetSize(); n++)
  3024. {
  3025. ffsco op;
  3026. op.dirs(0);
  3027. op.find(LPCTSTR(StrSubFoloderArray.ElementAt(n)), LPCTSTR(_T("*.jpg")));
  3028. ffsco::typeT coo;
  3029. ffsco::typeT::iterator itp;
  3030. coo = op.co_file();
  3031. for (itp = coo.begin(); itp != coo.end(); itp++)
  3032. {
  3033. strOrderNumberImage = (*itp).c_str();
  3034. nIndex = strOrderNumberImage.ReverseFind('\\');
  3035. strOrderNumberImage = strOrderNumberImage.Right(strOrderNumberImage.GetLength() - nIndex -1);
  3036. if (strOrderNumberImage.Left(1) != _T("m") && strOrderNumberImage.Left(1) != _T("s"))
  3037. {
  3038. StrPhotoArray.Add((*itp).c_str());
  3039. }
  3040. }
  3041. }
  3042. return 0;
  3043. }