Global.cpp 111 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746
  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 "ffsco.h"
  14. #include <winver.h>
  15. #pragma comment(lib,"Version.lib")
  16. #if JEFF_TEST_ON
  17. #include <Ws2tcpip.h>
  18. #pragma comment(lib, "ws2_32.lib")//使用了ws2_32.lib就不能同时再使用WinSock
  19. #else
  20. #include <WinSock.h>
  21. #endif
  22. #if JEFF_CODE
  23. //------------------------------------------------------------------
  24. int g_nVersion = -1;
  25. static CONST BYTE g_byShotVersion[6][10] =
  26. {
  27. { 6, 0, 148, 11, 205, 50, 4, 171, 32, 39 }, // 儿童座席版;
  28. { 6, 0, 4, 29, 24, 247, 189, 95, 83, 76 }, // 婚纱座席版;
  29. { 6, 0, 4, 187, 103, 10, 59, 169, 240, 220 }, // 儿童企业版;
  30. { 6, 0, 137, 160, 230, 173, 202, 2, 117, 142 }, // 婚纱企业版;
  31. { 6, 0, 194, 199, 210, 67, 185, 1, 138, 195 }, // 儿童全能版;
  32. { 6, 0, 188, 145, 100, 47, 154, 177, 34, 205 }, // 婚纱全能版;
  33. };
  34. // start---------------加密表达式加密后的数组----------------------;
  35. static CONST BYTE g_byCalExVersion[6][114] =
  36. {
  37. // 儿童座席版;
  38. { 109, 0, 90, 15, 108, 138, 37, 190, 82, 8, 20, 252, 32, 162, 7, 8, 254, 255, 56, 245, 194, 4, 46, 120, 49, 120, 156, 27, 17, 164, 217,
  39. 79, 167, 146, 197, 69, 55, 117, 197, 149, 42, 217, 151, 195, 254, 145, 187, 197, 232, 188, 114, 223, 40, 229, 151, 245, 116, 177, 141, 94, 134, 14,
  40. 13, 169, 165, 94, 5, 216, 235, 60, 176, 38, 174, 121, 187, 174, 16, 30, 17, 20, 246, 34, 20, 252, 32, 162, 7, 8, 254, 255, 56, 245, 194,
  41. 4, 46, 120, 49, 120, 156, 27, 17, 164, 217, 79, 167, 146, 143, 132, 219, 173, 211, 2, 99, 180 },
  42. // 婚纱座席版;
  43. { 109, 0, 128, 13, 164, 143, 252, 87, 30, 48, 20, 21, 145, 114, 160, 96, 49, 127, 181, 32, 144, 213, 109, 99, 142, 219, 71, 26, 22, 220, 177,
  44. 179, 191, 82, 138, 45, 173, 160, 9, 83, 162, 106, 182, 175, 47, 92, 214, 78, 93, 21, 202, 165, 167, 200, 198, 172, 218, 74, 236, 194, 194, 228,
  45. 40, 27, 95, 60, 160, 173, 66, 185, 178, 7, 159, 220, 58, 71, 140, 19, 20, 37, 66, 84, 20, 21, 145, 114, 160, 96, 49, 127, 181, 32, 144,
  46. 213, 109, 99, 142, 219, 71, 26, 22, 220, 177, 179, 191, 82, 232, 182, 45, 27, 13, 195, 225, 204 },
  47. // 儿童企业版;
  48. { 109, 0, 229, 36, 223, 222, 213, 46, 70, 55, 240, 207, 237, 75, 226, 68, 133, 100, 42, 119, 89, 131, 79, 104, 158, 17, 172, 239, 4, 158, 201,
  49. 51, 62, 51, 94, 232, 14, 124, 81, 64, 100, 141, 187, 85, 156, 59, 205, 116, 200, 24, 108, 218, 145, 22, 7, 36, 45, 7, 156, 255, 170, 130,
  50. 165, 140, 99, 216, 120, 72, 171, 196, 27, 49, 138, 199, 137, 246, 214, 247, 121, 114, 215, 199, 240, 207, 237, 75, 226, 68, 133, 100, 42, 119, 89,
  51. 131, 79, 104, 158, 17, 172, 239, 4, 158, 201, 51, 62, 51, 248, 214, 27, 254, 221, 208, 181, 209 },
  52. // 婚纱企业版;
  53. { 109, 0, 94, 220, 40, 182, 30, 120, 56, 193, 78, 101, 1, 144, 68, 206, 192, 52, 67, 9, 243, 20, 9, 195, 153, 15, 22, 217, 243, 79, 177,
  54. 22, 24, 171, 185, 157, 172, 67, 117, 124, 153, 165, 3, 41, 218, 47, 149, 150, 48, 152, 75, 250, 204, 253, 92, 53, 121, 147, 242, 140, 80, 66,
  55. 34, 194, 16, 109, 237, 17, 222, 161, 96, 8, 11, 194, 58, 45, 86, 15, 207, 121, 247, 104, 78, 101, 1, 144, 68, 206, 192, 52, 67, 9, 243,
  56. 20, 9, 195, 153, 15, 22, 217, 243, 79, 177, 22, 24, 171, 122, 243, 190, 146, 77, 222, 208, 129 },
  57. // 儿童全能版;
  58. { 109, 0, 26, 222, 0, 239, 199, 199, 188, 225, 180, 168, 178, 208, 21, 79, 62, 90, 51, 31, 88, 128, 180, 105, 53, 137, 230, 254, 244, 50, 195,
  59. 49, 167, 143, 168, 125, 130, 125, 8, 73, 224, 120, 80, 95, 178, 49, 44, 158, 38, 38, 247, 169, 62, 187, 119, 192, 77, 194, 118, 246, 133, 241,
  60. 157, 62, 144, 24, 94, 173, 49, 192, 46, 250, 249, 239, 82, 78, 135, 3, 86, 154, 8, 135, 180, 168, 178, 208, 21, 79, 62, 90, 51, 31, 88,
  61. 128, 180, 105, 53, 137, 230, 254, 244, 50, 195, 49, 167, 143, 241, 214, 38, 180, 198, 3, 158, 165 },
  62. // 婚纱全能版;
  63. { 109, 0, 139, 145, 163, 176, 66, 18, 207, 79, 172, 200, 12, 124, 89, 151, 248, 238, 26, 85, 137, 146, 119, 58, 76, 194, 151, 239, 204, 104, 18,
  64. 166, 208, 54, 37, 85, 3, 174, 28, 74, 154, 156, 120, 194, 8, 112, 79, 42, 27, 89, 81, 95, 238, 74, 59, 199, 160, 101, 117, 179, 51, 138,
  65. 70, 176, 239, 182, 160, 212, 11, 33, 224, 74, 155, 143, 216, 10, 220, 71, 8, 168, 18, 175, 172, 200, 12, 124, 89, 151, 248, 238, 26, 85, 137,
  66. 146, 119, 58, 76, 194, 151, 239, 204, 104, 18, 166, 208, 54, 114, 118, 181, 24, 252, 41, 246, 88 },
  67. };
  68. // endof---------------加密表达式加密后的数组----------------------;
  69. // 升级包版本号;
  70. WORD g_arrFileVersion[4] = { 0 };
  71. TCHAR g_szLoginUser[MAX_PATH] = _T(""); // 当前软件的登陆用户名;
  72. TCHAR g_szLoginPsw[MAX_PATH] = _T(""); // 当前软件的登陆密码;
  73. TCHAR g_szModulePath[MAX_PATH] = _T(""); // 软件目录;
  74. TCHAR g_szModuleFileName[MAX_PATH] = _T(""); // 软件全名称;
  75. TCHAR g_szConnectString[MAX_PATH] = _T(""); // DB连接串;
  76. // 服务端主机信息;
  77. TCHAR g_szHostComputerIP[MAX_PATH] = _T(""); // 服务端主机名称;
  78. DWORD g_dwTCPChatPort = 0; // 服务端主机通信TCP端口;
  79. DWORD g_dwTCPFilePort = 0; // 服务端主机文件传输端口;
  80. // 短信服务端主机信息;
  81. TCHAR g_szSMSServer[MAX_PATH] = _T(""); // 短信服务端主机名称;
  82. DWORD g_dwTCPSMSPort = 0; // 短信服务端主机通信端口;
  83. // 数据库信息;
  84. TCHAR g_szDBSource[MAX_PATH] = _T(""); // 数据库源(服务所在IP或计算机名);
  85. TCHAR g_szDBSourcePort[MAX_PATH] = _T(""); // 数据库源端口;
  86. DWORD g_dwDBServerPort = 0; // 数据库源端口;
  87. TCHAR g_szDBAccount[MAX_PATH] = _T(""); // 数据库登录用户;
  88. TCHAR g_szDBPassWord[MAX_PATH] = _T(""); // 数据库登录密码;
  89. TCHAR g_szDBName[MAX_PATH] = _T(""); // 数据库名称;
  90. // 相片存储目录;
  91. TCHAR g_szShareHost[MAX_PATH] = _T(""); // 共享主机名;
  92. TCHAR g_szOriginalFolder[MAX_PATH] = _T(""); // 原片目录;
  93. TCHAR g_szOriginalBkFolder[MAX_PATH] = _T(""); // 原片备份目录;
  94. TCHAR g_szEarlyRepairFolder[MAX_PATH] = _T(""); // 初修片目录;
  95. TCHAR g_szEarlyRepairBkFolder[MAX_PATH] = _T(""); // 初修片备份目录;
  96. TCHAR g_szFurtherRepairFolder[MAX_PATH] = _T(""); // 精修片目录;
  97. TCHAR g_szFurtherRepairBkFolder[MAX_PATH] = _T(""); // 精修片备份目录;
  98. TCHAR g_szDesignFolder[MAX_PATH] = _T(""); // 设计片目录;
  99. TCHAR g_szDesignBkFolder[MAX_PATH] = _T(""); // 设计片备份目录;
  100. TCHAR g_szTelRecordingFolder[MAX_PATH] = _T(""); // 电话录音目录;
  101. TCHAR g_szFullDressImageFolder[MAX_PATH] = _T(""); // 礼服图片目录;
  102. #endif
  103. #if FORMER_CODE
  104. // 软件所用加密狗是否已注册医院跟踪功能; // Jeff,应该放在SoftKey做为静态变量使用;
  105. BOOL g_bSoftWareReg = FALSE;
  106. // 加密狗中的字符信息S1:如 201409062003558789.ly.com
  107. // 该全局变量在旧软件名称是:g_sdomain;
  108. // 该变量在数据库表字段[path].[path1]中存储;
  109. CString g_strDogMainInfo = _T("");
  110. // 未知用途;
  111. // 该全局变量在旧软件中名称是:CString g_bMain;
  112. // 与集团版有关联性;
  113. // 有可能是主店名称;
  114. CString g_strMain = _T("");
  115. // 分店名称数组;旧软件中名称:g_branchnamearray
  116. CStringArray g_strArrayOfBranchName;
  117. // ??
  118. CStringArray g_strArrayOfBranchName2;
  119. // 分店IP地址数组;
  120. CStringArray g_strArrayOfBranchIPAdress;
  121. // 分店的加密狗S1信息数组;
  122. CStringArray g_strArrayOfBranchDogMainInfo;
  123. // 座席版允许连接数(从加密狗中获取);
  124. unsigned int g_nCountOfAllowToConn = 0;
  125. DWORD g_nLeng = 0;
  126. BYTE *g_pData = NULL;
  127. DWORD g_nLeng2 = 0;
  128. BYTE *g_pData2 = NULL;
  129. SENDHEAD g_sendhead;
  130. BOOL g_bRedSkin = 0;
  131. COLORREF g_gridcol1 = RGB(204, 204, 204);
  132. COLORREF g_gridcol2 = RGB(190, 190, 190);
  133. COLORREF g_bkcol = RGB(184, 184, 184);
  134. CString g_date = _T("");
  135. CString g_title = _T("");
  136. CArray<CStringArray, CStringArray>g_userarray;
  137. CArray<CStringArray, CStringArray>g_cominfoarray;
  138. CArray<CStringArray, CStringArray>g_cominfoarraylocal;
  139. CArray<DWORD, DWORD>g_lengarray;
  140. CArray<DWORD, DWORD>g_btnlengarray;
  141. CArray<BYTE*, BYTE*>g_pointerarray;
  142. CBrush g_editbkbrush;
  143. DWORD g_btnleng[8] = { 0 };
  144. int g_btnlengpos = -1;
  145. int g_nYearpos = -1;
  146. CString g_branchname = _T(""); // Jeff.集团版:????本分店名称;
  147. CString g_branchip = _T("");
  148. CString g_branchip2 = _T("");
  149. BOOL g_bBranchModify = 0;
  150. BOOL g_bShowOK = 0; // Jeff:?
  151. BOOL g_bStaffAchievementShow = 0; // 此机用于员工业绩查看;
  152. BOOL g_bSaveUploadTask1 = 0;
  153. BOOL g_bSaveUploadTask2 = 0;
  154. BOOL g_bSaveUploadTask3 = 0;
  155. BOOL g_bSaveUploadTask4 = 0;
  156. BOOL g_bSearchFilter = 0;
  157. CString g_waiter1 = _T("");
  158. CString g_waiter2 = _T("");
  159. CString g_waiter3 = _T("");
  160. CString g_waiter4 = _T("");
  161. CString g_waiter5 = _T("");
  162. CString g_filterdate1 = _T("");
  163. CString g_filterdate2 = _T("");
  164. CString g_filterdate3 = _T("");
  165. CString g_filterdate4 = _T("");
  166. CString g_filterdate5 = _T("");
  167. CString g_filterdate6 = _T("");
  168. CString g_filterbranch = _T("");
  169. USER g_user;
  170. CString g_mainpath = _T(""); // 软件目录
  171. CString g_id = _T(""); //
  172. CString g_server = _T(""); // 服务端地址
  173. CStringArray g_serverarray; //
  174. CString g_serverbak = _T(""); //
  175. CString g_path1 = _T(""); /* 共享目录 <客户原片(管理软件)$> 如:"\\lyfz-pc\客户原片(管理软件)$" */
  176. CString g_path2 = _T(""); /* 共享目录 <修好的片(管理软件)$> 如:"\\lyfz-pc\修好的片(管理软件)$" */
  177. CString g_path3 = _T(""); /* 共享目录 <设计好的片(管理软件$)> 如:""> */
  178. CString g_path4 = _T(""); /* 共享目录 <精修好的片(管理软件$)> 如:""> */
  179. CString g_path5 = _T(""); /* 共享目录 <礼服图片(管理软件$)> 如:""> */
  180. CString g_path6 = _T(""); /* 共享目录 <电话录音(管理软件$)> 如:""> */
  181. CString g_path7 = _T(""); /* 共享目录 <客户原片(管理软件$)\效果图> 如:""> */
  182. CString g_path1bak = _T("");
  183. CString g_path2bak = _T("");
  184. CString g_path3bak = _T("");
  185. CString g_path4bak = _T("");
  186. CString g_path5bak = _T("");
  187. CString g_path6bak = _T("");
  188. CString g_path7bak = _T("");
  189. CDatabase g_db;
  190. DWORD g_ncount = 0;
  191. CFont g_titlefont;
  192. DWORD g_nSendCode = 0;
  193. BOOL g_bSendOK = 0;
  194. CString g_temp = _T("");
  195. CArray<CStringArray, CStringArray>g_hisyeararray;
  196. CArray<CStringArray, CStringArray>g_brancharray;
  197. CArray<CStringArray, CStringArray>g_oldclientarray;
  198. BOOL g_bNoConnDlg = 0;
  199. BOOL g_bInSkin = 0;
  200. BOOL g_bGenBranchData = 0;
  201. BOOL g_bSortAscending = FALSE;
  202. CFont g_listctrlfont;
  203. float g_fscalex = 0.0; // x坐标刻度
  204. float g_fscaley = 0.0; // y坐标刻度
  205. int g_screenwid = 0.0; // 桌面宽
  206. int g_screenhei = 0.0; // 桌面高
  207. float g_WidthScale2 = 1;
  208. float g_HeightScale2 = 1;
  209. RESDATA2 g_resdata2;
  210. BOOL g_bAlphaWnd = 0;
  211. BYTE g_bNeedDrawParent = 0;
  212. BOOL g_bAllBranch = 0;
  213. CString g_domain = _T("");
  214. CString g_sInfo = _T("");
  215. int g_ncot = 0; // Jeff:订单总数(包含历史订单在内),该变量作用是当订单总数大于1000时,向公司服务器发送数据;
  216. int g_conpos = 0;
  217. int g_nAutoShowStaffAchievement = -1;
  218. BOOL g_bShowBar = 1;
  219. int g_bookingtype = 0;
  220. BOOL g_bNoLoginLia = 0;
  221. BOOL g_bConnLYFZ = 0;
  222. BOOL g_bSendLYFZ = 0;
  223. int g_ntimeout = 29000;
  224. float g_WidthScale = 0.0;
  225. float g_HeightScale = 0.0;
  226. int g_dx = 0;
  227. int g_dy = 0;
  228. BOOL g_bNeedCoon = 1; // remark by Jeff:是否需要重新连接服务端;
  229. CStringArray g_menubranchname;
  230. CArray<CStringArray, CStringArray>g_List1array;
  231. /************************************************************************/
  232. /*
  233. Jeff:g_conntype
  234. g_conntype == 0 :表示正常连接?(或是连接本地服务器?)
  235. g_conntype == 1 :表示连接公司服务器(http://lijiafz.vicp.net)
  236. g_conntype == 2 :http://www.lyfz.net/download/ip.txt
  237. g_conntype == 3 :http://photo.bjlyfz.com/download/ip.txt
  238. g_conntype == 4 :
  239. */
  240. /************************************************************************/
  241. int g_conntype = 0;//正常
  242. //0 正常
  243. //1 连接1
  244. //2 连接2
  245. //3 连接3
  246. //4 连接4
  247. #endif
  248. #if FORMER_CODE
  249. // Pump messages while waiting for event
  250. //----------------------------------------------------------
  251. // 函数:WaitWithMessageLoop
  252. // 描述:等待某内核事件触发;
  253. // 参数:
  254. // hEvent: 被等待响应的内核事件对象;
  255. // nTimeout: 超时值;
  256. // 返回:TRUE返回触发成功;
  257. //----------------------------------------------------------
  258. BOOL WaitWithMessageLoop(HANDLE hEvent, int nTimeout)
  259. {
  260. DWORD dwRet = 0;
  261. while (1)
  262. {
  263. // wait for event or message, if it's a message, process it and return to waiting state
  264. dwRet = MsgWaitForMultipleObjects(1, &hEvent, FALSE, nTimeout, QS_ALLINPUT);
  265. if (dwRet == WAIT_OBJECT_0)
  266. {
  267. TRACE0("WaitWithMessageLoop() event triggered.\n");
  268. return TRUE;
  269. }
  270. else
  271. if (dwRet == WAIT_OBJECT_0 + 1)
  272. {
  273. // process window messages
  274. AfxGetApp()->PumpMessage();
  275. }
  276. else
  277. if (dwRet == WAIT_TIMEOUT)
  278. {
  279. // timed out !
  280. return FALSE;
  281. }
  282. else
  283. {
  284. // WAIT_ABANDONED_0 ...
  285. return TRUE;
  286. }
  287. }
  288. }
  289. //----------------------------------------------------------
  290. // 函数:DeleteDirectory
  291. // 描述:删除指定目录下的所有文件;
  292. // 参数:strDir:指定要删除的文件目录;
  293. // 返回:;
  294. //----------------------------------------------------------
  295. void DeleteDirectory(CString strDir)
  296. {
  297. try
  298. {
  299. // 首先删除文件及子文件夹
  300. CFileFind ff;
  301. BOOL bFound = ff.FindFile(strDir + "\\*", 0);
  302. while (bFound)
  303. {
  304. bFound = ff.FindNextFile();
  305. if (ff.GetFileName() == "." || ff.GetFileName() == "..")
  306. continue;
  307. // 去掉文件(夹)只读等属性
  308. SetFileAttributes(ff.GetFilePath(), FILE_ATTRIBUTE_NORMAL);
  309. if (ff.IsDirectory())
  310. { // 递归删除子文件夹
  311. DeleteDirectory(ff.GetFilePath());
  312. RemoveDirectory(ff.GetFilePath());
  313. }
  314. else
  315. {
  316. DeleteFile(ff.GetFilePath()); // 删除文件
  317. }
  318. }
  319. ff.Close();
  320. // 然后删除该文件夹
  321. RemoveDirectory(strDir);
  322. }
  323. catch (...)
  324. {
  325. //WriteLogin("出错在函数deldir中");
  326. }
  327. // int SHFileOperation( LPSHFILEOPSTRUCT lpFileOp );
  328. }
  329. void DataToArray(CArray<CStringArray, CStringArray>*pArrayOfString, int datapos)
  330. {
  331. try
  332. {
  333. pArrayOfString->RemoveAll();
  334. if (g_nLeng == 0)
  335. {
  336. return;
  337. }
  338. // 1.code[0]数组:用作发送时,存储着操作指令;用作接收时,存储着接收数据大小???;
  339. if (g_sendhead.code[0])
  340. {
  341. // 1.1.将g_pData全局变量里保存的数据进行解压,并存储在lpszOut数组里;
  342. BYTE *lpszOut = NULL;
  343. int nOutSize = 0;
  344. LZARI Lzari;
  345. Lzari.UnCompress(g_pData, g_nLeng, (const BYTE*&)lpszOut, nOutSize);
  346. // 1.2.将解压后的数据lpszOut附加到内存文件里;
  347. CMemFile memfile;
  348. memfile.Attach(lpszOut, nOutSize);
  349. Lzari.Release();
  350. // 1.3.将内存文件序列化保存到CArchive对象里;
  351. CArchive ar(&memfile, CArchive::load);
  352. pArrayOfString->SetSize(g_sendhead.count[0]);
  353. // 1.4.将CArchive对象里的数据,序列化到指定的CArray对象里;
  354. for (int ii = 0; ii < pArrayOfString->GetSize(); ii++)
  355. {
  356. pArrayOfString->ElementAt(ii).Serialize(ar);
  357. }
  358. // 1.5.完成数据的导出任务,释放内存;
  359. ar.Close();
  360. memfile.Detach();
  361. }
  362. else
  363. {
  364. CMemFile memfile;
  365. memfile.Attach(g_pData, g_nLeng);
  366. CArchive ar(&memfile, CArchive::load);
  367. pArrayOfString->SetSize(g_sendhead.count[0]);
  368. for (int ii = 0; ii < pArrayOfString->GetSize(); ii++)
  369. {
  370. pArrayOfString->ElementAt(ii).Serialize(ar);
  371. }
  372. ar.Close();
  373. memfile.Detach();
  374. }
  375. }
  376. catch (...)
  377. {
  378. }
  379. }
  380. void DataToArray(
  381. CArray<CStringArray, CStringArray>*pArrayOfString1,
  382. CArray<CStringArray, CStringArray>*pArrayOfString2,
  383. int datapos)
  384. {
  385. try
  386. {
  387. CArray<CStringArray, CStringArray>*parray[2] = { pArrayOfString1, pArrayOfString2 };
  388. DWORD bytereads = 0;
  389. for (int i = 0; i < 2; i++)
  390. {
  391. parray[i]->RemoveAll();
  392. if (g_sendhead.length[i] == 0)
  393. continue;
  394. if (g_sendhead.code[i])
  395. {
  396. // 1.1.将g_pData全局变量里保存的数据进行解压,并存储在lpszOut数组里;
  397. BYTE *lpszOut = NULL;
  398. int nOutSize = 0;
  399. LZARI Lzari;
  400. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  401. // 1.2.将解压后的数据lpszOut附加到内存文件里;
  402. CMemFile memfile;
  403. memfile.Attach(lpszOut, nOutSize);
  404. Lzari.Release();
  405. // 1.3.将内存文件序列化保存到CArchive对象里;
  406. bytereads += g_sendhead.length[i];
  407. CArchive ar(&memfile, CArchive::load);
  408. parray[i]->SetSize(g_sendhead.count[i]);
  409. // 1.4.将CArchive对象里的数据,序列化到指定的CArray对象里;
  410. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  411. {
  412. parray[i]->ElementAt(ii).Serialize(ar);
  413. }
  414. // 1.5.完成数据的导出任务,释放内存;
  415. ar.Close();
  416. memfile.Detach();
  417. }
  418. else
  419. {
  420. CMemFile memfile;
  421. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  422. bytereads += g_sendhead.length[i];
  423. CArchive ar(&memfile, CArchive::load);
  424. parray[i]->SetSize(g_sendhead.count[i]);
  425. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  426. {
  427. parray[i]->ElementAt(ii).Serialize(ar);
  428. }
  429. ar.Close();
  430. memfile.Detach();
  431. }
  432. }
  433. }
  434. catch (...)
  435. {
  436. }
  437. }
  438. void DataToArray(
  439. CArray<CStringArray, CStringArray>*pArrayOfString1,
  440. CArray<CStringArray, CStringArray>*pArrayOfString2,
  441. CArray<CStringArray, CStringArray>*pArrayOfString3,
  442. int datapos)
  443. {
  444. try
  445. {
  446. CArray<CStringArray, CStringArray>*parray[3] = { pArrayOfString1, pArrayOfString2, pArrayOfString3 };
  447. DWORD bytereads = 0;
  448. for (int i = 0; i < 3; i++)
  449. {
  450. parray[i]->RemoveAll(); if (g_sendhead.length[i] == 0)continue;
  451. if (g_sendhead.code[i])
  452. {
  453. BYTE *lpszOut = NULL;
  454. int nOutSize = 0;
  455. LZARI Lzari;
  456. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  457. CMemFile memfile;
  458. memfile.Attach(lpszOut, nOutSize);
  459. Lzari.Release();
  460. bytereads += g_sendhead.length[i];
  461. CArchive ar(&memfile, CArchive::load);
  462. parray[i]->SetSize(g_sendhead.count[i]);
  463. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  464. {
  465. parray[i]->ElementAt(ii).Serialize(ar);
  466. }
  467. ar.Close();
  468. memfile.Detach();
  469. }
  470. else
  471. {
  472. CMemFile memfile;
  473. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  474. bytereads += g_sendhead.length[i];
  475. CArchive ar(&memfile, CArchive::load);
  476. parray[i]->SetSize(g_sendhead.count[i]);
  477. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  478. {
  479. parray[i]->ElementAt(ii).Serialize(ar);
  480. }
  481. ar.Close();
  482. memfile.Detach();
  483. }
  484. }
  485. }
  486. catch (...)
  487. {
  488. }
  489. }
  490. void DataToArray(
  491. CArray<CStringArray, CStringArray>*pArrayOfString1,
  492. CArray<CStringArray, CStringArray>*pArrayOfString2,
  493. CArray<CStringArray, CStringArray>*pArrayOfString3,
  494. CArray<CStringArray, CStringArray>*pArrayOfString4,
  495. int datapos)
  496. {
  497. try
  498. {
  499. CArray<CStringArray, CStringArray>*parray[4] =
  500. {
  501. pArrayOfString1,
  502. pArrayOfString2,
  503. pArrayOfString3,
  504. pArrayOfString4
  505. };
  506. DWORD bytereads = 0;
  507. for (int i = 0; i < 4; i++)
  508. {
  509. parray[i]->RemoveAll(); if (g_sendhead.length[i] == 0)continue;
  510. if (g_sendhead.code[i])
  511. {
  512. BYTE *lpszOut = NULL;
  513. int nOutSize = 0;
  514. LZARI Lzari;
  515. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  516. CMemFile memfile;
  517. memfile.Attach(lpszOut, nOutSize);
  518. Lzari.Release();
  519. bytereads += g_sendhead.length[i];
  520. CArchive ar(&memfile, CArchive::load);
  521. parray[i]->SetSize(g_sendhead.count[i]);
  522. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  523. {
  524. parray[i]->ElementAt(ii).Serialize(ar);
  525. }
  526. ar.Close();
  527. memfile.Detach();
  528. }
  529. else
  530. {
  531. CMemFile memfile;
  532. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  533. bytereads += g_sendhead.length[i];
  534. CArchive ar(&memfile, CArchive::load);
  535. parray[i]->SetSize(g_sendhead.count[i]);
  536. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  537. {
  538. parray[i]->ElementAt(ii).Serialize(ar);
  539. }
  540. ar.Close();
  541. memfile.Detach();
  542. }
  543. }
  544. }
  545. catch (...)
  546. {
  547. }
  548. }
  549. void DataToArray(
  550. CArray<CStringArray, CStringArray>*pArrayOfString1,
  551. CArray<CStringArray, CStringArray>*pArrayOfString2,
  552. CArray<CStringArray, CStringArray>*pArrayOfString3,
  553. CArray<CStringArray, CStringArray>*pArrayOfString4,
  554. CArray<CStringArray, CStringArray>*pArrayOfString5,
  555. int datapos)
  556. {
  557. try
  558. {
  559. CArray<CStringArray, CStringArray>*parray[5] =
  560. {
  561. pArrayOfString1,
  562. pArrayOfString2,
  563. pArrayOfString3,
  564. pArrayOfString4,
  565. pArrayOfString5
  566. };
  567. DWORD bytereads = 0;
  568. for (int i = 0; i < 5; i++)
  569. {
  570. parray[i]->RemoveAll();
  571. if (g_sendhead.length[i] == 0)
  572. continue;
  573. if (g_sendhead.code[i])
  574. {
  575. BYTE *lpszOut = NULL;
  576. int nOutSize = 0;
  577. LZARI Lzari;
  578. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  579. CMemFile memfile;
  580. memfile.Attach(lpszOut, nOutSize);
  581. Lzari.Release();
  582. bytereads += g_sendhead.length[i];
  583. CArchive ar(&memfile, CArchive::load);
  584. parray[i]->SetSize(g_sendhead.count[i]);
  585. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  586. {
  587. parray[i]->ElementAt(ii).Serialize(ar);
  588. }
  589. ar.Close();
  590. memfile.Detach();
  591. }
  592. else
  593. {
  594. CMemFile memfile;
  595. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  596. bytereads += g_sendhead.length[i];
  597. CArchive ar(&memfile, CArchive::load);
  598. parray[i]->SetSize(g_sendhead.count[i]);
  599. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  600. {
  601. parray[i]->ElementAt(ii).Serialize(ar);
  602. }
  603. ar.Close();
  604. memfile.Detach();
  605. }
  606. }
  607. }
  608. catch (...)
  609. {
  610. }
  611. }
  612. void DataToArray(
  613. CArray<CStringArray, CStringArray>*pArrayOfString1,
  614. CArray<CStringArray, CStringArray>*pArrayOfString2,
  615. CArray<CStringArray, CStringArray>*pArrayOfString3,
  616. CArray<CStringArray, CStringArray>*pArrayOfString4,
  617. CArray<CStringArray, CStringArray>*pArrayOfString5,
  618. CArray<CStringArray, CStringArray>*pArrayOfString6,
  619. int datapos)
  620. {
  621. try
  622. {
  623. CArray<CStringArray, CStringArray>*parray[6] =
  624. {
  625. pArrayOfString1,
  626. pArrayOfString2,
  627. pArrayOfString3,
  628. pArrayOfString4,
  629. pArrayOfString5,
  630. pArrayOfString6
  631. };
  632. DWORD bytereads = 0;
  633. for (int i = 0; i < 6; i++)
  634. {
  635. parray[i]->RemoveAll();
  636. if (g_sendhead.length[i] == 0)continue;
  637. if (g_sendhead.code[i])
  638. {
  639. BYTE *lpszOut = NULL;
  640. int nOutSize = 0;
  641. LZARI Lzari;
  642. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  643. CMemFile memfile;
  644. memfile.Attach(lpszOut, nOutSize);
  645. Lzari.Release();
  646. bytereads += g_sendhead.length[i];
  647. CArchive ar(&memfile, CArchive::load);
  648. parray[i]->SetSize(g_sendhead.count[i]);
  649. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  650. {
  651. parray[i]->ElementAt(ii).Serialize(ar);
  652. }
  653. ar.Close();
  654. memfile.Detach();
  655. }
  656. else
  657. {
  658. CMemFile memfile;
  659. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  660. bytereads += g_sendhead.length[i];
  661. CArchive ar(&memfile, CArchive::load);
  662. parray[i]->SetSize(g_sendhead.count[i]);
  663. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  664. {
  665. parray[i]->ElementAt(ii).Serialize(ar);
  666. }
  667. ar.Close();
  668. memfile.Detach();
  669. }
  670. }
  671. }
  672. catch (...)
  673. {
  674. }
  675. }
  676. void DataToArray(
  677. CArray<CStringArray, CStringArray>*pArrayOfString1,
  678. CArray<CStringArray, CStringArray>*pArrayOfString2,
  679. CArray<CStringArray, CStringArray>*pArrayOfString3,
  680. CArray<CStringArray, CStringArray>*pArrayOfString4,
  681. CArray<CStringArray, CStringArray>*pArrayOfString5,
  682. CArray<CStringArray, CStringArray>*pArrayOfString6,
  683. CArray<CStringArray, CStringArray>*pArrayOfString7,
  684. int datapos)
  685. {
  686. try
  687. {
  688. CArray<CStringArray, CStringArray>*parray[7] =
  689. {
  690. pArrayOfString1,
  691. pArrayOfString2,
  692. pArrayOfString3,
  693. pArrayOfString4,
  694. pArrayOfString5,
  695. pArrayOfString6,
  696. pArrayOfString7
  697. };
  698. DWORD bytereads = 0;
  699. for (int i = 0; i < 7; i++)
  700. {
  701. parray[i]->RemoveAll();
  702. if (g_sendhead.length[i] == 0)continue;
  703. if (g_sendhead.code[i])
  704. {
  705. BYTE *lpszOut = NULL;
  706. int nOutSize = 0;
  707. LZARI Lzari;
  708. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  709. CMemFile memfile;
  710. memfile.Attach(lpszOut, nOutSize);
  711. Lzari.Release();
  712. bytereads += g_sendhead.length[i];
  713. CArchive ar(&memfile, CArchive::load);
  714. parray[i]->SetSize(g_sendhead.count[i]);
  715. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  716. {
  717. parray[i]->ElementAt(ii).Serialize(ar);
  718. }
  719. ar.Close();
  720. memfile.Detach();
  721. }
  722. else
  723. {
  724. CMemFile memfile;
  725. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  726. bytereads += g_sendhead.length[i];
  727. CArchive ar(&memfile, CArchive::load);
  728. parray[i]->SetSize(g_sendhead.count[i]);
  729. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  730. {
  731. parray[i]->ElementAt(ii).Serialize(ar);
  732. }
  733. ar.Close();
  734. memfile.Detach();
  735. }
  736. }
  737. }
  738. catch (...)
  739. {
  740. }
  741. }
  742. void DataToArray(
  743. CArray<CStringArray, CStringArray>*pArrayOfString1,
  744. CArray<CStringArray, CStringArray>*pArrayOfString2,
  745. CArray<CStringArray, CStringArray>*pArrayOfString3,
  746. CArray<CStringArray, CStringArray>*pArrayOfString4,
  747. CArray<CStringArray, CStringArray>*pArrayOfString5,
  748. CArray<CStringArray, CStringArray>*pArrayOfString6,
  749. CArray<CStringArray, CStringArray>*pArrayOfString7,
  750. CArray<CStringArray, CStringArray>*pArrayOfString8,
  751. int datapos)
  752. {
  753. try
  754. {
  755. CArray<CStringArray, CStringArray>*parray[8] =
  756. {
  757. pArrayOfString1,
  758. pArrayOfString2,
  759. pArrayOfString3,
  760. pArrayOfString4,
  761. pArrayOfString5,
  762. pArrayOfString6,
  763. pArrayOfString7,
  764. pArrayOfString8
  765. };
  766. DWORD bytereads = 0;
  767. for (int i = 0; i < 8; i++)
  768. {
  769. parray[i]->RemoveAll();
  770. if (g_sendhead.length[i] == 0)continue;
  771. if (g_sendhead.code[i])
  772. {
  773. BYTE *lpszOut = NULL;
  774. int nOutSize = 0;
  775. LZARI Lzari;
  776. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  777. CMemFile memfile;
  778. memfile.Attach(lpszOut, nOutSize);
  779. Lzari.Release();
  780. bytereads += g_sendhead.length[i];
  781. CArchive ar(&memfile, CArchive::load);
  782. parray[i]->SetSize(g_sendhead.count[i]);
  783. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  784. {
  785. parray[i]->ElementAt(ii).Serialize(ar);
  786. }
  787. ar.Close();
  788. memfile.Detach();
  789. }
  790. else
  791. {
  792. CMemFile memfile;
  793. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  794. bytereads += g_sendhead.length[i];
  795. CArchive ar(&memfile, CArchive::load);
  796. parray[i]->SetSize(g_sendhead.count[i]);
  797. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  798. {
  799. parray[i]->ElementAt(ii).Serialize(ar);
  800. }
  801. ar.Close();
  802. memfile.Detach();
  803. }
  804. }
  805. }
  806. catch (...)
  807. {
  808. }
  809. }
  810. void DataToArray(
  811. CArray<CStringArray, CStringArray>*pArrayOfString1,
  812. CArray<CStringArray, CStringArray>*pArrayOfString2,
  813. CArray<CStringArray, CStringArray>*pArrayOfString3,
  814. CArray<CStringArray, CStringArray>*pArrayOfString4,
  815. CArray<CStringArray, CStringArray>*pArrayOfString5,
  816. CArray<CStringArray, CStringArray>*pArrayOfString6,
  817. CArray<CStringArray, CStringArray>*pArrayOfString7,
  818. CArray<CStringArray, CStringArray>*pArrayOfString8,
  819. CArray<CStringArray, CStringArray>*pArrayOfString9,
  820. CArray<CStringArray, CStringArray>*pArrayOfString10,
  821. int datapos)
  822. {
  823. try
  824. {
  825. CArray<CStringArray, CStringArray>*parray[10] =
  826. {
  827. pArrayOfString1,
  828. pArrayOfString2,
  829. pArrayOfString3,
  830. pArrayOfString4,
  831. pArrayOfString5,
  832. pArrayOfString6,
  833. pArrayOfString7,
  834. pArrayOfString8,
  835. pArrayOfString9,
  836. pArrayOfString10
  837. };
  838. DWORD bytereads = 0;
  839. for (int i = 0; i < 10; i++)
  840. {
  841. parray[i]->RemoveAll();
  842. if (g_sendhead.length[i] == 0)continue;
  843. if (g_sendhead.code[i])
  844. {
  845. BYTE *lpszOut = NULL;
  846. int nOutSize = 0;
  847. LZARI Lzari;
  848. Lzari.UnCompress(g_pData + bytereads, g_sendhead.length[i], (const BYTE*&)lpszOut, nOutSize);
  849. CMemFile memfile;
  850. memfile.Attach(lpszOut, nOutSize);
  851. Lzari.Release();
  852. bytereads += g_sendhead.length[i];
  853. CArchive ar(&memfile, CArchive::load);
  854. parray[i]->SetSize(g_sendhead.count[i]);
  855. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  856. {
  857. parray[i]->ElementAt(ii).Serialize(ar);
  858. }
  859. ar.Close();
  860. memfile.Detach();
  861. }
  862. else
  863. {
  864. CMemFile memfile;
  865. memfile.Attach(g_pData + bytereads, g_sendhead.length[i]);
  866. bytereads += g_sendhead.length[i];
  867. CArchive ar(&memfile, CArchive::load);
  868. parray[i]->SetSize(g_sendhead.count[i]);
  869. for (int ii = 0; ii < parray[i]->GetSize(); ii++)
  870. {
  871. parray[i]->ElementAt(ii).Serialize(ar);
  872. }
  873. ar.Close();
  874. memfile.Detach();
  875. }
  876. }
  877. }
  878. catch (...)
  879. {
  880. }
  881. }
  882. // 从缓存中加载图片;
  883. void LoadImageFromBuf(Bitmap **img, BYTE *pData, DWORD leng)
  884. {
  885. try
  886. {
  887. if (pData == NULL)return;
  888. if (*img)delete *img;
  889. *img = NULL;
  890. // Allocate global memory on which to create stream
  891. HGLOBAL m_hMem = GlobalAlloc(GMEM_MOVEABLE, leng);
  892. if (m_hMem == NULL)return;
  893. BYTE* pmem = (BYTE*)GlobalLock(m_hMem);
  894. memcpy(pmem, pData, leng);
  895. IStream* pstm;
  896. CreateStreamOnHGlobal(m_hMem, TRUE, &pstm);
  897. // load from stream
  898. *img = Gdiplus::Bitmap::FromStream(pstm);
  899. // free/release stuff
  900. GlobalUnlock(m_hMem);
  901. pstm->Release();
  902. }
  903. catch (...)
  904. {
  905. }
  906. }
  907. void LoadImageFromFile(Image **img, CString path)
  908. {
  909. try
  910. {
  911. if (!PathFileExists(path))return;
  912. if (*img)delete *img;
  913. *img = NULL;
  914. BSTR bstr = path.AllocSysString();
  915. *img = Image::FromFile(bstr);
  916. SysFreeString(bstr);
  917. }
  918. catch (...)
  919. {
  920. }
  921. }
  922. void LoadImageFromFile(Bitmap **img, CString path)
  923. {
  924. try
  925. {
  926. if (!PathFileExists(path))return;
  927. if (*img)delete *img;
  928. *img = NULL;
  929. BSTR bstr = path.AllocSysString();
  930. *img = Bitmap::FromFile(bstr);
  931. SysFreeString(bstr);
  932. }
  933. catch (...)
  934. {
  935. }
  936. }
  937. void LoadImageFromBuf(Image **img, BYTE *pData, DWORD leng)
  938. {
  939. try
  940. {
  941. if (pData == NULL)return;
  942. if (*img)delete *img;
  943. *img = NULL;
  944. // Allocate global memory on which to create stream
  945. HGLOBAL m_hMem = GlobalAlloc(GMEM_MOVEABLE, leng);
  946. if (m_hMem == NULL)return;
  947. BYTE* pmem = (BYTE*)GlobalLock(m_hMem);
  948. memcpy(pmem, pData, leng);
  949. IStream* pstm;
  950. CreateStreamOnHGlobal(m_hMem, TRUE, &pstm);
  951. // load from stream
  952. *img = Gdiplus::Image::FromStream(pstm);
  953. // free/release stuff
  954. GlobalUnlock(m_hMem);
  955. pstm->Release();
  956. }
  957. catch (...)
  958. {
  959. }
  960. }
  961. void LoadImageFromBuf(Image **img, CString path)
  962. {
  963. try
  964. {
  965. CFile fp;
  966. if (fp.Open(path, CFile::modeRead))
  967. {
  968. DWORD leng = fp.GetLength();
  969. BYTE *pData = new BYTE[leng];
  970. fp.Read(pData, leng);
  971. fp.Close();
  972. LoadImageFromBuf(img, pData, leng);
  973. delete[]pData;
  974. }
  975. }
  976. catch (...)
  977. {
  978. }
  979. }
  980. void LoadImageFromBuf(Bitmap **img, CString path)
  981. {
  982. try
  983. {
  984. CFile fp;
  985. if (fp.Open(path, CFile::modeRead))
  986. {
  987. DWORD leng = fp.GetLength();
  988. BYTE *pData = new BYTE[leng];
  989. fp.Read(pData, leng);
  990. fp.Close();
  991. LoadImageFromBuf(img, pData, leng);
  992. delete[]pData;
  993. }
  994. }
  995. catch (...)
  996. {
  997. }
  998. }
  999. void LoadImageFromRes(Image **img, LPCTSTR lpszResourceName, LPCTSTR ResourceType)
  1000. {
  1001. try
  1002. {
  1003. HGLOBAL hGlobal = NULL;
  1004. HRSRC hSource = NULL;
  1005. LPVOID lpVoid = NULL;
  1006. int nSize = 0;
  1007. BOOL bResult = FALSE;
  1008. hSource = FindResource(NULL, lpszResourceName, ResourceType);
  1009. if (hSource == NULL)return;
  1010. hGlobal = LoadResource(NULL, hSource);
  1011. if (hGlobal == NULL)return;
  1012. lpVoid = LockResource(hGlobal);
  1013. if (lpVoid == NULL)return;
  1014. nSize = (UINT)SizeofResource(NULL, hSource);
  1015. LoadImageFromBuf(img, (BYTE*)hGlobal, nSize);
  1016. UnlockResource(hGlobal); // 16Bit Windows Needs This
  1017. FreeResource(hGlobal); // 16Bit Windows Needs This (32Bit - Automatic Release)
  1018. }
  1019. catch (...)
  1020. {
  1021. }
  1022. }
  1023. int GetOrientation(Image *image)
  1024. {
  1025. try
  1026. {
  1027. if (image)
  1028. {
  1029. UINT totalBufferSize;
  1030. UINT numProperties;
  1031. image->GetPropertySize(&totalBufferSize, &numProperties);
  1032. // Allocate the buffer that will receive the property items.
  1033. PropertyItem* pAllItems = (PropertyItem*)malloc(totalBufferSize);
  1034. // Fill the buffer.
  1035. image->GetAllPropertyItems(totalBufferSize, numProperties, pAllItems);
  1036. // Print the id data member of each property item.
  1037. for (UINT j = 0; j < numProperties; ++j)
  1038. {
  1039. if (PropertyTagOrientation == pAllItems[j].id)
  1040. {
  1041. short* ptrLong = (short*)(pAllItems[j].value);
  1042. int ret = (int)*ptrLong;
  1043. free(pAllItems);
  1044. return ret;
  1045. }
  1046. }
  1047. free(pAllItems);
  1048. }
  1049. }
  1050. catch (...)
  1051. {
  1052. }
  1053. return 1;
  1054. }
  1055. int GetEncoderClsid(const WCHAR* format, CLSID* pClsid)
  1056. {
  1057. UINT num = 0; // number of image encoders
  1058. UINT size = 0; // size of the image encoder array in bytes
  1059. ImageCodecInfo* pImageCodecInfo = NULL;
  1060. GetImageEncodersSize(&num, &size);
  1061. if (size == 0)
  1062. return -1; // Failure
  1063. pImageCodecInfo = (ImageCodecInfo*)(malloc(size));
  1064. if (pImageCodecInfo == NULL)
  1065. return -1; // Failure
  1066. GetImageEncoders(num, size, pImageCodecInfo);
  1067. for (UINT j = 0; j < num; ++j)
  1068. {
  1069. if (wcscmp(pImageCodecInfo[j].MimeType, format) == 0)
  1070. {
  1071. *pClsid = pImageCodecInfo[j].Clsid;
  1072. free(pImageCodecInfo);
  1073. return j; // Success
  1074. }
  1075. }
  1076. free(pImageCodecInfo);
  1077. return -1; // FailureFailure
  1078. }
  1079. void SaveImageToFile(Image *img, CString path)
  1080. {
  1081. try
  1082. {
  1083. if (img == NULL)return;
  1084. CLSID encoderClsid;
  1085. BSTR bstr = path.AllocSysString();
  1086. path.MakeLower();
  1087. if (path.Right(3) == "bmp")
  1088. {
  1089. GetEncoderClsid(L"image/bmp", &encoderClsid);
  1090. img->Save(bstr, &encoderClsid, NULL);
  1091. }
  1092. else if (path.Right(3) == "png")
  1093. {
  1094. GetEncoderClsid(L"image/png", &encoderClsid);
  1095. img->Save(bstr, &encoderClsid, NULL);
  1096. }
  1097. else// if(path.Right (3)=="jpg")
  1098. {
  1099. GetEncoderClsid(L"image/jpeg", &encoderClsid);
  1100. EncoderParameters encoderParameters;
  1101. ULONG quality;
  1102. encoderParameters.Count = 1;
  1103. encoderParameters.Parameter[0].Guid = EncoderQuality;
  1104. encoderParameters.Parameter[0].Type = EncoderParameterValueTypeLong;
  1105. encoderParameters.Parameter[0].NumberOfValues = 1;
  1106. // Save the image as a JPEG with quality level 100.
  1107. quality = 100;
  1108. encoderParameters.Parameter[0].Value = &quality;
  1109. img->Save(bstr, &encoderClsid, &encoderParameters);
  1110. }
  1111. SysFreeString(bstr);
  1112. }
  1113. catch (...)
  1114. {
  1115. }
  1116. }
  1117. void SaveImageToFile2(Image *img, CString path, ULONG quality)
  1118. {
  1119. try
  1120. {
  1121. if (img == NULL)return;
  1122. CLSID encoderClsid;
  1123. BSTR bstr = path.AllocSysString();
  1124. path.MakeLower();
  1125. if (path.Right(3) == "bmp")
  1126. {
  1127. GetEncoderClsid(L"image/bmp", &encoderClsid);
  1128. img->Save(bstr, &encoderClsid, NULL);
  1129. }
  1130. else if (path.Right(3) == "png")
  1131. {
  1132. GetEncoderClsid(L"image/png", &encoderClsid);
  1133. img->Save(bstr, &encoderClsid, NULL);
  1134. }
  1135. else// if(path.Right (3)=="jpg")
  1136. {
  1137. GetEncoderClsid(L"image/jpeg", &encoderClsid);
  1138. EncoderParameters encoderParameters;
  1139. encoderParameters.Count = 1;
  1140. encoderParameters.Parameter[0].Guid = EncoderQuality;
  1141. encoderParameters.Parameter[0].Type = EncoderParameterValueTypeLong;
  1142. encoderParameters.Parameter[0].NumberOfValues = 1;
  1143. // Save the image as a JPEG with quality level 100.
  1144. encoderParameters.Parameter[0].Value = &quality;
  1145. img->Save(bstr, &encoderClsid, &encoderParameters);
  1146. }
  1147. SysFreeString(bstr);
  1148. }
  1149. catch (...)
  1150. {
  1151. }
  1152. }
  1153. void IsWaiter2(CString id, CString name, CArray<CStringArray, CStringArray>*waiterarray, BOOL &bWait1, BOOL &bWait2, float &fscale1, float &fscale2, BOOL bCheckDate, CString date1, CString date2)
  1154. {
  1155. for (int i = 0; i < waiterarray->GetSize(); i++)
  1156. {
  1157. if (id == waiterarray->ElementAt(i).ElementAt(0))
  1158. {
  1159. if (bCheckDate)
  1160. {
  1161. if (waiterarray->ElementAt(i).ElementAt(21) < date1 || waiterarray->ElementAt(i).ElementAt(21) > date2 || waiterarray->ElementAt(i).ElementAt(22) != "OK")
  1162. {
  1163. bWait1 = bWait2 = 0;
  1164. return;
  1165. }
  1166. }
  1167. if (name == waiterarray->ElementAt(i).ElementAt(1))
  1168. {
  1169. bWait1 = 1;
  1170. fscale1 = _tstof(waiterarray->ElementAt(i).ElementAt(5)) / 100.0;
  1171. if (fscale1 == 0)fscale1 = 1;
  1172. }
  1173. else if (name == waiterarray->ElementAt(i).ElementAt(2))
  1174. {
  1175. bWait1 = 1;
  1176. fscale1 = _tstof(waiterarray->ElementAt(i).ElementAt(6)) / 100.0;
  1177. }
  1178. else if (name == waiterarray->ElementAt(i).ElementAt(3))
  1179. {
  1180. bWait1 = 1;
  1181. fscale1 = _tstof(waiterarray->ElementAt(i).ElementAt(7)) / 100.0;
  1182. }
  1183. else if (name == waiterarray->ElementAt(i).ElementAt(4))
  1184. {
  1185. bWait1 = 1;
  1186. fscale1 = _tstof(waiterarray->ElementAt(i).ElementAt(8)) / 100.0;
  1187. }
  1188. ///////////////////////////////////////////////////////////////////////
  1189. if (name == waiterarray->ElementAt(i).ElementAt(9))
  1190. {
  1191. bWait2 = 1;
  1192. fscale2 = _tstof(waiterarray->ElementAt(i).ElementAt(13)) / 100.0;
  1193. if (fscale2 == 0)fscale2 = 1;
  1194. }
  1195. else if (name == waiterarray->ElementAt(i).ElementAt(10))
  1196. {
  1197. bWait2 = 1;
  1198. fscale2 = _tstof(waiterarray->ElementAt(i).ElementAt(14)) / 100.0;
  1199. }
  1200. else if (name == waiterarray->ElementAt(i).ElementAt(11))
  1201. {
  1202. bWait2 = 1;
  1203. fscale2 = _tstof(waiterarray->ElementAt(i).ElementAt(15)) / 100.0;
  1204. }
  1205. else if (name == waiterarray->ElementAt(i).ElementAt(12))
  1206. {
  1207. bWait2 = 1;
  1208. fscale2 = _tstof(waiterarray->ElementAt(i).ElementAt(16)) / 100.0;
  1209. }
  1210. return;
  1211. }
  1212. }
  1213. return;
  1214. }
  1215. void IsWaiter3(CString id, CString name, CArray<CStringArray, CStringArray>*waiterarray, BOOL &bWait1, BOOL &bWait2, float &fscale1, float &fscale2)
  1216. {
  1217. bWait1 = bWait2 = 0;
  1218. for (int i = 0; i < waiterarray->GetSize(); i++)
  1219. {
  1220. if (id == waiterarray->ElementAt(i).ElementAt(0))
  1221. {
  1222. if (name == waiterarray->ElementAt(i).ElementAt(17))
  1223. {
  1224. bWait1 = 1;
  1225. fscale1 = _tstof(waiterarray->ElementAt(i).ElementAt(19)) / 100.0;
  1226. if (fscale1 == 0)fscale1 = 1;
  1227. }
  1228. ///////////////////////////////////////////////////////////////////////
  1229. if (name == waiterarray->ElementAt(i).ElementAt(18))
  1230. {
  1231. bWait2 = 1;
  1232. fscale2 = _tstof(waiterarray->ElementAt(i).ElementAt(20)) / 100.0;
  1233. }
  1234. return;
  1235. }
  1236. }
  1237. return;
  1238. }
  1239. //------------------------------------------------------------------------------
  1240. // Remark by Jeff;
  1241. // 函数:CheckPhoneType
  1242. // 描述:判断手机号属于哪个运营商的;
  1243. // 参数:
  1244. // phoneno: 欲判断的手机号;
  1245. //
  1246. // 返回:返回0表示移动; 1表示联通; 2表示电信; 3表示小灵通; -1表示未知的;
  1247. //
  1248. // 注意:
  1249. // 移动:
  1250. // 139, 138, 137, 136, 135, 134, 159, 158, 152, 151, 150, 157, 188, 187, 144
  1251. // 联通:
  1252. // 130, 131, 132, 155, 156, 186, 185
  1253. // 电信 :
  1254. // 133, 153, 189, 180, 181
  1255. //------------------------------------------------------------------------------
  1256. int CheckPhoneType(CONST CString &phoneno)
  1257. {
  1258. if (phoneno.IsEmpty())
  1259. return -1;
  1260. for (int i = 0; i < phoneno.GetLength(); i++)
  1261. {
  1262. if (phoneno.GetAt(i) < '0' || phoneno.GetAt(i) > '9')return -1;
  1263. }
  1264. if (phoneno.GetAt(0) == '1')
  1265. {
  1266. if (phoneno.GetLength() != 11)
  1267. return -1;
  1268. int mobile[] = { 139, 138, 137, 136, 135, 134, 159, 158, 152, 151, 150, 157, 188, 187, 144, 182, 147, 183, 184, 178 };
  1269. int unicom[] = { 130, 131, 132, 155, 156, 186, 185, 176 };
  1270. int telecom[] = { 133, 153, 189, 180, 181, 177 };
  1271. for (int i = 0; i < sizeof(mobile) / sizeof(int); i++)
  1272. {
  1273. if (mobile[i] == _ttoi(phoneno.Left(3)))
  1274. {
  1275. return 0;
  1276. }
  1277. }
  1278. for (int i = 0; i < sizeof(unicom) / sizeof(int); i++)
  1279. {
  1280. if (unicom[i] == _ttoi(phoneno.Left(3)))
  1281. {
  1282. return 1;
  1283. }
  1284. }
  1285. for (int i = 0; i < sizeof(telecom) / sizeof(int); i++)
  1286. {
  1287. if (telecom[i] == _ttoi(phoneno.Left(3)))
  1288. {
  1289. return 2;
  1290. }
  1291. }
  1292. TRACE(_T("------------------电话无效------------------\n"));
  1293. return -1;
  1294. }
  1295. return -1;
  1296. }
  1297. BOOL CheckDateOK(CString &str)
  1298. {
  1299. if (str.IsEmpty())return 1;
  1300. CString tip;
  1301. int i;
  1302. CString demo = CTime::GetCurrentTime().Format("%Y-%m-%d");
  1303. if (str.GetLength() != demo.GetLength())
  1304. goto ll;
  1305. //2009-01-01
  1306. if (str.GetAt(4) != '-')
  1307. goto ll;
  1308. if (str.GetAt(7) != '-')
  1309. goto ll;
  1310. for (i = 0; i < str.GetLength(); i++)
  1311. {
  1312. if (i == 4 || i == 7)continue;
  1313. if (str.GetAt(i) < '0' || str.GetAt(i) > '9')
  1314. goto ll;
  1315. }
  1316. return 1;
  1317. ll:
  1318. tip.Format(_T("日期:%s格式错误!\r\n样板:%s"), str, demo);
  1319. AfxMessageBox(tip, MB_ICONSTOP);
  1320. return 0;
  1321. }
  1322. BOOL CheckBadWords(CString str, BOOL bMsg)
  1323. {
  1324. //165
  1325. CString badwords[1065] =
  1326. {
  1327. _T("东北独立"),
  1328. _T("杜智富"),
  1329. _T("法伦"),
  1330. _T("刘国凯"),
  1331. _T("刘凯中"),
  1332. _T("薛伟"),
  1333. _T("蔡崇国"),
  1334. _T("陈一谘"),
  1335. _T("大家论坛"),
  1336. _T("弟子"),
  1337. _T("两会新闻"),
  1338. _T("王力雄"),
  1339. _T("辛灏年"),
  1340. _T("新语丝"),
  1341. _T("张钢"),
  1342. _T("中华人民实话实说"),
  1343. _T("猪聋畸"),
  1344. _T("转化"),
  1345. _T("自由民主论坛"),
  1346. _T("走私"),
  1347. _T("法lun功"),
  1348. _T("法轮功"),
  1349. _T("江泽民"),
  1350. _T("毛泽东"),
  1351. _T("minghuinews"),
  1352. _T("狗b"),
  1353. _T("法抡"),
  1354. _T("疆独"),
  1355. _T("操蛋"),
  1356. _T("喷你"),
  1357. _T("大B"),
  1358. _T("精液"),
  1359. _T("发正念"),
  1360. _T("法抡功"),
  1361. _T("共狗"),
  1362. _T("洪志"),
  1363. _T("西藏独"),
  1364. _T("瞒报"),
  1365. _T("法*轮*功"),
  1366. _T("枪枝"),
  1367. _T("枪"),
  1368. _T("迷幻药"),
  1369. _T("黄色"),
  1370. _T("淫乱"),
  1371. _T("淫"),
  1372. _T("强奸"),
  1373. _T("奸"),
  1374. _T("大中国论坛"),
  1375. _T("戴相龙"),
  1376. _T("登辉"),
  1377. _T("地下教会"),
  1378. _T("东土耳其斯坦"),
  1379. _T("多维"),
  1380. _T("反腐败论坛"),
  1381. _T("反攻"),
  1382. _T("高自联"),
  1383. _T("戈扬"),
  1384. _T("共党"),
  1385. _T("关卓中"),
  1386. _T("华语世界论坛"),
  1387. _T("黄慈萍"),
  1388. _T("贾庆林"),
  1389. _T("江core"),
  1390. _T("江流氓"),
  1391. _T("江澤民"),
  1392. _T("将则民"),
  1393. _T("禁看"),
  1394. _T("劳教"),
  1395. _T("老毛"),
  1396. _T("黎安友"),
  1397. _T("李继耐"),
  1398. _T("李岚清"),
  1399. _T("李录"),
  1400. _T("李少民"),
  1401. _T("李旺阳"),
  1402. _T("李小朋"),
  1403. _T("李总理"),
  1404. _T("连胜德"),
  1405. _T("两岸三地论坛"),
  1406. _T("凌锋"),
  1407. _T("流亡"),
  1408. _T("吕秀莲"),
  1409. _T("卖国"),
  1410. _T("民猪"),
  1411. _T("木犀地"),
  1412. _T("木子论坛"),
  1413. _T("南大自由论坛"),
  1414. _T("闹事"),
  1415. _T("亲美"),
  1416. _T("轻舟快讯"),
  1417. _T("热站政论网"),
  1418. _T("人民真实"),
  1419. _T("上海帮"),
  1420. _T("升天"),
  1421. _T("盛雪"),
  1422. _T("台湾建国运动组织"),
  1423. _T("汤光中"),
  1424. _T("唐柏桥"),
  1425. _T("王润生"),
  1426. _T("吴邦国"),
  1427. _T("吴方城"),
  1428. _T("吴官正"),
  1429. _T("吴宏达"),
  1430. _T("吴学灿"),
  1431. _T("八九"),
  1432. _T("八老"),
  1433. _T("保钓"),
  1434. _T("鲍彤"),
  1435. _T("北京当局"),
  1436. _T("邓笑贫"),
  1437. _T("东南西北论谈"),
  1438. _T("东社"),
  1439. _T("法十轮十功"),
  1440. _T("方励之"),
  1441. _T("分裂"),
  1442. _T("歌功颂德"),
  1443. _T("工自联"),
  1444. _T("功法"),
  1445. _T("共产"),
  1446. _T("郭伯雄"),
  1447. _T("郭罗基"),
  1448. _T("国家安全"),
  1449. _T("国军"),
  1450. _T("韩联潮"),
  1451. _T("江泽慧"),
  1452. _T("交班"),
  1453. _T("看中国"),
  1454. _T("李红痔"),
  1455. _T("李宏志"),
  1456. _T("李洪宽"),
  1457. _T("李月月鸟"),
  1458. _T("林长盛"),
  1459. _T("林樵清"),
  1460. _T("林慎立"),
  1461. _T("刘晓波"),
  1462. _T("轮大"),
  1463. _T("美国之音"),
  1464. _T("绵恒"),
  1465. _T("日内瓦金融"),
  1466. _T("瑞士金融大学"),
  1467. _T("色情"),
  1468. _T("统战"),
  1469. _T("外交与方略"),
  1470. _T("万维读者论坛"),
  1471. _T("汪岷"),
  1472. _T("王丹"),
  1473. _T("王刚"),
  1474. _T("五不"),
  1475. _T("西藏"),
  1476. _T("洗脑"),
  1477. _T("下体"),
  1478. _T("项怀诚"),
  1479. _T("新观察论坛"),
  1480. _T("邢铮"),
  1481. _T("修炼"),
  1482. _T("阎明复"),
  1483. _T("央视内部晚会"),
  1484. _T("杨月清"),
  1485. _T("亦凡"),
  1486. _T("易志熹"),
  1487. _T("尹庆民"),
  1488. _T("由喜贵"),
  1489. _T("于大海"),
  1490. _T("余英时"),
  1491. _T("宇明网"),
  1492. _T("圆满"),
  1493. _T("岳武"),
  1494. _T("择民"),
  1495. _T("贼民"),
  1496. _T("赵品潞"),
  1497. _T("正见网"),
  1498. _T("郑义"),
  1499. _T("政治犯"),
  1500. _T("指点江山论坛"),
  1501. _T("中俄边界"),
  1502. _T("中国和平"),
  1503. _T("中国社会进步党"),
  1504. _T("中国威胁论"),
  1505. _T("中华大地"),
  1506. _T("中华讲清"),
  1507. _T("中华真实报道"),
  1508. _T("周天法"),
  1509. _T("朱嘉明"),
  1510. _T("自已的故事"),
  1511. _T("作秀"),
  1512. _T("89-64cdjp"),
  1513. _T("boxun"),
  1514. _T("chinamz"),
  1515. _T("cnd"),
  1516. _T("dfdz"),
  1517. _T("falu"),
  1518. _T("nmis"),
  1519. _T("svdc"),
  1520. _T("tibetalk"),
  1521. _T("triangleboy"),
  1522. _T("unixbox"),
  1523. _T("wstaiji"),
  1524. _T("十六大"),
  1525. _T("推翻"),
  1526. _T("4-Jun"),
  1527. _T("法轮"),
  1528. _T("发论功"),
  1529. _T("发论"),
  1530. _T("发伦"),
  1531. _T("江主席"),
  1532. _T("朱镕基"),
  1533. _T("曾庆红"),
  1534. _T("傻逼"),
  1535. _T("日死你"),
  1536. _T("干死你"),
  1537. _T("操逼"),
  1538. _T("大逼"),
  1539. _T("烂比"),
  1540. _T("大花逼"),
  1541. _T("操你妈"),
  1542. _T("二逼"),
  1543. _T("绿色环保手机"),
  1544. _T("cdma"),
  1545. _T("赤匪"),
  1546. _T("独立台湾会"),
  1547. _T("发抡功"),
  1548. _T("江贼民"),
  1549. _T("蒙古独立"),
  1550. _T("神通加持法"),
  1551. _T("太子党"),
  1552. _T("一中一台"),
  1553. _T("他母亲"),
  1554. _T("你妈"),
  1555. _T("你娘"),
  1556. _T("你爸"),
  1557. _T("群奸"),
  1558. _T("包皮"),
  1559. _T("奶子"),
  1560. _T("打炮"),
  1561. _T("陈炳基"),
  1562. _T("陈蒙"),
  1563. _T("达赖"),
  1564. _T("大参考"),
  1565. _T("电视流氓"),
  1566. _T("鸡毛信文汇"),
  1567. _T("劳改"),
  1568. _T("林保华"),
  1569. _T("马大维"),
  1570. _T("马良骏"),
  1571. _T("民意"),
  1572. _T("民主墙"),
  1573. _T("童屹"),
  1574. _T("王希哲"),
  1575. _T("王冶坪"),
  1576. _T("熊炎"),
  1577. _T("徐才厚"),
  1578. _T("学自联"),
  1579. _T("严家其"),
  1580. _T("张健"),
  1581. _T("张万年"),
  1582. _T("中国之春"),
  1583. _T("21世纪中国基金会"),
  1584. _T("bignews"),
  1585. _T("lihongzhi"),
  1586. _T("renminbao"),
  1587. _T("voachinese"),
  1588. _T("去你妈的"),
  1589. _T("奸淫"),
  1590. _T("淫荡"),
  1591. _T("贱货"),
  1592. _T("成人书库"),
  1593. _T("狗卵子"),
  1594. _T("轮奸"),
  1595. _T("招妓"),
  1596. _T("阴道"),
  1597. _T("阴水"),
  1598. _T("狂操"),
  1599. _T("淫水"),
  1600. _T("性欲"),
  1601. _T("阝月"),
  1602. _T("发抡"),
  1603. _T("江猪"),
  1604. _T("台湾独"),
  1605. _T("新疆独"),
  1606. _T("氵去"),
  1607. _T("车仑"),
  1608. _T("泄密"),
  1609. _T("失密"),
  1610. _T("出卖"),
  1611. _T("被盗"),
  1612. _T("肉洞"),
  1613. _T("博讯"),
  1614. _T("曹长青"),
  1615. _T("曹刚川"),
  1616. _T("陈希同"),
  1617. _T("陈小同"),
  1618. _T("陈总统"),
  1619. _T("程铁军"),
  1620. _T("程真"),
  1621. _T("持不同政见"),
  1622. _T("赤化"),
  1623. _T("春夏自由论坛"),
  1624. _T("地下刊物"),
  1625. _T("丁关根"),
  1626. _T("丁子霖"),
  1627. _T("独夫"),
  1628. _T("白皮书"),
  1629. _T("北京之春"),
  1630. _T("俄国"),
  1631. _T("巴赫"),
  1632. _T("大法"),
  1633. _T("东西南北论坛"),
  1634. _T("动乱"),
  1635. _T("江绵恒"),
  1636. _T("两会"),
  1637. _T("刘宾雁"),
  1638. _T("刘青"),
  1639. _T("刘士贤"),
  1640. _T("学习班"),
  1641. _T("真象"),
  1642. _T("在十月"),
  1643. _T("钟山风雨论坛"),
  1644. _T("自焚"),
  1645. _T("1989"),
  1646. _T("dafa"),
  1647. _T("falundafa"),
  1648. _T("fa轮"),
  1649. _T("freedom"),
  1650. _T("fuck"),
  1651. _T("GCD"),
  1652. _T("huanet"),
  1653. _T("making"),
  1654. _T("peacehall"),
  1655. _T("renmingbao"),
  1656. _T("sex"),
  1657. _T("simple"),
  1658. _T("taip"),
  1659. _T("yuming"),
  1660. _T("江ze民"),
  1661. _T("收容所"),
  1662. _T("数据中国"),
  1663. _T("hongzhi"),
  1664. _T("freechina"),
  1665. _T("法*功"),
  1666. _T("李大师"),
  1667. _T("真善忍"),
  1668. _T("炼功"),
  1669. _T("李鹏"),
  1670. _T("小穴"),
  1671. _T("江戏子"),
  1672. _T("民进党"),
  1673. _T("水扁"),
  1674. _T("朱容基"),
  1675. _T("贱逼"),
  1676. _T("干你娘"),
  1677. _T("卖逼"),
  1678. _T("卖比"),
  1679. _T("肉棍"),
  1680. _T("中国移动通信"),
  1681. _T("法愣"),
  1682. _T("江八点"),
  1683. _T("肉棒"),
  1684. _T("酱猪媳"),
  1685. _T("蒙独"),
  1686. _T("天安门一代"),
  1687. _T("新华内情"),
  1688. _T("shit"),
  1689. _T("我日"),
  1690. _T("鸡巴"),
  1691. _T("舔奶"),
  1692. _T("小鸡鸡"),
  1693. _T("婊子"),
  1694. _T("射精"),
  1695. _T("狗娘"),
  1696. _T("操比"),
  1697. _T("哈批"),
  1698. _T("精子"),
  1699. _T("屁眼"),
  1700. _T("狗操"),
  1701. _T("发骚"),
  1702. _T("妈批"),
  1703. _T("插你"),
  1704. _T("逼样"),
  1705. _T("肛交"),
  1706. _T("淫图"),
  1707. _T("法功"),
  1708. _T("四川独"),
  1709. _T("工力"),
  1710. _T("交媾"),
  1711. _T(""),
  1712. _T("(+)"),
  1713. _T("<"),
  1714. _T(">"),
  1715. _T("1 0 1 5 9"),
  1716. _T("10159"),
  1717. _T("12593"),
  1718. _T("13725516608"),
  1719. _T("13875448369"),
  1720. _T("168168168"),
  1721. _T("16大"),
  1722. _T("6-4tianwang"),
  1723. _T("av"),
  1724. _T("bitch"),
  1725. _T("B样"),
  1726. _T("chinaliberal"),
  1727. _T("chinesenewsnet"),
  1728. _T("creaders"),
  1729. _T("dajiyuan"),
  1730. _T("dpp"),
  1731. _T("dpp大法"),
  1732. _T("E周刊"),
  1733. _T("fa lun"),
  1734. _T("falun"),
  1735. _T("flg"),
  1736. _T("freenet"),
  1737. _T("hrichina"),
  1738. _T("hypermart.net"),
  1739. _T("incest"),
  1740. _T("IP17908"),
  1741. _T("jiangdongriji"),
  1742. _T("minghui"),
  1743. _T("nacb"),
  1744. _T("naive"),
  1745. _T("paper64"),
  1746. _T("playboy"),
  1747. _T("rfa"),
  1748. _T("safeweb"),
  1749. _T("Soccer01.com"),
  1750. _T("triangle"),
  1751. _T("UltraSurf"),
  1752. _T("UP8新势力"),
  1753. _T("ustibet"),
  1754. _T("voa"),
  1755. _T("wangce"),
  1756. _T("xinsheng"),
  1757. _T("zhengjian"),
  1758. _T("zhengjianwang"),
  1759. _T("zhenshanren"),
  1760. _T("zhuanfalun"),
  1761. _T("安装卫星电视"),
  1762. _T("罢工"),
  1763. _T("罢课"),
  1764. _T("白立朴"),
  1765. _T("办证"),
  1766. _T("绑架"),
  1767. _T("包赢"),
  1768. _T("保密室"),
  1769. _T("鲍戈"),
  1770. _T("暴乱"),
  1771. _T("暴政"),
  1772. _T("爆炸"),
  1773. _T("北大三角地论坛"),
  1774. _T("北韩"),
  1775. _T("北美论坛"),
  1776. _T("北美自由论坛"),
  1777. _T("屄"),
  1778. _T("不解来电"),
  1779. _T("彩民"),
  1780. _T("操你"),
  1781. _T("操他"),
  1782. _T("柴玲"),
  1783. _T("常劲"),
  1784. _T("陈军"),
  1785. _T("陈破空"),
  1786. _T("陈宣良"),
  1787. _T("成人电影"),
  1788. _T("成人频道"),
  1789. _T("成人生活片"),
  1790. _T("程凯"),
  1791. _T("迟浩田"),
  1792. _T("传:单"),
  1793. _T("传单"),
  1794. _T("春夏论坛"),
  1795. _T("打倒"),
  1796. _T("大2众卡"),
  1797. _T("大比"),
  1798. _T("大纪元"),
  1799. _T("大纪园"),
  1800. _T("大史记"),
  1801. _T("大中华论坛"),
  1802. _T("大众真人真事"),
  1803. _T("代办"),
  1804. _T("代办文凭"),
  1805. _T("代开"),
  1806. _T("代开票"),
  1807. _T("代人报仇"),
  1808. _T("弹劾"),
  1809. _T("弹药"),
  1810. _T("党中央"),
  1811. _T("邓小平"),
  1812. _T("迪里夏提"),
  1813. _T("第四代"),
  1814. _T("钓鱼岛"),
  1815. _T("丁元"),
  1816. _T("东方红时空"),
  1817. _T("东方时空"),
  1818. _T("东突"),
  1819. _T("东突厥斯坦"),
  1820. _T("东突厥斯坦伊斯兰"),
  1821. _T("动5感地带"),
  1822. _T("独裁"),
  1823. _T("独立"),
  1824. _T("赌具"),
  1825. _T("短信商务广告"),
  1826. _T("屙民"),
  1827. _T("二B"),
  1828. _T("二手车"),
  1829. _T("发财诗"),
  1830. _T("发愣"),
  1831. _T("发囵"),
  1832. _T("发沦"),
  1833. _T("发纶"),
  1834. _T("发轮"),
  1835. _T("发论公"),
  1836. _T("发票"),
  1837. _T("法 轮 功"),
  1838. _T("法.轮.功"),
  1839. _T("法仑"),
  1840. _T("法囵"),
  1841. _T("法沦"),
  1842. _T("法纶"),
  1843. _T("法轮大法"),
  1844. _T("法论"),
  1845. _T("法谪"),
  1846. _T("法谪功"),
  1847. _T("反封锁"),
  1848. _T("反封锁技术"),
  1849. _T("反革命"),
  1850. _T("反共"),
  1851. _T("反人类"),
  1852. _T("反日"),
  1853. _T("反社会"),
  1854. _T("方舟子"),
  1855. _T("飞扬论坛"),
  1856. _T("非典"),
  1857. _T("斐得勒"),
  1858. _T("费良勇"),
  1859. _T("分家在"),
  1860. _T("粉饰太平"),
  1861. _T("风雨神州"),
  1862. _T("封从德"),
  1863. _T("封杀"),
  1864. _T("封杀酱猪媳"),
  1865. _T("冯东海"),
  1866. _T("冯素英"),
  1867. _T("\"?S"),
  1868. _T("\""),
  1869. _T("佛展千手法"),
  1870. _T("付申奇"),
  1871. _T("傅申奇"),
  1872. _T("傅志寰"),
  1873. _T("肛门"),
  1874. _T("港料"),
  1875. _T("高官"),
  1876. _T("高利贷"),
  1877. _T("高文谦"),
  1878. _T("高薪养廉"),
  1879. _T("高瞻"),
  1880. _T("睾丸"),
  1881. _T("鸽派"),
  1882. _T("蛤蟆"),
  1883. _T("个人崇拜"),
  1884. _T("公投"),
  1885. _T("公证"),
  1886. _T("功友"),
  1887. _T("共产党"),
  1888. _T("共匪"),
  1889. _T("共军"),
  1890. _T("狗逼"),
  1891. _T("狗屎"),
  1892. _T("古怪歌"),
  1893. _T("贯通两极法"),
  1894. _T("广闻"),
  1895. _T("龟公"),
  1896. _T("龟头"),
  1897. _T("鬼子"),
  1898. _T("郭平"),
  1899. _T("郭岩华"),
  1900. _T("国家机密"),
  1901. _T("国民党"),
  1902. _T("国研新闻邮件"),
  1903. _T("国贼"),
  1904. _T("韩东方"),
  1905. _T("汉奸"),
  1906. _T("何德普"),
  1907. _T("何勇"),
  1908. _T("河殇"),
  1909. _T("核污染"),
  1910. _T("黑车"),
  1911. _T("黑庄"),
  1912. _T("红灯区"),
  1913. _T("红色恐怖"),
  1914. _T("宏法"),
  1915. _T("宏志"),
  1916. _T("洪传"),
  1917. _T("洪吟"),
  1918. _T("洪哲胜"),
  1919. _T("后果自负"),
  1920. _T("胡紧掏"),
  1921. _T("胡锦涛"),
  1922. _T("胡锦滔"),
  1923. _T("胡锦淘"),
  1924. _T("胡景涛"),
  1925. _T("胡平"),
  1926. _T("胡总书记"),
  1927. _T("护法"),
  1928. _T("花花公子"),
  1929. _T("华建敏"),
  1930. _T("华通时事论坛"),
  1931. _T("华夏文摘"),
  1932. _T("华岳时事论坛"),
  1933. _T("黄祸"),
  1934. _T("回民暴"),
  1935. _T("悔过书"),
  1936. _T("鸡8"),
  1937. _T("鸡八"),
  1938. _T("鸡扒"),
  1939. _T("鸡吧"),
  1940. _T("鸡鸡"),
  1941. _T("姬胜德"),
  1942. _T("积克馆"),
  1943. _T("基督"),
  1944. _T("集会"),
  1945. _T("妓女"),
  1946. _T("贾廷安"),
  1947. _T("贾育台"),
  1948. _T("假钞"),
  1949. _T("简鸿章"),
  1950. _T("建国党"),
  1951. _T("贱比"),
  1952. _T("贱人"),
  1953. _T("江独裁"),
  1954. _T("江罗"),
  1955. _T("江青"),
  1956. _T("江则民"),
  1957. _T("江贼"),
  1958. _T("江折民"),
  1959. _T("江猪媳"),
  1960. _T("姜春云"),
  1961. _T("僵贼"),
  1962. _T("僵贼民"),
  1963. _T("讲法"),
  1964. _T("教徒"),
  1965. _T("教养院"),
  1966. _T("接班"),
  1967. _T("揭批书"),
  1968. _T("结账"),
  1969. _T("金尧如"),
  1970. _T("锦涛"),
  1971. _T("经文"),
  1972. _T("靖国神社"),
  1973. _T("静坐"),
  1974. _T("九成新"),
  1975. _T("开放杂志"),
  1976. _T("砍掉"),
  1977. _T("抗日"),
  1978. _T("抗议"),
  1979. _T("靠你妈"),
  1980. _T("邝锦文"),
  1981. _T("拉丹"),
  1982. _T("拉登"),
  1983. _T("烂逼"),
  1984. _T("烂货"),
  1985. _T("劳动教养所"),
  1986. _T("老江"),
  1987. _T("老人政治"),
  1988. _T("李长春"),
  1989. _T("李登辉"),
  1990. _T("李洪志"),
  1991. _T("李兰菊"),
  1992. _T("李老师"),
  1993. _T("李禄"),
  1994. _T("李瑞环"),
  1995. _T("李淑娴"),
  1996. _T("李文斌"),
  1997. _T("李小鹏"),
  1998. _T("李志绥"),
  1999. _T("李总统"),
  2000. _T("联4通"),
  2001. _T("联总"),
  2002. _T("联总之声"),
  2003. _T("廉政大论坛"),
  2004. _T("梁光烈"),
  2005. _T("梁擎墩"),
  2006. _T("两岸关系"),
  2007. _T("两个中国"),
  2008. _T("两会报道"),
  2009. _T("廖锡龙"),
  2010. _T("林保华射精"),
  2011. _T("灵动卡"),
  2012. _T("领事馆"),
  2013. _T("刘宾深"),
  2014. _T("刘刚"),
  2015. _T("刘华清"),
  2016. _T("刘俊国"),
  2017. _T("刘千石"),
  2018. _T("刘山青"),
  2019. _T("刘士贤司马晋"),
  2020. _T("刘文胜"),
  2021. _T("刘晓竹"),
  2022. _T("刘永川"),
  2023. _T("六 合"),
  2024. _T("六合"),
  2025. _T("六合彩"),
  2026. _T("六码"),
  2027. _T("六四"),
  2028. _T("六四民主运动"),
  2029. _T("龙虎豹"),
  2030. _T("龙虎豹宋书元"),
  2031. _T("龙卷风"),
  2032. _T("陆委会"),
  2033. _T("吕京花"),
  2034. _T("抡功"),
  2035. _T("伦功"),
  2036. _T("轮功"),
  2037. _T("罗干"),
  2038. _T("罗礼诗"),
  2039. _T("麻将"),
  2040. _T("麻将机"),
  2041. _T("马会"),
  2042. _T("马三家"),
  2043. _T("马时敏"),
  2044. _T("卖国唐捷"),
  2045. _T("毛厕洞"),
  2046. _T("毛片"),
  2047. _T("毛贼东"),
  2048. _T("美国参考"),
  2049. _T("猛料"),
  2050. _T("蒙古独"),
  2051. _T("梦网洪志"),
  2052. _T("迷药"),
  2053. _T("密穴"),
  2054. _T("绵恒异议人士"),
  2055. _T("民国"),
  2056. _T("民联"),
  2057. _T("民运"),
  2058. _T("民阵"),
  2059. _T("民主"),
  2060. _T("民族矛盾"),
  2061. _T("明慧"),
  2062. _T("莫伟强"),
  2063. _T("内幕"),
  2064. _T("男女公关"),
  2065. _T("男性"),
  2066. _T("南大论坛"),
  2067. _T("倪育贤"),
  2068. _T("你妈的"),
  2069. _T("你说我说论坛"),
  2070. _T("牛逼"),
  2071. _T("牛比"),
  2072. _T("潘国平"),
  2073. _T("泡沫经济"),
  2074. _T("嫖娼"),
  2075. _T("平米A"),
  2076. _T("迫害"),
  2077. _T("破鞋"),
  2078. _T("祁建"),
  2079. _T("齐墨"),
  2080. _T("钱达"),
  2081. _T("钱国梁"),
  2082. _T("钱其琛"),
  2083. _T("枪支"),
  2084. _T("抢粮记"),
  2085. _T("乔石"),
  2086. _T("窃听器"),
  2087. _T("窃听王"),
  2088. _T("亲日"),
  2089. _T("钦本立"),
  2090. _T("秦晋"),
  2091. _T("青天白日旗"),
  2092. _T("情妇"),
  2093. _T("庆红"),
  2094. _T("求:购"),
  2095. _T("全1球通"),
  2096. _T("全国两会"),
  2097. _T("权柄"),
  2098. _T("热比娅"),
  2099. _T("人民报"),
  2100. _T("人民报讯"),
  2101. _T("人民大众"),
  2102. _T("人民大众时事参考"),
  2103. _T("人民内情真相"),
  2104. _T("人民真实报道"),
  2105. _T("人民之声论坛"),
  2106. _T("人权"),
  2107. _T("人质"),
  2108. _T("日货"),
  2109. _T("日你"),
  2110. _T("日他"),
  2111. _T("如6意通"),
  2112. _T("乳房"),
  2113. _T("三陪"),
  2114. _T("骚货"),
  2115. _T("杀笔"),
  2116. _T("傻B"),
  2117. _T("煞笔"),
  2118. _T("善恶有报"),
  2119. _T("上访"),
  2120. _T("上海孤儿院"),
  2121. _T("邵家健"),
  2122. _T("涉日"),
  2123. _T("神7州行"),
  2124. _T("沈彤"),
  2125. _T("盛华仁"),
  2126. _T("盛雪辛灏年"),
  2127. _T("十八摸"),
  2128. _T("石戈"),
  2129. _T("时代论坛"),
  2130. _T("时事参考"),
  2131. _T("时事论坛"),
  2132. _T("使馆"),
  2133. _T("世界经济导报"),
  2134. _T("示威"),
  2135. _T("事实独立"),
  2136. _T("刷卡"),
  2137. _T("双十节"),
  2138. _T("氵去车仑工力"),
  2139. _T("税力"),
  2140. _T("司马晋"),
  2141. _T("司马璐"),
  2142. _T("司徒华"),
  2143. _T("私彩"),
  2144. _T("斯诺"),
  2145. _T("四联航空"),
  2146. _T("宋xx"),
  2147. _T("宋平"),
  2148. _T("宋书元"),
  2149. _T("宋祖英"),
  2150. _T("苏绍智"),
  2151. _T("苏晓康"),
  2152. _T("他妈"),
  2153. _T("他妈的"),
  2154. _T("台*湾"),
  2155. _T("台独"),
  2156. _T("台盟"),
  2157. _T("台湾"),
  2158. _T("台湾狗"),
  2159. _T("台湾联盟"),
  2160. _T("台湾青年独立联盟"),
  2161. _T("台湾政论区"),
  2162. _T("台湾自由联盟"),
  2163. _T("唐捷"),
  2164. _T("套牌"),
  2165. _T("套牌车"),
  2166. _T("特码"),
  2167. _T("滕文生"),
  2168. _T("提供特码"),
  2169. _T("天安门录影带"),
  2170. _T("天安门事件"),
  2171. _T("天安门屠杀"),
  2172. _T("天怒"),
  2173. _T("天葬"),
  2174. _T("统独"),
  2175. _T("投毒"),
  2176. _T("透码"),
  2177. _T("突厥斯坦"),
  2178. _T("屠杀"),
  2179. _T("外交论坛"),
  2180. _T("外围"),
  2181. _T("晚年周恩来"),
  2182. _T("万润南"),
  2183. _T("万晓东"),
  2184. _T("王宝森"),
  2185. _T("王炳章"),
  2186. _T("王策"),
  2187. _T("王超华"),
  2188. _T("王辅臣"),
  2189. _T("王涵万"),
  2190. _T("王沪"),
  2191. _T("王军涛"),
  2192. _T("王瑞林"),
  2193. _T("王若望"),
  2194. _T("王秀丽"),
  2195. _T("网特"),
  2196. _T("尉健行"),
  2197. _T("魏京生"),
  2198. _T("温家宝"),
  2199. _T("温元凯"),
  2200. _T("文革"),
  2201. _T("我操"),
  2202. _T("无抵押贷款"),
  2203. _T("无界浏览器"),
  2204. _T("无能"),
  2205. _T("吴百益"),
  2206. _T("吴弘达"),
  2207. _T("吴仁华"),
  2208. _T("吴学璨"),
  2209. _T("吾尔开希"),
  2210. _T("五不争鸣论坛"),
  2211. _T("伍凡"),
  2212. _T("藏独"),
  2213. _T("香港总部"),
  2214. _T("项小吉"),
  2215. _T("小6灵通"),
  2216. _T("小参考"),
  2217. _T("小肛"),
  2218. _T("小泉"),
  2219. _T("小泉纯一郎"),
  2220. _T("肖强"),
  2221. _T("邪恶"),
  2222. _T("谢长廷"),
  2223. _T("谢选骏"),
  2224. _T("谢中之"),
  2225. _T("新华举报"),
  2226. _T("新华通论坛"),
  2227. _T("新生网"),
  2228. _T("新闻封锁"),
  2229. _T("信用危机"),
  2230. _T("性服务"),
  2231. _T("性交"),
  2232. _T("熊焱"),
  2233. _T("徐邦秦"),
  2234. _T("徐匡迪"),
  2235. _T("徐水良"),
  2236. _T("许家屯"),
  2237. _T("玄`机"),
  2238. _T("玄机"),
  2239. _T("学潮"),
  2240. _T("学潮晚年周恩来"),
  2241. _T("学联"),
  2242. _T("学运"),
  2243. _T("雪山狮子"),
  2244. _T("压迫"),
  2245. _T("颜射"),
  2246. _T("杨怀安"),
  2247. _T("杨建利"),
  2248. _T("杨巍"),
  2249. _T("杨周"),
  2250. _T("姚月谦"),
  2251. _T("摇奖"),
  2252. _T("夜话紫禁城"),
  2253. _T("一码"),
  2254. _T("一切证件"),
  2255. _T("一肖"),
  2256. _T("伊斯兰运动"),
  2257. _T("移3动"),
  2258. _T("义解"),
  2259. _T("异议人士"),
  2260. _T("易丹轩"),
  2261. _T("阴唇"),
  2262. _T("阴蒂"),
  2263. _T("阴茎"),
  2264. _T("阴胫"),
  2265. _T("淫秽"),
  2266. _T("淫穴"),
  2267. _T("印尼伊斯兰祈祷团"),
  2268. _T("印章"),
  2269. _T("游行"),
  2270. _T("幼齿"),
  2271. _T("幼女"),
  2272. _T("于浩成"),
  2273. _T("舆论"),
  2274. _T("舆论反制"),
  2275. _T("远志明"),
  2276. _T("杂种"),
  2277. _T("造反"),
  2278. _T("则民"),
  2279. _T("泽民"),
  2280. _T("曾培炎"),
  2281. _T("炸药"),
  2282. _T("张伯笠"),
  2283. _T("张宏堡"),
  2284. _T("张林"),
  2285. _T("张伟国"),
  2286. _T("张昭富"),
  2287. _T("张志清"),
  2288. _T("招生"),
  2289. _T("赵海青"),
  2290. _T("赵南"),
  2291. _T("赵晓微"),
  2292. _T("赵紫阳"),
  2293. _T("哲民"),
  2294. _T("真相"),
  2295. _T("镇压"),
  2296. _T("争鸣论坛"),
  2297. _T("正法"),
  2298. _T("正义党论坛"),
  2299. _T("郑源"),
  2300. _T("政变"),
  2301. _T("政府"),
  2302. _T("政权"),
  2303. _T("政治反对派"),
  2304. _T("政治风波"),
  2305. _T("支那"),
  2306. _T("中俄边界新约"),
  2307. _T("中功"),
  2308. _T("中共"),
  2309. _T("中国复兴论坛"),
  2310. _T("中国孤儿院"),
  2311. _T("中国论坛"),
  2312. _T("中国社会论坛"),
  2313. _T("中国问题论坛"),
  2314. _T("中国真实内容"),
  2315. _T("中国猪"),
  2316. _T("中华大众"),
  2317. _T("中华民国"),
  2318. _T("中华人民正邪"),
  2319. _T("中华时事"),
  2320. _T("中华养生益智功"),
  2321. _T("周锋锁"),
  2322. _T("周旋"),
  2323. _T("朱琳"),
  2324. _T("朱毛"),
  2325. _T("朱溶剂"),
  2326. _T("猪操"),
  2327. _T("猪毛"),
  2328. _T("主席"),
  2329. _T("主义"),
  2330. _T("专制"),
  2331. _T("庄家"),
  2332. _T("追讨债务"),
  2333. _T("追债"),
  2334. _T("子弹"),
  2335. _T("紫阳"),
  2336. _T("自民党"),
  2337. _T("自由"),
  2338. _T("自由运动"),
  2339. _T("作爱"),
  2340. _T("做爱"),
  2341. _T("儍B"),
  2342. _T("儍 B"),
  2343. _T("珺"),
  2344. _T("彧"),
  2345. _T("︰"),
  2346. _T("现房"),
  2347. _T("公寓"),
  2348. _T("小户"),
  2349. _T("房产"),
  2350. _T("写字楼"),
  2351. _T("房型"),
  2352. _T("旺铺"),
  2353. _T("购房"),
  2354. _T("精装"),
  2355. _T("别墅"),
  2356. _T("洋房"),
  2357. _T("城堡"),
  2358. _T("生态区"),
  2359. _T("名宅"),
  2360. _T("劵"),
  2361. _T("房折"),
  2362. _T("公馆"),
  2363. _T("首付"),
  2364. _T("复式"),
  2365. _T("全户型"),
  2366. _T("装修"),
  2367. _T("卖房"),
  2368. _T("买房"),
  2369. _T("豪宅"),
  2370. _T("租房"),
  2371. _T("样板间"),
  2372. _T("地产"),
  2373. _T("楼盘"),
  2374. _T("商业楼"),
  2375. _T("景观住宅"),
  2376. _T("两限房"),
  2377. _T("风水宝地"),
  2378. _T("抢购"),
  2379. _T("号码百事通"),
  2380. _T("街铺"),
  2381. _T("一梯两户"),
  2382. _T("看房"),
  2383. _T("特惠房"),
  2384. _T("小旺铺"),
  2385. _T("准现房"),
  2386. _T("房展"),
  2387. _T("户型"),
  2388. _T("銶"),
  2389. _T("㎡"),
  2390. _T("湳"),
  2391. _T("― ")
  2392. //-----------------
  2393. #if JEFF_DELETE_ON
  2394. _T("【call5.me】"),
  2395. _T("您可拨020"),
  2396. _T("88btt.com热线400611"),
  2397. _T("400678165"),
  2398. _T("海王星"),
  2399. _T("博天堂"),
  2400. _T("十八大"),
  2401. _T("钓鱼岛"),
  2402. _T("无限次数提款"),
  2403. _T("广东地和"),
  2404. _T("利来"),
  2405. _T("抢劫"),
  2406. _T("fa lun"),
  2407. _T("强奸"),
  2408. _T("dafa"),
  2409. _T("falun"),
  2410. _T("SIM卡抽奖"),
  2411. _T("罢工"),
  2412. _T("罢课"),
  2413. _T("暴乱"),
  2414. _T("婊子"),
  2415. _T("操你"),
  2416. _T("操你娘"),
  2417. _T("蠢猪"),
  2418. _T("达赖"),
  2419. _T("打倒"),
  2420. _T("大法"),
  2421. _T("大纪元"),
  2422. _T("弹药"),
  2423. _T("钓鱼岛"),
  2424. _T("东突"),
  2425. _T("东突厥斯坦伊斯兰运动"),
  2426. _T("发抡"),
  2427. _T("发仑"),
  2428. _T("发伦"),
  2429. _T("发囵"),
  2430. _T("发沦"),
  2431. _T("发纶"),
  2432. _T("发轮"),
  2433. _T("发论"),
  2434. _T("法 轮 功"),
  2435. _T("法.轮.功"),
  2436. _T("法抡"),
  2437. _T("法仑"),
  2438. _T("法伦"),
  2439. _T("法囵"),
  2440. _T("法沦"),
  2441. _T("法纶"),
  2442. _T("法轮"),
  2443. _T("法论"),
  2444. _T("反革命"),
  2445. _T("反日"),
  2446. _T("分裂"),
  2447. _T("干你娘"),
  2448. _T("功友"),
  2449. _T("古怪歌"),
  2450. _T("国研新闻邮件"),
  2451. _T("黑庄"),
  2452. _T("宏志"),
  2453. _T("洪志"),
  2454. _T("胡锦涛"),
  2455. _T("鸡巴"),
  2456. _T("鸡毛信文汇"),
  2457. _T("妓女"),
  2458. _T("简鸿章"),
  2459. _T("江八点"),
  2460. _T("江独裁"),
  2461. _T("江泽民"),
  2462. _T("疆独"),
  2463. _T("教徒"),
  2464. _T("锦涛"),
  2465. _T("靖国神社"),
  2466. _T("九、评"),
  2467. _T("九.评"),
  2468. _T("九码"),
  2469. _T("九-评"),
  2470. _T("拉丹"),
  2471. _T("拉登"),
  2472. _T("李鹏"),
  2473. _T("联总之声传单"),
  2474. _T("灵动卡"),
  2475. _T("六合彩"),
  2476. _T("六码"),
  2477. _T("吕秀莲"),
  2478. _T("绿色环保手机"),
  2479. _T("美国之音"),
  2480. _T("猛料"),
  2481. _T("迷药"),
  2482. _T("民运"),
  2483. _T("民猪"),
  2484. _T("嫖娼"),
  2485. _T("迫害"),
  2486. _T("枪支"),
  2487. _T("强奸"),
  2488. _T("窃听器"),
  2489. _T("人民报"),
  2490. _T("人民报讯"),
  2491. _T("人民大众时事参考"),
  2492. _T("人民内情真相"),
  2493. _T("人民真实报道"),
  2494. _T("人权"),
  2495. _T("日你妈"),
  2496. _T("日他"),
  2497. _T("三码"),
  2498. _T("三陪"),
  2499. _T("色情"),
  2500. _T("傻B"),
  2501. _T("涉日"),
  2502. _T("十六大"),
  2503. _T("示威"),
  2504. _T("他妈的"),
  2505. _T("台*湾"),
  2506. _T("特等奖"),
  2507. _T("天葬"),
  2508. _T("突厥斯坦"),
  2509. _T("推翻"),
  2510. _T("王八蛋"),
  2511. _T("温家宝"),
  2512. _T("无能"),
  2513. _T("香港总部"),
  2514. _T("小鸡鸡"),
  2515. _T("新华举报"),
  2516. _T("新华内情"),
  2517. _T("新闻封锁"),
  2518. _T("畜生"),
  2519. _T("玄`机"),
  2520. _T("压迫"),
  2521. _T("淫秽"),
  2522. _T("银行联合管理局"),
  2523. _T("印尼伊斯兰祈祷团"),
  2524. _T("游行"),
  2525. _T("舆论"),
  2526. _T("造反"),
  2527. _T("真善忍"),
  2528. _T("镇压"),
  2529. _T("正法"),
  2530. _T("政变"),
  2531. _T("政治风波"),
  2532. _T("中俄边界新约"),
  2533. _T("中国银联"),
  2534. _T("中华民国"),
  2535. _T("中奖"),
  2536. _T("朱容基"),
  2537. _T("自焚"),
  2538. _T("自由运动"),
  2539. _T("达赖"),
  2540. _T("套牌"),
  2541. _T("情妇"),
  2542. _T("监听"),
  2543. _T("巴南电信"),
  2544. _T("合川分公司"),
  2545. _T("合川电信"),
  2546. _T("死光"),
  2547. _T("116114"),
  2548. _T("北京宝诚"),
  2549. _T("华盛投资"),
  2550. _T("名门国际"),
  2551. _T("利博"),
  2552. _T("赤橙黄绿"),
  2553. _T("免佣BJL首发"),
  2554. _T("洗*码优惠"),
  2555. _T("【俱乐部】"),
  2556. _T("18266381922"),
  2557. _T("回拨卡"),
  2558. _T("号码百事通推出短信订机票!实时")
  2559. #endif
  2560. };
  2561. for (int i = 0; i < 1065; i++)//165
  2562. {
  2563. g_temp = badwords[i];
  2564. if (str.Find(g_temp) != -1)
  2565. {
  2566. // AfxMessageBox("信息服务商禁止的非法字符:("+g_temp+")希望您谅解!");
  2567. TRACE(_T("信息服务商禁止的非法字符,希望您谅解\n"));
  2568. return 1;
  2569. }
  2570. }
  2571. return 0;
  2572. }
  2573. ///目录是否存在的检查: 支持网络文件夹
  2574. bool CheckFolderFileExist(CString &strPath)
  2575. {
  2576. CString path = strPath;
  2577. CFile fp;
  2578. if (fp.Open(path, CFile::modeRead))
  2579. {
  2580. fp.Close();
  2581. return 1;
  2582. }
  2583. if (strPath.Right(1) != "\\")
  2584. path += "\\";
  2585. path += "zaqw1234.dat";
  2586. ::DeleteFile(path);
  2587. if (fp.Open(path, CFile::modeCreate) == 0)
  2588. return 0;
  2589. fp.Close();
  2590. ::DeleteFile(path);
  2591. return 1;
  2592. }
  2593. int FindArray(CStringArray *pArray, const CString &Str)
  2594. {
  2595. for (int i = 0; i < pArray->GetSize(); i++)
  2596. {
  2597. if (pArray->ElementAt(i) == Str)
  2598. return i;
  2599. }
  2600. return -1;
  2601. }
  2602. void FillLength(CString &str, int length)
  2603. {
  2604. while (str.GetLength() < length)
  2605. str += " ";
  2606. }
  2607. int GetYearPos(int year)
  2608. {
  2609. for (int i = 0; i < g_hisyeararray.GetSize(); i++)
  2610. {
  2611. if (year == _ttoi(g_hisyeararray.ElementAt(i).ElementAt(0)))
  2612. return i;
  2613. }
  2614. return -1;
  2615. }
  2616. BOOL GIsHalfHZ(const CString &str)
  2617. {
  2618. int len = str.GetLength();
  2619. BOOL IsHalf = FALSE;
  2620. for (int i = 0; i < len; i++)
  2621. {
  2622. if (str.GetAt(i) < 0) IsHalf = !IsHalf;
  2623. }
  2624. return IsHalf;
  2625. }
  2626. void WriteTitle(CString str)
  2627. {
  2628. g_title = str;
  2629. CStdioFile fp;
  2630. fp.Open(g_mainpath + "\\title.txt", CFile::modeWrite | CFile::modeCreate);
  2631. fp.WriteString(str);
  2632. fp.Close();
  2633. }
  2634. CString GetIP(CString branch)
  2635. {
  2636. for (int i = 0; i < g_brancharray.GetSize(); i++)
  2637. {
  2638. if (g_domain == g_brancharray.ElementAt(i).ElementAt(2))
  2639. {
  2640. //if(g_serverbak.Find (".ly.com")!=-1)
  2641. return g_server;
  2642. CString ip = g_serverbak;
  2643. //MyGetIPByName(ip);
  2644. return ip;
  2645. }
  2646. if (branch == g_brancharray.ElementAt(i).ElementAt(0))
  2647. {
  2648. return g_brancharray.ElementAt(i).ElementAt(1);
  2649. }
  2650. }
  2651. return _T("");
  2652. }
  2653. BOOL IsHanZi(CString str)
  2654. {
  2655. TBYTE ucHigh, ucLow;
  2656. for (int i = 0; i < str.GetLength(); i++)
  2657. {
  2658. if ((TBYTE)str[i] < 0x80)
  2659. {
  2660. continue;
  2661. }
  2662. ucHigh = (TBYTE)str[i];
  2663. ucLow = (TBYTE)str[i + 1];
  2664. if (ucHigh < 0xa1 || ucLow < 0xa1)
  2665. {
  2666. continue;
  2667. }
  2668. return 1;
  2669. }
  2670. return 0;
  2671. }
  2672. int GetType(CString str)
  2673. {
  2674. if (IsHanZi(str))return 0;
  2675. BOOL bDigit = 1;
  2676. BOOL bAlpha = 1;
  2677. for (int i = 0; i < str.GetLength(); i++)
  2678. {
  2679. if (!::isdigit(str.GetAt(i)))
  2680. //if(! ((str.GetAt (i)<='0' && str.GetAt (i)>='9' ) ))
  2681. bDigit = 0;
  2682. if (!((str.GetAt(i) <= 'z' && str.GetAt(i) >= 'a') || (str.GetAt(i) <= 'Z' && str.GetAt(i) >= 'A')))
  2683. //else if(!::isalpha ( ((unsigned char)str.GetAt (i))))
  2684. bAlpha = 0;
  2685. if (bDigit == 0 && bAlpha == 0)return 0;
  2686. }
  2687. if (bDigit)
  2688. {
  2689. /*#ifdef SUNRAIN_VERSION
  2690. return 0;
  2691. #else*/
  2692. return 0;
  2693. //#endif
  2694. }
  2695. else if (bAlpha)
  2696. {
  2697. return 2;
  2698. }
  2699. else
  2700. return 0;
  2701. }
  2702. CString FilterBZ(CString &bz)
  2703. {
  2704. bz.Replace(_T("'"), _T(""));
  2705. /* int i=bz.GetLength ()-1;
  2706. char c;
  2707. for(;i>=0;i--)
  2708. {
  2709. c=bz.GetAt (i);
  2710. if(c<32)// && c!=10 && c!=13)
  2711. bz.Delete (i);
  2712. }*/
  2713. if (bz.GetLength() > 1023)
  2714. {
  2715. AfxMessageBox(_T("文字太长, 字符串将被截取!"), MB_ICONSTOP);
  2716. bz = bz.Left(1023);
  2717. }
  2718. return bz;
  2719. }
  2720. // GetWidth()的长度与CRect的长度是不一样的单位值,需要转换适合的比例;(一个是图片的像素尺寸,一个DC的大小尺寸)
  2721. // 将图片尺寸与设备尺寸进行转换适合的比例;
  2722. void RectFitDes(int width, int height, CRect &rc)
  2723. {
  2724. try
  2725. {
  2726. if (width == 0 || height == 0)return;
  2727. // 图片长宽比例;
  2728. float fscale = (float)width / (float)height;
  2729. // 设备长宽比例;
  2730. float rcscale = ((float)rc.Width()) / ((float)rc.Height());
  2731. int rcwid = rc.Width();
  2732. int rchei = rc.Height();
  2733. int dt = 0;
  2734. // Jeff.如果设备长宽比例 < 图片长宽比例;(即相同长度下,高越大比例值越小,所以此时图片尺寸 与 显示设备的尺寸相比,要显得更长)
  2735. if (rcscale < fscale)
  2736. {
  2737. // Jeff.remarks
  2738. // 调整显示设备的大小,以使之能容纳图片尺寸;(即长宽比例上,要大于或等于图片的长宽比例)
  2739. // 所以有两种方法使得 rcscale >= fscale 表达式成立:
  2740. // -----------------------------------------------
  2741. // 方法1:显示设备宽加x值,计算出下面表达式x的值即可
  2742. // (rc.Width()+x) / rc.Height() >= width/height;
  2743. // 方法2:显示设备高减x值,计算出下面表达式x的值即可
  2744. // (rc.Width()) / (rc.Height()-x) >= width/height;
  2745. //------------------------------------------------
  2746. // 两种方法的最后表达式为:
  2747. // x >= rc.Height() - rcWidth()*(height/width);
  2748. // 即 x >= rc.Height() - rcWidth()/fscale;
  2749. //------------------------------------------------
  2750. dt = (rchei - rcwid / fscale) / 2;
  2751. rc.top += dt;
  2752. rc.bottom -= dt;
  2753. }
  2754. else
  2755. {
  2756. dt = (rcwid - rchei*fscale) / 2;
  2757. rc.left += dt;
  2758. rc.right -= dt;
  2759. }
  2760. }
  2761. catch (...)
  2762. {
  2763. }
  2764. }
  2765. BOOL IsHasRights(int pos)
  2766. {
  2767. return 1;
  2768. if (g_user.rights.GetLength() > pos)
  2769. {
  2770. BOOL ret = _ttoi(g_user.rights.Mid(pos, 1));
  2771. if (ret == 0)AfxMessageBox(_T("没有相关权限!"), MB_ICONINFORMATION);
  2772. return ret;
  2773. }
  2774. AfxMessageBox(_T("没有相关权限!"), MB_ICONINFORMATION);
  2775. return 0;
  2776. }
  2777. BOOL IsHasRights2(int pos)
  2778. {
  2779. return 1;
  2780. if (g_user.rights.GetLength() > pos)
  2781. {
  2782. BOOL ret = _ttoi(g_user.rights.Mid(pos, 1));
  2783. return ret;
  2784. }
  2785. return 0;
  2786. }
  2787. BOOL IsHasRightsnew(int pos)
  2788. {
  2789. if (g_user.rights.GetLength() > pos)
  2790. {
  2791. BOOL ret = _ttoi(g_user.rights.Mid(pos, 1));
  2792. if (ret == 0)AfxMessageBox(_T("没有相关权限! 请与系统管理员联系!"), MB_ICONINFORMATION);
  2793. return ret;
  2794. }
  2795. AfxMessageBox(_T("没有相关权限! 请与系统管理员联系!"), MB_ICONINFORMATION);
  2796. return 0;
  2797. }
  2798. BOOL IsHasRights2new(int pos)
  2799. {
  2800. if (g_user.rights.GetLength() > pos)
  2801. {
  2802. BOOL ret = _ttoi(g_user.rights.Mid(pos, 1));
  2803. return ret;
  2804. }
  2805. return 0;
  2806. }
  2807. /********************************************************************************************
  2808. /* Syntax
  2809. /* void FirstLetter(int nCode, CString& strLetter)
  2810. /* Remarks:
  2811. /* Get the first letter of pinyin according to specified Chinese character code.
  2812. /* Parameters:
  2813. /* nCode - the code of the chinese character.
  2814. /* strLetter - a CString object that is to receive the string of the first letter.
  2815. /* Return Values:
  2816. /* None.
  2817. /* Author:
  2818. /* lixiaosan
  2819. /* Create Date:
  2820. /* 05-26-2006
  2821. /********************************************************************************************/
  2822. void FirstLetter(int nCode, CString& strLetter)
  2823. {
  2824. if (nCode >= 1601 && nCode < 1637) strLetter = _T("A");
  2825. if (nCode >= 1637 && nCode < 1833) strLetter = _T("B");
  2826. if (nCode >= 1833 && nCode < 2078) strLetter = _T("C");
  2827. if (nCode >= 2078 && nCode < 2274) strLetter = _T("D");
  2828. if (nCode >= 2274 && nCode < 2302) strLetter = _T("E");
  2829. if (nCode >= 2302 && nCode < 2433) strLetter = _T("F");
  2830. if (nCode >= 2433 && nCode < 2594) strLetter = _T("G");
  2831. if (nCode >= 2594 && nCode < 2787) strLetter = _T("H");
  2832. if (nCode >= 2787 && nCode < 3106) strLetter = _T("J");
  2833. if (nCode >= 3106 && nCode < 3212) strLetter = _T("K");
  2834. if (nCode >= 3212 && nCode < 3472) strLetter = _T("L");
  2835. if (nCode >= 3472 && nCode < 3635) strLetter = _T("M");
  2836. if (nCode >= 3635 && nCode < 3722) strLetter = _T("N");
  2837. if (nCode >= 3722 && nCode < 3730) strLetter = _T("O");
  2838. if (nCode >= 3730 && nCode < 3858) strLetter = _T("P");
  2839. if (nCode >= 3858 && nCode < 4027) strLetter = _T("Q");
  2840. if (nCode >= 4027 && nCode < 4086) strLetter = _T("R");
  2841. if (nCode >= 4086 && nCode < 4390) strLetter = _T("S");
  2842. if (nCode >= 4390 && nCode < 4558) strLetter = _T("T");
  2843. if (nCode >= 4558 && nCode < 4684) strLetter = _T("W");
  2844. if (nCode >= 4684 && nCode < 4925) strLetter = _T("X");
  2845. if (nCode >= 4925 && nCode < 5249) strLetter = _T("Y");
  2846. if (nCode >= 5249 && nCode < 5590) strLetter = _T("Z");
  2847. }
  2848. /********************************************************************************************
  2849. /* Syntax
  2850. /* GetFirstLetter(CString strName, CString& strFirstLetter)
  2851. /* Remarks:
  2852. /* Get the first letter of pinyin according to specified Chinese character.
  2853. /* Parameters:
  2854. /* strName - a CString object that is to be parsed.
  2855. /* strFirstLetter - a CString object that is to receive the string of the first letter.
  2856. /* Return Values:
  2857. /* None.
  2858. /* Author:
  2859. /* lixiaosan
  2860. /* Create Date:
  2861. /* 05-26-2006
  2862. /********************************************************************************************/
  2863. void GetFirstLetter(CString strName, CString& strFirstLetter)
  2864. {
  2865. TBYTE ucHigh, ucLow;
  2866. int nCode;
  2867. CString strRet;
  2868. strFirstLetter.Empty();
  2869. for (int i = 0; i < strName.GetLength(); i++)
  2870. {
  2871. if ((TBYTE)strName[i] < 0x80)
  2872. {
  2873. strRet = strName.Mid(i, 1);
  2874. strRet.MakeUpper();
  2875. strFirstLetter += strRet;
  2876. continue;
  2877. }
  2878. ucHigh = (TBYTE)strName[i];
  2879. ucLow = (TBYTE)strName[i + 1];
  2880. if (ucHigh < 0xa1 || ucLow < 0xa1)
  2881. continue;
  2882. else
  2883. // Treat code by section-position as an int type parameter,
  2884. // so make following change to nCode.
  2885. nCode = (ucHigh - 0xa0) * 100 + ucLow - 0xa0;
  2886. FirstLetter(nCode, strRet);
  2887. strFirstLetter += strRet;
  2888. i++;
  2889. }
  2890. }
  2891. CString newGUID()
  2892. {
  2893. CString str;
  2894. GUID guid;
  2895. CoInitialize(NULL);
  2896. if (S_OK == ::CoCreateGuid(&guid))
  2897. {
  2898. str.Format(
  2899. _T("{%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X}"),
  2900. guid.Data1,
  2901. guid.Data2,
  2902. guid.Data3,
  2903. guid.Data4[0], guid.Data4[1],
  2904. guid.Data4[2], guid.Data4[3],
  2905. guid.Data4[4], guid.Data4[5],
  2906. guid.Data4[6], guid.Data4[7]);
  2907. }
  2908. CoUninitialize();
  2909. return str.Left(28);
  2910. }
  2911. CString GetNameFromDomain(CString domain)
  2912. {
  2913. for (int i = 0; i < g_brancharray.GetSize(); i++)
  2914. {
  2915. if (domain == g_brancharray.ElementAt(i).ElementAt(2))
  2916. {
  2917. return g_brancharray.ElementAt(i).ElementAt(0);
  2918. }
  2919. }
  2920. return _T("");
  2921. }
  2922. void ConvertToPrice(CString &str)
  2923. {
  2924. if (str.Find('.') == -1)return;
  2925. str.TrimRight('0');
  2926. str.TrimRight('.');
  2927. }
  2928. BOOL myisdigit(CString str)
  2929. {
  2930. for (int i = 0; i < str.GetLength(); i++)
  2931. {
  2932. if (!::isdigit(str.GetAt(i)))
  2933. return 0;
  2934. }
  2935. return 1;
  2936. }
  2937. BOOL IsHasRightsnew2(int pos, CString rights)
  2938. {
  2939. if (rights.GetLength() > pos)
  2940. {
  2941. BOOL ret = _ttoi(rights.Mid(pos, 1));
  2942. if (ret == 0)AfxMessageBox(_T("没有相关权限! 请与系统管理员联系!"), MB_ICONINFORMATION);
  2943. return ret;
  2944. }
  2945. AfxMessageBox(_T("没有相关权限! 请与系统管理员联系!"), MB_ICONINFORMATION);
  2946. return 0;
  2947. }
  2948. DWORD FindAppProcessID(CString path)
  2949. {
  2950. try
  2951. {
  2952. HANDLE handle = ::CreateToolhelp32Snapshot(TH32CS_SNAPALL, 0);
  2953. PROCESSENTRY32 Info;
  2954. Info.dwSize = sizeof(PROCESSENTRY32);
  2955. path.MakeLower();
  2956. if (::Process32First(handle, &Info))
  2957. {
  2958. do
  2959. {
  2960. CString ss = Info.szExeFile;
  2961. ss.MakeLower();
  2962. if (ss.Find(path) != -1 || (!ss.CompareNoCase(path)))
  2963. {
  2964. ::CloseHandle(handle);
  2965. return Info.th32ProcessID;
  2966. }
  2967. } while (::Process32Next(handle, &Info));
  2968. ::CloseHandle(handle);
  2969. }
  2970. return -1;
  2971. }
  2972. catch (...)
  2973. {
  2974. }
  2975. return 0;
  2976. }
  2977. BOOL isInnerIP(DWORD a_ip) // Jeff.判断是否是内网?
  2978. {
  2979. BOOL bValid = 0;
  2980. if ((a_ip >> 24 == 0xa) || (a_ip >> 16 == 0xc0a8) || (a_ip >> 22 == 0x2b0))
  2981. {
  2982. bValid = 1;
  2983. }
  2984. return bValid;
  2985. }
  2986. //// Jeff.UNICODE版本未完成;
  2987. //void MyGetIPByName2(CString &name)
  2988. //{
  2989. //#if JEFF_TEST_ON
  2990. // CString strIP = name;
  2991. //#ifdef UNICODE
  2992. // int nLen = WideCharToMultiByte(CP_ACP, 0, strIP, -1, NULL, 0, NULL, NULL);
  2993. // if (nLen <= 0)
  2994. // return;
  2995. //
  2996. // char *hostname = new char[nLen];
  2997. // if (hostname == NULL)
  2998. // return;
  2999. //
  3000. // WideCharToMultiByte(CP_ACP, 0, strIP, -1, hostname, nLen, NULL, NULL);
  3001. // hostname[nLen - 1] = 0;
  3002. //#else
  3003. // char *hostname = strIP.GetBuffer();
  3004. // strIP.ReleaseBuffer();
  3005. //#endif
  3006. // addrinfo *ailist, *aip;
  3007. // addrinfo hint;
  3008. // sockaddr_in *sinp;
  3009. // //char *hostname = "luoyedeshan"; /* 这是我的用户名 */
  3010. // char buf[INET_ADDRSTRLEN];
  3011. // //char *server = "3294"; /* 这是服务端口号 */
  3012. // const char *pIPAddr;
  3013. // int ilRc;
  3014. // hint.ai_family = AF_INET; /* hint 的限定设置 */
  3015. // hint.ai_socktype = 0; /* 这里可是设置 socket type . 比如 SOCK——DGRAM */
  3016. // hint.ai_flags = AI_PASSIVE; /* flags 的标志很多 。常用的有AI_CANONNAME; */
  3017. // hint.ai_protocol = 0; /* 设置协议 一般为0,默认 */
  3018. // hint.ai_addrlen = 0; /* 下面不可以设置,为0,或者为NULL */
  3019. // hint.ai_canonname = NULL;
  3020. // hint.ai_addr = NULL;
  3021. // hint.ai_next = NULL;
  3022. // ilRc = getaddrinfo(hostname, NULL/*server*/, &hint, &ailist);
  3023. //
  3024. // delete hostname;
  3025. //
  3026. // if (ilRc < 0)
  3027. // {
  3028. // //char str_error[100];
  3029. // //strcpy_s(str_error, gai_strerrorA(errno));
  3030. // //printf("str_error = %s", str_error);
  3031. // return;
  3032. // }
  3033. //
  3034. // for (aip = ailist; aip != NULL; aip = aip->ai_next) /* 显示获取的信息 */
  3035. // {
  3036. // sinp = (sockaddr_in *)aip->ai_addr; /* 为什么是for 循环 ,先向下看 */
  3037. // pIPAddr = inet_ntop(AF_INET, &sinp->sin_addr, buf, INET_ADDRSTRLEN);
  3038. // printf(" addr = %s", pIPAddr ? pIPAddr : "unknow ");
  3039. // printf("port = %d ", ntohs(sinp->sin_port));
  3040. // printf(" \n");
  3041. // }
  3042. //#else
  3043. // CString strIP = name;
  3044. // int nLen = WideCharToMultiByte(CP_ACP, 0, strIP, -1, NULL, 0, NULL, NULL);
  3045. // if ( nLen <= 0 )
  3046. // {
  3047. // return;
  3048. // }
  3049. //
  3050. // char *pszIP = new char[nLen];
  3051. // if ( pszIP == NULL)
  3052. // {
  3053. // return;
  3054. // }
  3055. //
  3056. // WideCharToMultiByte(CP_ACP, 0, strIP, -1, pszIP, nLen, NULL, NULL);
  3057. // pszIP[nLen - 1] = 0;
  3058. //
  3059. // name.Empty();
  3060. // DWORD dwServerIP = 0;
  3061. // HOSTENT *host = gethostbyname(pszIP);
  3062. // delete pszIP;
  3063. // struct in_addr addr;
  3064. // if (host != NULL)
  3065. // {
  3066. // for (int i = 0; host->h_addr_list[i] != NULL; i++)
  3067. // {
  3068. // memset(&addr, 0, sizeof(addr));
  3069. // memcpy(&addr.S_un.S_addr, host->h_addr_list[i], host->h_length);
  3070. // dwServerIP = ntohl(addr.S_un.S_addr);
  3071. // BYTE* pIP = (BYTE*)&dwServerIP;
  3072. // name.Format(_T("%d.%d.%d.%d"), pIP[3], pIP[2], pIP[1], pIP[0]);
  3073. // }
  3074. // }
  3075. //#endif
  3076. //}
  3077. //
  3078. //// Jeff.UNICODE版本未完成;
  3079. //void MyGetIPByName(CString &name) // Jeff.根据计算机名称获取IP地址;
  3080. //{
  3081. //#if JEFF_TEST_ON
  3082. // g_serverarray.RemoveAll();
  3083. // CString strIP = name;
  3084. // name.Empty();
  3085. //
  3086. //#ifdef UNICODE
  3087. // int nLen = WideCharToMultiByte(CP_ACP, 0, strIP, -1, NULL, 0, NULL, NULL);
  3088. // if (nLen <= 0)
  3089. // return;
  3090. //
  3091. // char *hostname = new char[nLen];
  3092. // if (hostname == NULL)
  3093. // return;
  3094. //
  3095. // WideCharToMultiByte(CP_ACP, 0, strIP, -1, hostname, nLen, NULL, NULL);
  3096. // hostname[nLen - 1] = 0;
  3097. //#else
  3098. // char *hostname = strIP.GetBuffer();
  3099. // strIP.ReleaseBuffer();
  3100. //#endif
  3101. // addrinfo *ailist, *aip;
  3102. // addrinfo hint;
  3103. // sockaddr_in *sinp;
  3104. // //char *hostname = "luoyedeshan"; /* 这是我的用户名 */
  3105. // char buf[INET_ADDRSTRLEN];
  3106. // //char *server = "3294"; /* 这是服务端口号 */
  3107. // const char *pIPAddr;
  3108. // int ilRc;
  3109. // hint.ai_family = AF_INET; /* hint 的限定设置 */
  3110. // hint.ai_socktype = 0; /* 这里可是设置 socket type . 比如 SOCK——DGRAM */
  3111. // hint.ai_flags = AI_PASSIVE; /* flags 的标志很多 。常用的有AI_CANONNAME; */
  3112. // hint.ai_protocol = 0; /* 设置协议 一般为0,默认 */
  3113. // hint.ai_addrlen = 0; /* 下面不可以设置,为0,或者为NULL */
  3114. // hint.ai_canonname = NULL;
  3115. // hint.ai_addr = NULL;
  3116. // hint.ai_next = NULL;
  3117. // ilRc = getaddrinfo(hostname, NULL/*server*/, &hint, &ailist);
  3118. //
  3119. // delete hostname;
  3120. //
  3121. // if (ilRc < 0)
  3122. // {
  3123. // //char str_error[100];
  3124. // //strcpy_s(str_error, gai_strerrorA(errno));
  3125. // //printf("str_error = %s", str_error);
  3126. // return;
  3127. // }
  3128. //
  3129. // for (aip = ailist; aip != NULL; aip = aip->ai_next) /* 显示获取的信息 */
  3130. // {
  3131. // sinp = (sockaddr_in *)aip->ai_addr; /* 为什么是for 循环 ,先向下看 */
  3132. // pIPAddr = inet_ntop(AF_INET, &sinp->sin_addr, buf, INET_ADDRSTRLEN);
  3133. // printf(" addr = %s", pIPAddr ? pIPAddr : "unknow ");
  3134. // printf("port = %d ", ntohs(sinp->sin_port));
  3135. // printf(" \n");
  3136. // }
  3137. //#else
  3138. // g_serverarray.RemoveAll();
  3139. // CString strIP = name;
  3140. // name.Empty();
  3141. // DWORD dwServerIP = 0;
  3142. // HOSTENT *host = gethostbyname(strIP); // Jeff.所有本机的网络适配器;
  3143. // struct in_addr addr;
  3144. // if (host != NULL)
  3145. // {
  3146. // // Jeff.遍历本机所有适配器的IP地址;
  3147. // for (int i = 0; host->h_addr_list[i] != NULL; i++)
  3148. // {
  3149. // memset(&addr, 0, sizeof(addr));
  3150. // memcpy(&addr.S_un.S_addr, host->h_addr_list[i], host->h_length);
  3151. // dwServerIP = ntohl(addr.S_un.S_addr);
  3152. // BYTE* pIP = (BYTE*)&dwServerIP;
  3153. // name.Format(_T("%d.%d.%d.%d"), pIP[3], pIP[2], pIP[1], pIP[0]);
  3154. // g_serverarray.Add(name);
  3155. // }
  3156. // }
  3157. // while (g_serverarray.GetSize() > 1)
  3158. // {
  3159. // CString name;
  3160. // BOOL bFind = 0;
  3161. // for (int i = 0; i < g_serverarray.GetSize(); i++)
  3162. // {
  3163. // DWORD dwServerIP = inet_addr(g_serverarray.ElementAt(i));
  3164. // dwServerIP = htonl(dwServerIP);//加了才正确
  3165. // if (isInnerIP(dwServerIP) == 0)
  3166. // {
  3167. // // AfxMessageBox("外部IP");
  3168. // g_serverarray.RemoveAt(i);
  3169. // bFind = 1;
  3170. // break;
  3171. // }
  3172. // // else
  3173. // // AfxMessageBox("内部IP");
  3174. // }
  3175. // if (bFind == 0)
  3176. // {
  3177. // break;
  3178. // }
  3179. // }
  3180. //#endif
  3181. //}
  3182. CString GetW(CString str)
  3183. {
  3184. int x = _ttoi(str);
  3185. if (x > 9999)
  3186. {
  3187. str.Format(_T("%d"), x);
  3188. str = str.Right(5);
  3189. str = str.Left(1);
  3190. return str;
  3191. }
  3192. return _T("");
  3193. }
  3194. CString GetK(CString str)
  3195. {
  3196. int x = _ttoi(str);
  3197. if (x > 999)
  3198. {
  3199. str.Format(_T("%d"), x);
  3200. str = str.Right(4);
  3201. str = str.Left(1);
  3202. return str;
  3203. }
  3204. return _T("");
  3205. }
  3206. CString GetB(CString str)
  3207. {
  3208. int x = _ttoi(str);
  3209. if (x > 99)
  3210. {
  3211. str.Format(_T("%d"), x);
  3212. str = str.Right(3);
  3213. str = str.Left(1);
  3214. return str;
  3215. }
  3216. return _T("");
  3217. }
  3218. CString GetS(CString str)
  3219. {
  3220. int x = _ttoi(str);
  3221. if (x > 9)
  3222. {
  3223. str.Format(_T("%d"), x);
  3224. str = str.Right(2);
  3225. str = str.Left(1);
  3226. return str;
  3227. }
  3228. return _T("");
  3229. }
  3230. CString GetG(CString str)
  3231. {
  3232. int x = _ttoi(str);
  3233. if (x > 0)
  3234. {
  3235. str.Format(_T("%d"), x);
  3236. str = str.Right(1);
  3237. return str;
  3238. }
  3239. return _T("");
  3240. }
  3241. CString GetHMoney(CString str)
  3242. {
  3243. if (str.IsEmpty())
  3244. return _T("");
  3245. if (str == _T("0"))
  3246. return _T("零");
  3247. if (_ttoi(str) < 1 || _ttoi(str) > 9)
  3248. return _T("");
  3249. CString ret[] = { _T("壹"), _T("贰"), _T("叁"), _T("肆"), _T("伍"), _T("陆"), _T("柒"), _T("捌"), _T("玖") };
  3250. return ret[_ttoi(str) - 1];
  3251. }
  3252. BOOL CheckDateOK2(CString str)
  3253. {
  3254. if (str.IsEmpty())return 0;
  3255. CString tip;
  3256. int i;
  3257. CString demo = CTime::GetCurrentTime().Format(_T("%Y-%m-%d"));
  3258. if (str.GetLength() != demo.GetLength())
  3259. goto ll;
  3260. //2009-01-01
  3261. if (str.GetAt(4) != '-')
  3262. goto ll;
  3263. if (str.GetAt(7) != '-')
  3264. goto ll;
  3265. for (i = 0; i < str.GetLength(); i++)
  3266. {
  3267. if (i == 4 || i == 7)continue;
  3268. if (str.GetAt(i) < '0' || str.GetAt(i) > '9')
  3269. goto ll;
  3270. }
  3271. return 1;
  3272. ll:
  3273. return 0;
  3274. }
  3275. CString GetDomainFromBranch(CString branch)
  3276. {
  3277. if (branch.IsEmpty())return _T("");
  3278. for (int i = 0; i < g_brancharray.GetSize(); i++)
  3279. {
  3280. if (branch == g_brancharray.ElementAt(i).ElementAt(0))
  3281. {
  3282. return g_brancharray.ElementAt(i).ElementAt(2);
  3283. }
  3284. }
  3285. return _T("");
  3286. }
  3287. CString GetBranchPhotoPath(CString branch)
  3288. {
  3289. if (branch.IsEmpty())return _T("");
  3290. for (int i = 0; i < g_brancharray.GetSize() - 1; i++)
  3291. {
  3292. if (branch == g_brancharray.ElementAt(i).ElementAt(0))
  3293. {
  3294. return _T("\\") + g_brancharray.ElementAt(i).ElementAt(2);
  3295. }
  3296. }
  3297. return _T("");
  3298. }
  3299. CTime GetTmFromStr(CString date)
  3300. {
  3301. try
  3302. {
  3303. CTime tm(_ttoi(date.Mid(0, 4)), _ttoi(date.Mid(5, 2)), _ttoi(date.Mid(8, 2)), 0, 0, 0);
  3304. CString ss;
  3305. ss.Format(_T("%d-%d-%d"), tm.GetYear(), tm.GetMonth(), tm.GetDay());
  3306. return tm;
  3307. }
  3308. catch (...)
  3309. {
  3310. date = _T("1980-01-01");
  3311. CTime tm(_ttoi(date.Mid(0, 4)), _ttoi(date.Mid(5, 2)), _ttoi(date.Mid(8, 2)), 0, 0, 0);
  3312. return tm;
  3313. }
  3314. }
  3315. #endif
  3316. #if JEFF_CODE
  3317. // const char *inet_ntop(int af, const void *src, char *dst, socklen_t cnt)
  3318. // {
  3319. // if ( dst != NULL)
  3320. // {
  3321. // dst[0] = 0;
  3322. // if (af == AF_INET)
  3323. // {
  3324. // sockaddr_in in;
  3325. // memset(&in, 0, sizeof(in));
  3326. // in.sin_family = AF_INET;
  3327. // memcpy(&in.sin_addr, src, sizeof(in_addr));
  3328. // getnameinfo((sockaddr *)&in, sizeof(sockaddr_in), dst, cnt, NULL, 0, NI_NUMERICHOST);
  3329. // return dst;
  3330. // }
  3331. // else if (af == AF_INET6)
  3332. // {
  3333. // sockaddr_in6 in;
  3334. // memset(&in, 0, sizeof(in));
  3335. // in.sin6_family = AF_INET6;
  3336. // memcpy(&in.sin6_addr, src, sizeof(in6_addr));
  3337. // getnameinfo((sockaddr *)&in, sizeof(sockaddr_in6), dst, cnt, NULL, 0, NI_NUMERICHOST);
  3338. // return dst;
  3339. // }
  3340. // }
  3341. // WSASetLastError(WSA_INVALID_PARAMETER);
  3342. // return dst;
  3343. // }
  3344. //************************************//
  3345. // 数据库地址;
  3346. // 数据库端口;
  3347. // 数据库管理员账号;
  3348. // 数据库管理员密码;
  3349. // 数据库名称;
  3350. //
  3351. // [函数]:GetIniInfo
  3352. // [描述]:获取指定ini信息;
  3353. // [参数]:
  3354. // szPath:ini所在目录;
  3355. // szIniName:ini名;
  3356. // [返回]:void
  3357. //************************************//
  3358. int GetSysIniInfo(const char *szPath, const char *szIniName)
  3359. {
  3360. TCHAR szDrive[_MAX_DRIVE] = { 0 };
  3361. TCHAR szDir[_MAX_DIR] = { 0 };
  3362. TCHAR szFna[_MAX_DIR] = { 0 };
  3363. TCHAR szExt[_MAX_DIR] = { 0 };
  3364. ::GetModuleFileName(NULL, g_szModuleFileName, sizeof(g_szModuleFileName) / sizeof(TCHAR));
  3365. _stprintf_s(g_szModulePath, _T("%s"), g_szModuleFileName);
  3366. _tsplitpath_s(g_szModulePath, szDrive, szDir, szFna, szExt);
  3367. _tcscpy_s(g_szModulePath, szDrive);
  3368. _tcscat_s(g_szModulePath, szDir);
  3369. // -----------------------------------------------------//
  3370. TCHAR szFile[MAX_PATH + 1] = _T("");
  3371. if (szPath != NULL && szIniName != NULL)
  3372. _stprintf_s(szFile, _T("%s\\%s"), szPath, szIniName);
  3373. else
  3374. _stprintf_s(szFile, _T("%s\\ServiceInfo.ini"), g_szModulePath);
  3375. TRACE("szFile =%s\n", szFile);
  3376. HANDLE hFile = CreateFile(szFile, 0/*GENERIC_READ*/, 0, NULL, OPEN_EXISTING, 0, NULL);
  3377. if (ERROR_FILE_NOT_FOUND == GetLastError())
  3378. {
  3379. // 如果没找到,使用默认连接;
  3380. _tcscpy_s(g_szHostComputerIP, _T("."));
  3381. g_dwTCPChatPort = 5678;
  3382. return -1;
  3383. }
  3384. // 获取数据库信息;
  3385. GetPrivateProfileString(_T("DatabaseInfo"), _T("dbSource"), _T(""), g_szDBSource, MAX_PATH, szFile);
  3386. g_dwDBServerPort = GetPrivateProfileInt(_T("DatabaseInfo"), _T("dbServerPort"), 0, szFile);
  3387. GetPrivateProfileString(_T("DatabaseInfo"), _T("dbAccount"), _T(""), g_szDBAccount, MAX_PATH, szFile);
  3388. GetPrivateProfileString(_T("DatabaseInfo"), _T("dbPassWord"), _T(""), g_szDBPassWord, MAX_PATH, szFile);
  3389. GetPrivateProfileString(_T("DatabaseInfo"), _T("dbName"), _T(""), g_szDBName, MAX_PATH, szFile);
  3390. if (g_dwDBServerPort != 0)
  3391. _stprintf_s(g_szConnectString, _T("driver={SQL Server};Server=%s,%d;database=%s;uid=%s;pwd=%s"),
  3392. g_szDBSource, g_dwDBServerPort, g_szDBName, g_szDBAccount, g_szDBPassWord);
  3393. else
  3394. _stprintf_s(g_szConnectString, _T("driver={SQL Server};Server=%s;database=%s;uid=%s;pwd=%s"),
  3395. g_szDBSource, g_szDBName, g_szDBAccount, g_szDBPassWord);
  3396. // 获取服务器信息;
  3397. GetPrivateProfileString(_T("NetWorkInfo"), _T("ServerName"), _T(""), g_szHostComputerIP, MAX_PATH, szFile);
  3398. g_dwTCPChatPort = GetPrivateProfileInt(_T("NetWorkInfo"), _T("TCPChatPort"), 0, szFile);
  3399. g_dwTCPFilePort = GetPrivateProfileInt(_T("NetWorkInfo"), _T("TCPFilePort"), 0, szFile);
  3400. // 获取利亚方舟服务器信息;
  3401. GetPrivateProfileString(_T("NetWorkInfo"), _T("SMSServerName"), _T(""), g_szSMSServer, MAX_PATH, szFile);
  3402. g_dwTCPSMSPort = GetPrivateProfileInt(_T("NetWorkInfo"), _T("TCPSMSPort"), 0, szFile);
  3403. return 0;
  3404. }
  3405. //int MyFindPort_2(int start, BYTE *InByte, int InLen, char *OutPath)
  3406. int MyFindPort_2(int start, CONST int &nIndex, int InLen, char *OutPath)
  3407. {
  3408. int n;
  3409. int ret;
  3410. int nValues[8];
  3411. double lfValues[8];
  3412. CHAR s0[50] = "", s1[50] = "", s2[50] = "", s3[50] = "", s4[50] = "", s5[50] = "", s6[50] = "", s7[50] = "";
  3413. CHAR KeyPath[MAX_PATH] = "";
  3414. //查找系统上所有的锁;
  3415. for (n = 0; n < 256; n++)
  3416. {
  3417. ZeroMemory(KeyPath, sizeof(KeyPath));
  3418. ret = FindPort(n, KeyPath);
  3419. if (ret != 0 && n == 0)return -1053;//表示系统上没有任何智能锁;
  3420. if (ret != 0)return ret;
  3421. //使用该设备路径锁进行运算;
  3422. ret = CalEx((BYTE*)&g_byShotVersion[nIndex], InLen, &nValues[0], &nValues[1], &nValues[2], &nValues[3], &nValues[4], &nValues[5], &nValues[6], &nValues[7],
  3423. &lfValues[0], &lfValues[1], &lfValues[2], &lfValues[3], &lfValues[4], &lfValues[5], &lfValues[6], &lfValues[7],
  3424. s0, s1, s2, s3, s4, s5, s6, s7, KeyPath, 2000);
  3425. //如果正确,则返回该设备路径供以后使用;
  3426. if (ret == -63)
  3427. return ret;
  3428. if ((ret == 0) && (nValues[0] == 123))
  3429. {
  3430. // 找到加密狗,判断是否注册了医院跟踪功能;
  3431. g_nVersion = nIndex;
  3432. memset(nValues,0,8*sizeof(int));
  3433. memset(lfValues, 0, 8 * sizeof(double));
  3434. memset(s0, 0, 50 * sizeof(CHAR));
  3435. memset(s1, 0, 50 * sizeof(CHAR));
  3436. memset(s2, 0, 50 * sizeof(CHAR));
  3437. memset(s3, 0, 50 * sizeof(CHAR));
  3438. memset(s4, 0, 50 * sizeof(CHAR));
  3439. memset(s5, 0, 50 * sizeof(CHAR));
  3440. memset(s6, 0, 50 * sizeof(CHAR));
  3441. memset(s7, 0, 50 * sizeof(CHAR));
  3442. ret = CalEx((BYTE*)&g_byCalExVersion[nIndex], 114, &nValues[0], &nValues[1], &nValues[2], &nValues[3], &nValues[4], &nValues[5], &nValues[6], &nValues[7],
  3443. &lfValues[0], &lfValues[1], &lfValues[2], &lfValues[3], &lfValues[4], &lfValues[5], &lfValues[6], &lfValues[7],
  3444. s0, s1, s2, s3, s4, s5, s6, s7, KeyPath, 2000);
  3445. if (ret == 0 || ret == -43)
  3446. {
  3447. g_bSoftWareReg = atoi(s2);
  3448. if (g_bSoftWareReg)
  3449. {
  3450. }
  3451. }
  3452. return 0;
  3453. }
  3454. }
  3455. return -53;
  3456. }
  3457. int GetSoftWareVersion()
  3458. {
  3459. int nRet = 0;
  3460. CHAR szUSBKeyPath[MAX_PATH] = "";
  3461. for (int i(0); i < 6; i++)
  3462. {
  3463. //nRet = MyFindPort_2(0, g_byShotVersion[i], 10, szUSBKeyPath);
  3464. nRet = MyFindPort_2(0, i, 10, szUSBKeyPath);
  3465. if (nRet == 0)
  3466. {
  3467. //g_nVersion = i;
  3468. break;
  3469. }
  3470. }
  3471. return g_nVersion;
  3472. }
  3473. //----------------------------------------------------------
  3474. // 函数:IsFileExist
  3475. // 描述:判断某文件是否存在;
  3476. // 参数:
  3477. // pFileFullName: 指定的文件名;
  3478. // 返回:TRUE表示文件存在;
  3479. //----------------------------------------------------------
  3480. BOOL IsFileExist(const TCHAR *pFileFullName)
  3481. {
  3482. int err = 0;
  3483. // Check for existence.
  3484. if ((err = _taccess(pFileFullName, 0)) == 0)
  3485. {
  3486. //printf_s( "File crt_access_s.c exists.\n" );
  3487. // Check for write permission.
  3488. if ((err = _taccess(pFileFullName, 2)) == 0)
  3489. {
  3490. //printf_s( "File crt_access_s.c does have ""write permission.\n" );
  3491. }
  3492. else
  3493. {
  3494. //printf_s( "File crt_access_s.c does not have ""write permission.\n" );
  3495. }
  3496. }
  3497. else
  3498. {
  3499. //printf_s( "File crt_access_s.c does not exist.\n" );
  3500. return FALSE;
  3501. }
  3502. return TRUE;
  3503. }
  3504. inline int MultiByteLengthConvertToWideCharLength(/*LPCSTR*/LPCCH lpString)
  3505. {
  3506. return MultiByteToWideChar(CP_ACP, 0, lpString, -1, NULL, 0);
  3507. }
  3508. // Jeff.注册控件函数;2014.09.11
  3509. //----------------------------------------------------------
  3510. // 函数:RegisterOcx
  3511. // 描述:注册指定的组件文件;
  3512. // 参数:ocxfile指定要注册的组件文件名;
  3513. // 返回:TRUE表示注册成功;
  3514. //----------------------------------------------------------
  3515. BOOL RegisterOcx(LPCTSTR ocxfile)
  3516. {
  3517. HKEY hKey;
  3518. bool bRet;
  3519. USES_CONVERSION;
  3520. ITypeLib* pTypeLib;
  3521. CString CLSIDStr;
  3522. CLSID clsid;
  3523. LPOLESTR wRes = NULL;
  3524. #ifdef UNICODE
  3525. if (LoadTypeLib(ocxfile, &pTypeLib) == S_OK)
  3526. #else
  3527. if (LoadTypeLib(T2OLE(ocxfile), &pTypeLib) == S_OK)
  3528. #endif
  3529. {
  3530. TLIBATTR tlibAttr, *ptlibAttr;
  3531. ptlibAttr = &tlibAttr;
  3532. pTypeLib->GetLibAttr(&ptlibAttr);
  3533. clsid = ptlibAttr->guid;
  3534. pTypeLib->Release();
  3535. }
  3536. ::StringFromCLSID(clsid, &wRes);
  3537. CLSIDStr = OLE2CT(wRes);
  3538. if ((RegOpenKeyEx(HKEY_CLASSES_ROOT, _T("CLSID\\") + CLSIDStr, 0, KEY_READ, &hKey) == ERROR_SUCCESS) || (RegOpenKeyEx(HKEY_CLASSES_ROOT, _T("Wow6432Node\\TypeLib\\") + CLSIDStr, 0, KEY_READ, &hKey) == ERROR_SUCCESS))
  3539. {
  3540. return true;
  3541. }
  3542. else
  3543. {
  3544. HINSTANCE hLib = LoadLibrary(ocxfile);
  3545. if (hLib < (HINSTANCE)HINSTANCE_ERROR)
  3546. {
  3547. MessageBox(0, _T("权限不足,不能载入OCX文件!无法注册控件!"), _T("结果"), MB_OK);
  3548. bRet = false;
  3549. }
  3550. else
  3551. {
  3552. FARPROC lpDllEntryPoint;
  3553. lpDllEntryPoint = GetProcAddress(hLib, "DllRegisterServer");
  3554. if (lpDllEntryPoint != NULL)
  3555. {
  3556. if (FAILED((*lpDllEntryPoint)()))
  3557. {
  3558. MessageBox(0, _T("调用注册函数(DllRegisterServer)失败!无法注册控件!"), _T("结果"), MB_OK);
  3559. bRet = false;
  3560. }
  3561. else
  3562. bRet = true;
  3563. }
  3564. else
  3565. {
  3566. MessageBox(0, _T("调用注册函数(DllRegisterServer)失败!无法注册控件!"), _T("结果"), MB_OK);
  3567. bRet = false;
  3568. }
  3569. }
  3570. FreeLibrary(hLib);
  3571. return bRet;
  3572. }
  3573. }
  3574. // Jeff.Hacker. WINDOWS NT 以上的内核需要提权,才能对系统进行高级管理;
  3575. //----------------------------------------------------------
  3576. // 函数:GetDebugPriv
  3577. // 描述:对程序提权;
  3578. // 参数:
  3579. // 返回:TRUE表示程序提权成功;
  3580. //----------------------------------------------------------
  3581. BOOL GetDebugPriv()
  3582. {
  3583. // 返回的访问令牌指针;
  3584. HANDLE hToken;
  3585. // 接收所返回的制定特权名称的信息;
  3586. LUID sedebugnameValue;
  3587. // 新特权信息的指针(结构体);
  3588. TOKEN_PRIVILEGES tkp;
  3589. DWORD dwCurProcId = GetCurrentProcessId();
  3590. // 要修改访问权限的进程句柄;
  3591. HANDLE hCurProc;
  3592. hCurProc = ::OpenProcess(PROCESS_ALL_ACCESS, FALSE, dwCurProcId);
  3593. if (!::OpenProcessToken(hCurProc, TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
  3594. {
  3595. ShowSystemErrorInfo(CString("提权OpenProcessToken失败。"), GetLastError());
  3596. return FALSE;
  3597. }
  3598. if (!::LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &sedebugnameValue))
  3599. {
  3600. ShowSystemErrorInfo(CString("提权LookupPrivilegeValue失败。"), GetLastError());
  3601. CloseHandle(hToken);
  3602. return FALSE;
  3603. }
  3604. tkp.PrivilegeCount = 1;
  3605. tkp.Privileges[0].Luid = sedebugnameValue;
  3606. tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
  3607. if (!::AdjustTokenPrivileges(hToken, FALSE, &tkp, sizeof tkp, NULL, NULL))
  3608. {
  3609. ShowSystemErrorInfo(CString("提权AdjustTokenPrivileges失败。"), GetLastError());
  3610. CloseHandle(hToken);
  3611. return FALSE;
  3612. }
  3613. CloseHandle(hCurProc);
  3614. CloseHandle(hToken);
  3615. return TRUE;
  3616. }
  3617. //----------------------------------------------------------
  3618. // 函数:GetFileVersion
  3619. // 描述:获取指定模块的文件版本信息
  3620. // 参数:
  3621. // hModule: 指定的模块(如果为NULL,表示获取自身文件版本信息);
  3622. // pBuffer: 返回的文件版本信息;
  3623. //
  3624. // 返回:TRUE表示获取模块文件版本信息成功;
  3625. //----------------------------------------------------------
  3626. bool GetFileVersion(HMODULE hModule, WORD *pBuffer)
  3627. {
  3628. TCHAR fname[MAX_PATH];
  3629. VS_FIXEDFILEINFO *pVi;
  3630. DWORD dwHandle;
  3631. std::string str;
  3632. if (::GetModuleFileName(hModule, fname, MAX_PATH))
  3633. {
  3634. int size = GetFileVersionInfoSize(fname, &dwHandle);
  3635. if (size > 0)
  3636. {
  3637. BYTE *buffer = new BYTE[size];
  3638. memset(buffer, 0, size);
  3639. if (GetFileVersionInfo(fname, dwHandle, size, buffer))
  3640. {
  3641. if (VerQueryValue(buffer, _T("\\"), (LPVOID *)&pVi, (PUINT)&size))
  3642. {
  3643. pBuffer[0] = HIWORD(pVi->dwFileVersionMS);
  3644. pBuffer[1] = LOWORD(pVi->dwFileVersionMS);
  3645. pBuffer[2] = HIWORD(pVi->dwFileVersionLS);
  3646. pBuffer[3] = LOWORD(pVi->dwFileVersionLS);
  3647. delete buffer;
  3648. return true;
  3649. }
  3650. }
  3651. delete buffer;
  3652. }
  3653. }
  3654. return false;
  3655. }
  3656. //----------------------------------------------------------
  3657. // 函数:CheckInternalIP
  3658. // 描述:判断IP(网络字节序)地址是否为外网地址;
  3659. // 参数:ip_addr:主机IP(必须为网络字节序);
  3660. //
  3661. // 返回:TRUE表示主机IP为外网IP; FALSE表示内网IP;
  3662. //----------------------------------------------------------
  3663. BOOL CheckInternalIPV4(const unsigned int &ip_addr)
  3664. {
  3665. // 三段保留IP段,做为私有地址,不在在公网上使用,只作内网IP;
  3666. // A类:10.0.0.0 ~ 10.255.255.255 = 0A.00.00.00 ~ 0A.FF.FF.FF
  3667. // B类:172.16.0.0 ~ 172.31.255.255 = AC.10.00.00 ~ AC.1F.FF.FF
  3668. // C类:192.168.0.0 ~ 192.168.255.255 = C0.A8.00.00 ~ C0.A8.FF.FF
  3669. // D类:127.0.0.0 ~ 127.255.255.255 = 7F.00.00.00 ! 7F.FF.FF.FF (环回地址)
  3670. #if 0
  3671. //检查3类地址是否属于公网;
  3672. if ((ip_addr >= 0x0A000000 && ip_addr <= 0x0AFFFFFF) ||
  3673. (ip_addr >= 0xAC100000 && ip_addr <= 0xAC1FFFFF) ||
  3674. (ip_addr >= 0xC0A80000 && ip_addr <= 0xC0A8FFFF)
  3675. )
  3676. {
  3677. return FALSE;
  3678. }
  3679. return TRUE;
  3680. #endif
  3681. #if 0
  3682. //检查3类地址是否属于内网;
  3683. // 0xa -- "10.0.0.0">>24;
  3684. // 0xc0a8--"192.168.0.0.">>16;
  3685. // 0x2b0--"127.17.0.1">>22
  3686. if ((ip_addr >> 24 == 0xa) || (ip_addr >> 16 == 0xc0a8) || (ip_addr >> 22 == 0x2b0))
  3687. return FALSE;
  3688. else
  3689. return TRUE;
  3690. #endif
  3691. #if 1
  3692. // 回环地址也算进去!
  3693. if ((ip_addr >> 24 == 0x0A) || (ip_addr >> 20 == 0xAC1) || (ip_addr >> 16 == 0xC0A8) || (ip_addr >> 26 == 0x7))
  3694. return FALSE;
  3695. else
  3696. return TRUE;
  3697. #endif
  3698. }
  3699. //----------------------------------------------------------
  3700. // 函数:IsValidIPV4
  3701. // 描述:判断字符串是否是有效的IPV4;
  3702. // 参数:szIP:主机IP;
  3703. //
  3704. // 返回:TRUE表示字符串为有效的IPV4;
  3705. //----------------------------------------------------------
  3706. BOOL IsValidIPV4(const TCHAR *szIP)
  3707. {
  3708. int nIndex = 0;
  3709. int nPointCount = 0; // "."IPV4有3个;
  3710. int nLen = _tcslen(szIP);
  3711. for (int i = 0; i < nLen; i++)
  3712. {
  3713. if (szIP[i] == '.')
  3714. {
  3715. if (i == 0 || i == nLen - 1)
  3716. {
  3717. return FALSE;
  3718. }
  3719. else
  3720. {
  3721. if (++nIndex != i)
  3722. {
  3723. nIndex = i;
  3724. nPointCount++;
  3725. }
  3726. else
  3727. return FALSE;
  3728. }
  3729. continue;
  3730. }
  3731. if (isdigit(szIP[i]) == 0)
  3732. return FALSE;
  3733. }
  3734. if (nPointCount != 3)
  3735. return FALSE;
  3736. return TRUE;
  3737. }
  3738. //----------------------------------------------------------
  3739. // 函数:GetHostAllOfIP
  3740. // 描述:返回指定主机名称的所有IPV4地址;
  3741. // 参数:
  3742. // pHostName: 主机名;
  3743. // vtHostIPV4:指定主机名的所有IPV4地址;
  3744. //
  3745. // 返回:TRUE表示字符串为有效的IPV4;
  3746. //----------------------------------------------------------
  3747. int GetHostAllOfIP(const TCHAR *pHostName, std::vector<std::string> &vtHostIPV4)
  3748. {
  3749. #if 0
  3750. WSADATA wsa = { 0 };
  3751. WSAStartup(MAKEWORD(2, 2), &wsa);
  3752. #endif
  3753. #if 0 // YLGL项目使用不了,因为包含了旧的系统头文件;
  3754. addrinfo hint, *answer, *curr;
  3755. memset(&hint, 0, sizeof(addrinfo));
  3756. hint.ai_family = AF_INET;
  3757. hint.ai_socktype = SOCK_STREAM;
  3758. int nRet = GetAddrInfo(pHostName, NULL, &hint, &answer);
  3759. //int nRet = GetAddrInfo(pHostName, "5678", &hint, &answer);
  3760. if (nRet != 0)
  3761. {
  3762. DWORD dwError = GetLastError();
  3763. return;
  3764. }
  3765. TCHAR szIP[MAX_PATH];
  3766. for (curr = answer; curr != NULL; curr = curr->ai_next)
  3767. {
  3768. //std::string ipstr;
  3769. memset(szIP, 0, MAX_PATH);
  3770. inet_ntop(AF_INET, &(((sockaddr_in*)(curr->ai_addr))->sin_addr), szIP, MAX_PATH);
  3771. vtHostIPV4.push_back(szIP);
  3772. }
  3773. freeaddrinfo(answer);
  3774. #endif
  3775. return 0;
  3776. }
  3777. WCHAR* GetIPbyHostName(LPCCH lpHostname)
  3778. {
  3779. #if 0
  3780. addrinfo *ailist, *aip;
  3781. addrinfo hint;
  3782. sockaddr_in *sinp;
  3783. //char *hostname = "luoyedeshan"; /* 这是我的用户名 */
  3784. CHAR buf[INET_ADDRSTRLEN];
  3785. //char *server = "3294"; /* 这是服务端口号 */
  3786. CONST CHAR *pIPAddr = NULL;
  3787. int ilRc;
  3788. hint.ai_family = AF_INET; /* hint 的限定设置 */
  3789. hint.ai_socktype = 0; /* 这里可是设置 socket type . 比如 SOCK——DGRAM */
  3790. hint.ai_flags = AI_PASSIVE; /* flags 的标志很多 。常用的有AI_CANONNAME; */
  3791. hint.ai_protocol = 0; /* 设置协议 一般为0,默认 */
  3792. hint.ai_addrlen = 0; /* 下面不可以设置,为0,或者为NULL */
  3793. hint.ai_canonname = NULL;
  3794. hint.ai_addr = NULL;
  3795. hint.ai_next = NULL;
  3796. ilRc = getaddrinfo(lpHostname, NULL/*server*/, &hint, &ailist);
  3797. if (ilRc != 0)
  3798. {
  3799. CHAR str_error[100];
  3800. strcpy_s(str_error, gai_strerrorA(errno));
  3801. printf("str_error = %s", str_error);
  3802. return NULL;
  3803. }
  3804. for (aip = ailist; aip != NULL; aip = aip->ai_next) /* 显示获取的信息 */
  3805. {
  3806. sinp = (sockaddr_in *)aip->ai_addr; /* 为什么是for 循环 ,先向下看 */
  3807. pIPAddr = inet_ntop(AF_INET, &sinp->sin_addr, buf, INET_ADDRSTRLEN);
  3808. // printf(" addr = %s", pIPAddr ? pIPAddr : "unknow ");
  3809. // printf("port = %d ", ntohs(sinp->sin_port));
  3810. // printf(" \n");
  3811. }
  3812. int nwlen = MultiByteToWideChar(CP_ACP, 0, pIPAddr, -1, NULL, 0);
  3813. WCHAR *ptIP = new WCHAR[nwlen];
  3814. MultiByteToWideChar(CP_ACP, 0, pIPAddr, -1, ptIP, nwlen);
  3815. return ptIP;
  3816. #endif
  3817. return _T("");
  3818. }
  3819. int IsExistFolder(CONST TCHAR *szPath)//可判断文件夹和文件的存在;
  3820. {
  3821. if ((_taccess(szPath, 0)) != -1)
  3822. {
  3823. //printf("Jeff:File %s \t exists \n",szPath );
  3824. /* Check for write permission */
  3825. if ((_taccess(szPath, 2)) != -1)
  3826. {
  3827. //printf("Jeff:File %s \t has write permission \n",szPath );
  3828. CString str;
  3829. str.Format(_T("共享文件夹<%s>: 存在!\n"), szPath);
  3830. WriteClientLog(str);
  3831. return 1;
  3832. }
  3833. // else // 只能判断文件权限,不能判断目录;
  3834. // {
  3835. // CString str;
  3836. // str.Format("共享文件夹<%s>:\t存在,不可写!■■■■■■■\n",szPath);
  3837. // WriteClientLog(str);
  3838. //
  3839. // return 0;
  3840. // }
  3841. }
  3842. else
  3843. {
  3844. //printf("Jeff:\t File %s no exists \n",szPath );
  3845. CString str;
  3846. str.Format(_T("◆共享文件夹<%s>: 不存在,请设置共享或访问权限!◆\n"), szPath);
  3847. WriteClientLog(str);
  3848. return -1;
  3849. }
  3850. return 0;
  3851. }
  3852. //---------------------------------------------------------------------
  3853. // add by Jeff 2014.10.24
  3854. // 函数:全局函数lyfzCopyFileEx
  3855. // 描述:文件复制。
  3856. // 参数:
  3857. // lpExistingFileName:你要拷贝的源文件名;
  3858. // lpNewFileName: 你要拷贝的目标文件名;
  3859. // bFailIfExists: 如果目标已经存在,不拷贝(True)并重命名,覆盖目标(false)
  3860. // 返回:与CopyFile返回一致;
  3861. //---------------------------------------------------------------------
  3862. BOOL lyfzCopyFileEx(LPCTSTR lpExistingFileName, LPCTSTR lpNewFileName, const BOOL &bFailIfExists)
  3863. {
  3864. // 1.如果是覆盖选项;
  3865. if (!bFailIfExists)
  3866. return CopyFile(lpExistingFileName, lpNewFileName, bFailIfExists);
  3867. // 2.如果不是覆盖选项;
  3868. TCHAR szNewFileName[_MAX_PATH] = { 0 };
  3869. TCHAR szDrive[_MAX_DRIVE] = { 0 };
  3870. TCHAR szDir[_MAX_DIR] = { 0 };
  3871. TCHAR szFna[_MAX_FNAME] = { 0 };
  3872. TCHAR szExt[_MAX_EXT] = { 0 };
  3873. _stprintf_s(szNewFileName, _T("%s"), lpNewFileName);
  3874. _tsplitpath_s(szNewFileName, szDrive, szDir, szFna, szExt);
  3875. int nIndex = 1;
  3876. while (PathFileExists(szNewFileName))
  3877. {
  3878. _stprintf_s(szNewFileName, _T("%s%s%s (%d)%s"), szDrive, szDir, szFna, nIndex++, szExt);
  3879. }
  3880. return CopyFile(lpExistingFileName, szNewFileName, bFailIfExists);
  3881. }
  3882. //---------------------------------------------------------------------
  3883. // add by Jeff 2014.10.24
  3884. // 函数:全局函数lyfzImportImage,多字节版本,非UNICODE
  3885. // 描述:导入图片。
  3886. // 参数:
  3887. // lpDestDirectory: 文件导入的目标目录;
  3888. // strArrayOfImage: 要导入的图片文件数组;
  3889. // bFailIfExists: 如果目标已经存在,不拷贝(True)并重命名,覆盖目标(false)
  3890. // 返回:
  3891. //
  3892. // 说明:在调用lyfzImportImage前,需要对传递的参数进行有效性验证
  3893. // 1.验证形参lpDestDirectory对应的实参是否是有效的目录(有无创建目录的非法字符存在)
  3894. // 2.验证形参strArrayOfImage对应的实参数组是否大于0;
  3895. // 如果校验没有通过,应该拒绝调lyfzImportImage,以防止错误产生。
  3896. //---------------------------------------------------------------------
  3897. void lyfzImportImage(LPCTSTR lpDestDirectory, CStringArray &strArrayOfImage, const BOOL &bFailIfExists)
  3898. {
  3899. // 传递给lyfzCreateDirectory的参数规范化;
  3900. int nlen = _tcslen(lpDestDirectory);
  3901. TCHAR szNewFileName[_MAX_PATH] = { 0 };
  3902. TCHAR szTempDirectory[_MAX_PATH] = { 0 };
  3903. if (lpDestDirectory[nlen - 1] != '\\')
  3904. _stprintf_s(szTempDirectory, _T("%s\\"), lpDestDirectory);
  3905. else
  3906. _stprintf_s(szTempDirectory, _T("%s"), lpDestDirectory);
  3907. // 若目录或子目录不存在创建;
  3908. lyfzCreateDirectory(szTempDirectory);
  3909. // 遍历复制;
  3910. CString strImage;
  3911. INT_PTR nSize = strArrayOfImage.GetSize();
  3912. for (INT_PTR i = 0; i < nSize; i++)
  3913. {
  3914. strImage = strArrayOfImage.ElementAt(i);
  3915. strImage = strImage.Mid(strImage.ReverseFind('\\') + 1);
  3916. //strImage = strImage.Left(strImage.ReverseFind('.'));
  3917. _stprintf_s(szNewFileName, _T("%s%s"), szTempDirectory, strImage);
  3918. lyfzCopyFileEx(szNewFileName, strArrayOfImage.ElementAt(i), bFailIfExists);
  3919. }
  3920. }
  3921. //---------------------------------------------------------------------
  3922. // add by Jeff 2014.10.25
  3923. // 函数:全局函数lyfzCreateDirectory,多字节版本,非UNICODE
  3924. // 描述:创建目录及子目录文件夹;
  3925. // 参数:
  3926. // lpDestDirectory:目录,必须是"E:\lyfzdb\数据\"格式,目录最后必须有"\",否则最后一个子目录无法创建!
  3927. // 建议使用系统_tsplitpath来分隔目录,这样会保存最后一个"\"斜杠;
  3928. // 返回:成功创建返回TRUE;
  3929. //---------------------------------------------------------------------
  3930. BOOL lyfzCreateDirectory(LPCTSTR lpDestDirectory)
  3931. {
  3932. BOOL bExists = FALSE;
  3933. TCHAR szNewFileName[_MAX_PATH] = { 0 };
  3934. TCHAR szDrive[_MAX_DRIVE] = { 0 };
  3935. TCHAR szDir[_MAX_DIR] = { 0 };
  3936. TCHAR szFna[_MAX_FNAME] = { 0 };
  3937. TCHAR szExt[_MAX_EXT] = { 0 };
  3938. int nIndex = 0;
  3939. do
  3940. {
  3941. bExists = PathFileExists(lpDestDirectory);
  3942. if (!bExists)
  3943. {
  3944. memset(szDrive, 0, _MAX_DRIVE);
  3945. memset(szDir, 0, _MAX_DIR);
  3946. memset(szFna, 0, _MAX_FNAME);
  3947. memset(szExt, 0, _MAX_EXT);
  3948. lyfzSplitpath(lpDestDirectory, szDrive, szDir, ++nIndex);
  3949. _stprintf_s(szNewFileName, _T("%s%s"), szDrive, szDir);
  3950. CreateDirectory(szNewFileName, NULL);
  3951. //if (FALSE == CreateDirectory(szNewFileName, NULL))
  3952. //{
  3953. //ShowSystemErrorInfo(CString("创建目录出错。"), GetLastError());
  3954. //return FALSE;
  3955. // continue;
  3956. //}
  3957. }
  3958. } while (!bExists);
  3959. return TRUE;
  3960. }
  3961. //---------------------------------------------------------------------
  3962. // add by Jeff 2014.10.24
  3963. // 函数:全局函数tSplitpath,多字节版本,非UNICODE
  3964. // 描述:类系统Windows C++运行库函数_tsplitpath。
  3965. // 参数:
  3966. //
  3967. // 返回:
  3968. //---------------------------------------------------------------------
  3969. void lyfzSplitpath(const TCHAR *path, TCHAR *drive, TCHAR *dir, const int &nTimes)
  3970. {
  3971. int nlen = _tcslen(path);
  3972. int i = 0;
  3973. int npoint = 0; // '.'
  3974. int nsprit = 0; // '\\'
  3975. int ncolon = 0; // ':'
  3976. int ntimes = -1;
  3977. while (nlen > i++)
  3978. {
  3979. if (path[i] == ':')
  3980. ncolon = i;
  3981. else if (path[i] == '\\')
  3982. {
  3983. if (nTimes == ntimes++) break;
  3984. nsprit = i;
  3985. }
  3986. }
  3987. memcpy(drive, path, ncolon + 1);
  3988. memcpy(dir, &path[ncolon + 1], nsprit - ncolon);
  3989. }
  3990. //---------------------------------------------------------------------
  3991. // Jeff add 2014.06.23;
  3992. // 函数:ShowErrorInfo
  3993. // 描述:
  3994. // 参数:
  3995. // lpszFunction:函数名;
  3996. // dwError:错误码;
  3997. // 返回:
  3998. //---------------------------------------------------------------------
  3999. void ShowSystemErrorInfo(CString &strDescription, const DWORD &dwError)
  4000. {
  4001. LPVOID lpMsgBuf;
  4002. BOOL fOk = FormatMessage(
  4003. FORMAT_MESSAGE_ALLOCATE_BUFFER |
  4004. FORMAT_MESSAGE_FROM_SYSTEM |
  4005. FORMAT_MESSAGE_IGNORE_INSERTS,
  4006. NULL,
  4007. dwError,
  4008. MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
  4009. (LPTSTR)&lpMsgBuf,
  4010. 0, NULL);
  4011. if (!fOk)
  4012. {
  4013. // Is it a network-related error?
  4014. HMODULE hDll = LoadLibraryEx(TEXT("netmsg.dll"), NULL, DONT_RESOLVE_DLL_REFERENCES);
  4015. if (hDll != NULL)
  4016. {
  4017. FormatMessage(
  4018. FORMAT_MESSAGE_FROM_HMODULE |
  4019. FORMAT_MESSAGE_FROM_SYSTEM |
  4020. FORMAT_MESSAGE_IGNORE_INSERTS,
  4021. hDll,
  4022. dwError,
  4023. MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US),
  4024. (LPTSTR)&lpMsgBuf,
  4025. 0,
  4026. NULL);
  4027. FreeLibrary(hDll);
  4028. }
  4029. }
  4030. if (lpMsgBuf != NULL)
  4031. {
  4032. CString strDisplay;
  4033. strDisplay.Format(_T("%s.错误码=%d,Windows描述:%s"), strDescription, dwError, (PCTSTR)LocalLock(lpMsgBuf));
  4034. //WriteLogin(strDisplay);
  4035. AfxMessageBox(strDisplay);
  4036. LocalFree(lpMsgBuf);
  4037. }
  4038. else
  4039. {
  4040. //WriteLogin(strDescription);
  4041. AfxMessageBox(_T("未知道错误"));
  4042. }
  4043. }
  4044. CString GetLastErrorInfo(CONST DWORD &dwError)
  4045. {
  4046. LPVOID lpMsgBuf;
  4047. BOOL fOk = FormatMessage(
  4048. FORMAT_MESSAGE_ALLOCATE_BUFFER |
  4049. FORMAT_MESSAGE_FROM_SYSTEM |
  4050. FORMAT_MESSAGE_IGNORE_INSERTS,
  4051. NULL,
  4052. dwError,
  4053. MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
  4054. (LPTSTR)&lpMsgBuf,
  4055. 0, NULL);
  4056. if (!fOk)
  4057. {
  4058. // Is it a network-related error?
  4059. HMODULE hDll = LoadLibraryEx(TEXT("netmsg.dll"), NULL, DONT_RESOLVE_DLL_REFERENCES);
  4060. if (hDll != NULL)
  4061. {
  4062. FormatMessage(
  4063. FORMAT_MESSAGE_FROM_HMODULE |
  4064. FORMAT_MESSAGE_FROM_SYSTEM |
  4065. FORMAT_MESSAGE_IGNORE_INSERTS,
  4066. hDll,
  4067. dwError,
  4068. MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US),
  4069. (LPTSTR)&lpMsgBuf,
  4070. 0,
  4071. NULL);
  4072. FreeLibrary(hDll);
  4073. }
  4074. }
  4075. CString strErrorInfo = _T("");
  4076. if (lpMsgBuf != NULL)
  4077. {
  4078. strErrorInfo.Format(_T("错误码=%d,Windows描述:%s"), dwError, (PCTSTR)LocalLock(lpMsgBuf));
  4079. LocalFree(lpMsgBuf);
  4080. }
  4081. else
  4082. {
  4083. strErrorInfo = _T("未知道错误");
  4084. }
  4085. return strErrorInfo;
  4086. }
  4087. //---------------------------------------------------------------------
  4088. // Jeff add 2014.06.23;
  4089. // 函数:WriteClientLog
  4090. // 描述:写客户端程序日志。
  4091. // 参数:
  4092. // str:日志内容;
  4093. // 返回:
  4094. // 非线程安全!而且写速度超慢,会造成死等现象!在线程运行速度极快的情况下,死等!
  4095. //---------------------------------------------------------------------
  4096. void WriteClientLog(const CString &strLogContent)
  4097. {
  4098. try
  4099. {
  4100. CStdioFile fp;
  4101. //CString path = g_mainpath + _T("\\新短信日志.txt");
  4102. CString path;
  4103. path.Format(_T("%sSMS短信日志.txt"),g_szModulePath);
  4104. if (PathFileExists(path))
  4105. {
  4106. if (fp.Open(path, CFile::modeWrite) == FALSE)
  4107. {
  4108. return;
  4109. }
  4110. ULONGLONG length = fp.GetLength();
  4111. if (length > 1 * 1024 * 1024)
  4112. {
  4113. fp.Close();
  4114. ::DeleteFile(path);
  4115. return;
  4116. }
  4117. fp.SeekToEnd();
  4118. }
  4119. else
  4120. fp.Open(path, CFile::modeCreate | CFile::modeWrite);
  4121. char* old_locale = _strdup(setlocale(LC_CTYPE, NULL));
  4122. setlocale(LC_CTYPE, "chs");//设定
  4123. // WriteString在UNICODE下无法写中文,需要setlocale语言区域;
  4124. fp.WriteString((CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S")) + _T(" ") + strLogContent + _T("\n")));
  4125. setlocale(LC_CTYPE, old_locale);
  4126. free(old_locale);//还原区域设定
  4127. fp.Close();
  4128. }
  4129. catch (CException *e)
  4130. {
  4131. e->ReportError();
  4132. e->Delete();
  4133. }
  4134. }
  4135. //---------------------------------------------------------------------
  4136. // add by Jeff 2014.10.27
  4137. // 函数:全局函数IsDirectoryLegitimate,多字节版本,非UNICODE
  4138. // 描述:判断一个目录路径字符串,是否属于合法的、可创建的目录路径。
  4139. // 参数:strDirectory 被验证的路径字符串;
  4140. //
  4141. // 返回:合法路径返回TRUE;
  4142. //---------------------------------------------------------------------
  4143. BOOL IsDirectoryLegitimate(const CString &strDirectory)
  4144. {
  4145. if (strDirectory.Find('/') != -1 ||
  4146. strDirectory.Find('\\') != -1 ||
  4147. strDirectory.Find(':') != -1 ||
  4148. strDirectory.Find('*') != -1 ||
  4149. strDirectory.Find('?') != -1 ||
  4150. strDirectory.Find('\"') != -1 ||
  4151. strDirectory.Find('>') != -1 ||
  4152. strDirectory.Find('<') != -1 ||
  4153. strDirectory.Find('|') != -1
  4154. )
  4155. return FALSE;
  4156. return TRUE;
  4157. }
  4158. //----------------------------------------------------------------------
  4159. // remark by Jeff 2014.11.08
  4160. // 函数:ExportCutImageToFile
  4161. // 描述:导出裁剪图片到指定目录;
  4162. // 参数:
  4163. // lpOrderCutImageInfo:订单号的裁剪相片信息;
  4164. // lpSrcDirectory:原图片路径;
  4165. // lpOrderCutImageInfo格式:相片名|裁剪方案|原片宽|原片高|裁剪left|裁剪top|裁剪bottom|裁剪rigth
  4166. // 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;
  4167. // lpSaveDirectory:导出相片的保存路径;
  4168. // 返回:无
  4169. //----------------------------------------------------------------------
  4170. void ExportCutImageToFile(LPCTSTR lpOrderCutImageInfo, LPCTSTR lpSrcDirectory, LPCTSTR lpSaveDirectory)
  4171. {
  4172. if (FALSE == lyfzCreateDirectory(lpSaveDirectory))
  4173. return;
  4174. CStringArray saSrcPhoto;
  4175. GetCountOfOrderFolderPhotoFile(lpSrcDirectory, saSrcPhoto);
  4176. CString strImageName; // 相片名;
  4177. CString strCutScheme; // 裁剪方案;
  4178. CRect rtCut; // 要裁剪的区域;
  4179. CString strTemp;
  4180. CString strImageInfo(lpOrderCutImageInfo);
  4181. int nIndex = -1;
  4182. do
  4183. {
  4184. // 225:5X7,1440,900,88,0,1352,900;
  4185. nIndex = strImageInfo.Find(';');
  4186. strTemp = strImageInfo.Left(nIndex);
  4187. strImageInfo = strImageInfo.Mid(nIndex + 1);
  4188. int SrcImageWid;
  4189. int SrcImageHei;
  4190. int ntempIndex = -1;
  4191. if (nIndex != -1)
  4192. {
  4193. if (FALSE == AnalysisImagInfo(saSrcPhoto, lpSrcDirectory, lpSaveDirectory, strTemp, strImageName, strCutScheme, rtCut))
  4194. continue;
  4195. }
  4196. else
  4197. {
  4198. if (strImageInfo.IsEmpty())
  4199. break;
  4200. AnalysisImagInfo(saSrcPhoto, lpSrcDirectory, lpSaveDirectory, strImageInfo, strImageName, strCutScheme, rtCut);
  4201. break;
  4202. }
  4203. } while (nIndex != -1);
  4204. }
  4205. //----------------------------------------------------------------------
  4206. // remark by Jeff 2014.11.08
  4207. // 函数:AnalysisImagInfo
  4208. // 描述:导出裁剪图片到指定目录;
  4209. // 参数:
  4210. // lpOrderCutImageInfo:订单号的裁剪相片信息;
  4211. // lpSrcDirectory:原图片路径;
  4212. // lpOrderCutImageInfo格式:相片名|裁剪方案|原片宽|原片高|裁剪left|裁剪top|裁剪bottom|裁剪rigth
  4213. // 225:5X7,1440,900,88,0,1352,900;
  4214. // lpSaveDirectory:导出相片的保存路径;
  4215. // 返回:无
  4216. //
  4217. // 说明:未对图片进行缩小,直接在原片上裁剪而得。
  4218. //----------------------------------------------------------------------
  4219. BOOL AnalysisImagInfo(CStringArray &saSrcPhoto, LPCTSTR lpSrcDirectory, LPCTSTR lpSaveDirectory, CString &strImageInfo, CString &strImageName, CString &strCutScheme, CRect &rtCut)
  4220. {
  4221. int ntempIndex = -1;
  4222. strImageName = strImageInfo.Left(3); // 裁剪相片名;
  4223. strImageInfo.Delete(0, 4);
  4224. CString strSrcImagePath;
  4225. BOOL bExist = FALSE;
  4226. for (int i = 0; i < saSrcPhoto.GetSize(); i++)
  4227. {
  4228. CString strTemp = saSrcPhoto.ElementAt(i);
  4229. strSrcImagePath = strTemp;
  4230. TCHAR szDrive[_MAX_DRIVE] = { 0 };
  4231. TCHAR szDir[_MAX_DIR] = { 0 };
  4232. TCHAR szFna[_MAX_DIR] = { 0 };
  4233. TCHAR szExt[_MAX_DIR] = { 0 };
  4234. //_tsplitpath_s((LPTSTR)saSrcPhoto.ElementAt(i), szDrive, szDir, (LPTSTR)strTemp, szExt);
  4235. //strTemp.ReleaseBuffer();
  4236. _tsplitpath_s(szDrive, szDrive, szDir, szFna, szExt);
  4237. if (strTemp == strImageName)
  4238. {
  4239. bExist = TRUE;
  4240. //saSrcPhoto.RemoveAt(i);
  4241. break;
  4242. }
  4243. }
  4244. if (FALSE == bExist)
  4245. return FALSE;
  4246. ntempIndex = strImageInfo.Find(',');
  4247. strCutScheme = strImageInfo.Left(ntempIndex); // 裁剪方案;
  4248. strImageInfo.Delete(0, ntempIndex + 1);
  4249. // 裁剪原图宽;
  4250. ntempIndex = strImageInfo.Find(',');
  4251. LONG SrcImageWid = _ttol(strImageInfo.Left(ntempIndex));
  4252. strImageInfo.Delete(0, ntempIndex + 1);
  4253. // 裁剪原图高;
  4254. ntempIndex = strImageInfo.Find(',');
  4255. LONG SrcImageHei = _ttol(strImageInfo.Left(ntempIndex));
  4256. strImageInfo.Delete(0, ntempIndex + 1);
  4257. // left坐标值;
  4258. ntempIndex = strImageInfo.Find(',');
  4259. rtCut.left = _ttol(strImageInfo.Left(ntempIndex));
  4260. strImageInfo.Delete(0, ntempIndex + 1);
  4261. // top坐标;
  4262. ntempIndex = strImageInfo.Find(',');
  4263. rtCut.top = _ttol(strImageInfo.Left(ntempIndex));
  4264. strImageInfo.Delete(0, ntempIndex + 1);
  4265. // right坐标;
  4266. ntempIndex = strImageInfo.Find(',');
  4267. rtCut.right = _ttol(strImageInfo.Left(ntempIndex));
  4268. strImageInfo.Delete(0, ntempIndex + 1);
  4269. // bottom坐标;
  4270. rtCut.bottom = _ttol(strImageInfo.Left(ntempIndex));
  4271. // 导出裁剪相片到指定目录;
  4272. // 1.加载原图;
  4273. Image *SrcImage = NULL;
  4274. //if (FALSE == PathFileExists(CString(lpSrcDirectory + strImageName + _T(".jpg"))))
  4275. if (FALSE == PathFileExists(strSrcImagePath))
  4276. {
  4277. AfxMessageBox(_T("相片源文件不存在"));
  4278. return FALSE;
  4279. }
  4280. //LoadImageFromBuf(&SrcImage, CString(lpSrcDirectory + strImageName + _T(".jpg")));
  4281. LoadImageFromBuf(&SrcImage, strSrcImagePath);
  4282. if (SrcImage == NULL)
  4283. {
  4284. AfxMessageBox(_T("加载源图片失败"));
  4285. return FALSE;
  4286. }
  4287. int orientation = GetOrientation(SrcImage);
  4288. if (orientation == 8)
  4289. SrcImage->RotateFlip(Rotate270FlipNone);
  4290. else if (orientation == 6)
  4291. SrcImage->RotateFlip(Rotate90FlipNone);
  4292. if (SrcImage->GetWidth() == 0)
  4293. return FALSE;
  4294. float scale = 1.0;
  4295. scale *= (float)SrcImage->GetWidth() / (float)SrcImageWid;
  4296. rtCut.left *= scale;
  4297. rtCut.right *= scale;
  4298. rtCut.top *= scale;
  4299. rtCut.bottom *= scale;
  4300. #if 0 // 保存在原图上画裁剪区域;
  4301. Graphics graph(SrcImage);
  4302. Pen blackPen(Color(255, 255, 0, 0), 1);
  4303. graph.DrawRectangle(&blackPen, rtCut.left, rtCut.top, rtCut.Width(), rtCut.Height());
  4304. SaveImageToFile(SrcImage, CString(lpSaveDirectory + strImageName + _T(".jpg")));
  4305. delete SrcImage;
  4306. #else // 直接保存裁剪后的图片;
  4307. Bitmap bp(rtCut.Width(), rtCut.Height());
  4308. Graphics *graphic = Graphics::FromImage(&bp);
  4309. graphic->Clear(Color(255, 255, 255, 255));
  4310. graphic->SetInterpolationMode(InterpolationModeHighQualityBicubic);
  4311. graphic->SetSmoothingMode(SmoothingModeHighQuality);//SmoothingModeHighSpeed
  4312. graphic->SetPixelOffsetMode(PixelOffsetModeHighQuality);
  4313. graphic->SetCompositingMode(CompositingModeSourceOver);
  4314. graphic->SetCompositingQuality(CompositingQualityHighQuality);
  4315. graphic->SetTextRenderingHint(TextRenderingHintAntiAliasGridFit);
  4316. graphic->DrawImage(SrcImage, RectF(0, 0, rtCut.Width(), rtCut.Height()), rtCut.left, rtCut.top, rtCut.Width(), rtCut.Height(), UnitPixel);
  4317. delete SrcImage;
  4318. //delete graphic;
  4319. //CString strSave;
  4320. //strSave.Format("%s%s:%s.jpg", lpSaveDirectory,strImageName,strCutScheme);
  4321. //SaveImageToFile(&bp, strSave);
  4322. SaveImageToFile(&bp, CString(lpSaveDirectory + strImageName + _T(":") + strCutScheme + _T(".jpg")));
  4323. #endif
  4324. return TRUE;
  4325. }
  4326. // 相片后缀:jpg、raw、cr2、NEF 四种常用后缀
  4327. //--------------------------------------------------------------------------------
  4328. // Remark by Jeff 2014.11.10
  4329. // 函数:GetCountOfOrderFolderPhotoFile
  4330. // 描述:获取订单文件夹下所有相片文件,不含"m"和"s"开头的小图;
  4331. // 参数:pOrderFolder:订单文件路径;
  4332. // 返回:
  4333. //
  4334. //--------------------------------------------------------------------------------
  4335. int GetCountOfOrderFolderPhotoFile(__in const TCHAR *pOrderFolder, __out CStringArray &StrPhotoArray)
  4336. {
  4337. CStringArray StrSubFoloderArray;
  4338. using namespace helper_coffs;
  4339. ffsco o;
  4340. o.dirs(1); // Jeff.1:查找子目录;
  4341. o.find(LPCTSTR(pOrderFolder), LPCTSTR(_T("*.*"))); // 可能存在m和s开头的缩略图,需要过滤掉;
  4342. if (o.count() == 0)
  4343. return 0;
  4344. // 获取子目录数;
  4345. ffsco::typeT coo;
  4346. ffsco::typeT::iterator it;
  4347. coo = o.co_dir();
  4348. for (it = coo.begin(); it != coo.end(); it++)
  4349. {
  4350. if (FindArray(&StrSubFoloderArray, (*it).c_str()) == -1)
  4351. StrSubFoloderArray.Add((*it).c_str());
  4352. }
  4353. int nIndex = -1;
  4354. CString strOrderNumberImage;
  4355. // 获取子目录下的文件数;
  4356. //CStringArray StrPhotoArray;
  4357. for (int n = 0; n < StrSubFoloderArray.GetSize(); n++)
  4358. {
  4359. ffsco op;
  4360. op.dirs(0);
  4361. op.find(LPCTSTR(StrSubFoloderArray.ElementAt(n)), LPCTSTR(_T("*.jpg")));
  4362. ffsco::typeT coo;
  4363. ffsco::typeT::iterator itp;
  4364. coo = op.co_file();
  4365. for (itp = coo.begin(); itp != coo.end(); itp++)
  4366. {
  4367. strOrderNumberImage = (*itp).c_str();
  4368. nIndex = strOrderNumberImage.ReverseFind('\\');
  4369. strOrderNumberImage = strOrderNumberImage.Right(strOrderNumberImage.GetLength() - nIndex - 1);
  4370. if (strOrderNumberImage.Left(1) != _T("m") && strOrderNumberImage.Left(1) != _T("s"))
  4371. {
  4372. StrPhotoArray.Add((*itp).c_str());
  4373. }
  4374. }
  4375. }
  4376. return 0;
  4377. }
  4378. //------------------------------------------------------------------------
  4379. // Remark by Jeff;2014-09-21
  4380. // 函数:GetCount
  4381. // 描述:获取指定短信内容的字符数(不是字节数);
  4382. // 参数:content 短信内容;
  4383. // 返回:短信内容字符数;
  4384. //
  4385. //------------------------------------------------------------------------
  4386. #define MSG_LENGTH 64
  4387. int GetTextMsgCount(CONST CString &strContent)
  4388. {
  4389. int nNumberOfTextMsg = 0;
  4390. #ifdef UNICODE
  4391. int nWCharLen = strContent.GetLength();
  4392. #else
  4393. int nWCharLen = MultiByteToWideChar(CP_ACP, 0, strContent, -1, NULL, 0); // Jeff.无论constent是否空,MultiByteToWideChar返回结果都>=1;
  4394. #endif
  4395. // 魔数MSG_LENGTH = 67:
  4396. // 当短信字符数超过70时,短信服务商会分为两部分;
  4397. // 1.将前67个字符为一条短信;
  4398. // 2.将67后的为另一部分,若仍大于70,再次执行1;
  4399. // 3.若短信小于等于70,则为一条短信;
  4400. nNumberOfTextMsg = nWCharLen / MSG_LENGTH;
  4401. if (nNumberOfTextMsg == 0)
  4402. return 1;
  4403. if (nWCharLen % MSG_LENGTH > 2)
  4404. ++nNumberOfTextMsg;
  4405. return nNumberOfTextMsg;
  4406. }
  4407. // Jeff.将宽字节转为多字节;
  4408. CHAR *UnicodeToGB2312(LPCWCH lpWideCharStr)
  4409. {
  4410. int cchWideChar = WideCharToMultiByte(CP_ACP, 0, lpWideCharStr, -1, NULL, 0, NULL, NULL);
  4411. CHAR *pMultiByteStr = new CHAR[cchWideChar + 1];
  4412. WideCharToMultiByte(CP_ACP, 0, lpWideCharStr, -1, pMultiByteStr, cchWideChar, NULL, NULL);
  4413. return pMultiByteStr;
  4414. }
  4415. //增加自动启动注册表项
  4416. INT AddAutoSysRun(LPBYTE lpExeFile,CONST DWORD &cbExeFile, LPCTSTR lpKeyName, INT iAutoRunSystem)
  4417. {
  4418. HKEY hKey = NULL;
  4419. DWORD dwErrorCode = 0;
  4420. //创建注册表,有该键则读取,无则创建
  4421. dwErrorCode = RegCreateKeyEx(HKEY_LOCAL_MACHINE,
  4422. _T("Software\\Microsoft\\Windows\\CurrentVersion\\Run"),
  4423. 0,
  4424. NULL,
  4425. REG_OPTION_NON_VOLATILE,
  4426. KEY_ALL_ACCESS, //
  4427. //KEY_READ,
  4428. NULL, //Security
  4429. &hKey,
  4430. NULL);
  4431. if (dwErrorCode == ERROR_SUCCESS)
  4432. {
  4433. if (iAutoRunSystem)
  4434. {
  4435. dwErrorCode = RegSetValueEx(hKey, lpKeyName, NULL, REG_SZ, lpExeFile, cbExeFile);
  4436. }
  4437. else
  4438. {
  4439. dwErrorCode = RegDeleteValue(hKey, lpKeyName);
  4440. dwErrorCode = RegDeleteKey(hKey, lpKeyName);
  4441. }
  4442. }
  4443. if (NULL != hKey)
  4444. RegCloseKey(hKey);
  4445. hKey = NULL;
  4446. return 0;
  4447. }
  4448. #endif