1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578 |
- #include "CHttpBll.h"
- #include <QCryptographicHash>
- #include <QTextCodec>
- #include "logproc.h"
- std::shared_ptr<CHttpBll> g_httpBllPtr = nullptr;
- CHttpBll::CHttpBll()
- {
- sKey = "";
- sToken = "";
- }
- QString CHttpBll::getAuthorization(QString sUri, QString sTimeStamp)
- {
- if(sToken != "")
- {
- QString sAuthorization = "post&" +
- sUri + "&" + sTimeStamp + "&" + sToken;
- QByteArray sha1 = QCryptographicHash::hash(sAuthorization.toLatin1(), QCryptographicHash::Sha1);
- QByteArray shaResult = sha1;
- sAuthorization = "Token " + sKey + ":" + shaResult.toBase64().data();
- return sAuthorization;
- // return sAccessToken;
- }
- return "";
- }
- QString CHttpBll::getToken()
- {
- return sToken;
- }
- QString CHttpBll::getKey()
- {
- return sKey;
- }
- void CHttpBll::requestProc(CHttpRequestPackage requestPkg)
- {
-
- // QString sTimeStamp = QString::number(g_AppInfo->timestamp());
- // requestPkg.sHeadList.push_back(QString::fromLocal8Bit("platform,%1").arg("WEB"));
- // requestPkg.sHeadList.push_back(QString::fromLocal8Bit("deviceId,%1").arg(g_AppInfo->sMachineId));
- // requestPkg.sHeadList.push_back(QString::fromLocal8Bit("time,%1").arg(sTimeStamp));
- requestPkg.sHeadList.push_back(QString::fromLocal8Bit("Referer,%1").arg(requestPkg.sUri));
- requestPkg.sHeadList.push_back(QString::fromLocal8Bit("User-Agent,%1").arg("Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) electron-exam-shell/1.9.1 Chrome/58.0.3029.110 Electron/1.7.16 Safari/537.36"));
- if(sToken != "")
- {
- requestPkg.sHeadList.push_back(QString::fromLocal8Bit("key,%1").arg(sKey));
- requestPkg.sHeadList.push_back(QString::fromLocal8Bit("token,%1").arg(sToken));
- // requestPkg.sHeadList.push_back(QString::fromLocal8Bit("Authorization,%1").arg(getAuthorization(requestPkg.sUri, sTimeStamp)));
- }
- __int64 nStartTime = g_appInfoPtr->serverMTime();
- initHeads(requestPkg);
- QString sErrorMsg = "";
- std::string sResponse = "";
- int nCode = 0;
- if (requestPkg.nHttpType == HttpType::htDownload)
- {
- requestPkg.sUri = requestPkg.sUri.replace("\\", "/");
- if (!downLoadFile(requestPkg.sUri.toLocal8Bit().data(), requestPkg.sCommonStr.toLocal8Bit().data(), nCode))
- {
- --requestPkg.nRetryCount;
- if(requestPkg.nRetryCount > 0)
- {
- downLoad(requestPkg);
- return;
- }
- sErrorMsg = QString::fromLocal8Bit("%1下载失败!").arg(requestPkg.sUri);
- }
- }
- if(requestPkg.nHttpType == HttpType::htPost)
- {
- if(!doPost(requestPkg, sResponse, nCode))
- {
- sErrorMsg = QString::fromLocal8Bit("接口%1调用失败!").arg(requestPkg.sUri);
- }
- }
- else if(requestPkg.nHttpType == HttpType::htGet || requestPkg.nHttpType == HttpType::htGetUrl)
- {
- if(!doGet(requestPkg, sResponse, nCode))
- {
- sErrorMsg = QString::fromLocal8Bit("接口%1调用失败!").arg(requestPkg.sUri);
- }
- }
- else if (requestPkg.nHttpType == HttpType::htPut)
- {
- if (!doPut(requestPkg, sResponse, nCode))
- {
- sErrorMsg = QString::fromLocal8Bit("接口%1调用失败!").arg(requestPkg.sUri);
- }
- }
- __int64 nEndTime = g_appInfoPtr->serverMTime();
- myServerLog()<< requestPkg.sUri << ":resCode," << nCode<<"response:"<<sResponse.c_str() << "requestTime(ms):" << nEndTime - nStartTime;
- myDebug() << requestPkg.sUri << ":"<< sResponse.c_str();
- if (nCode != 200)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (reader.parse(sResponse, jsonRoot))
- {
- if (jsonRoot.isMember("desc"))
- {
- sErrorMsg = jsonRoot["desc"].asString().c_str();
- }
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- if (nCode == 403)
- {
- emit sgnTokenExpired();
- return;
- }
- switch(requestPkg.nRequestType)
- {
- case RequestType::rtUpgrade://客户端版本升级接口
- {
- CUpgrade upgrade;
- upgrade.nCode = nCode;
- if(sErrorMsg != "" || nCode !=200)
- {
- upgrade.sMessage = sErrorMsg;
- }
- else
- {
- genUpgrade(&upgrade, sResponse);
- }
- emit sgnUpgrade(upgrade);
- }
- break;
- case RequestType::rtSysNotice://客户端版本升级接口
- {
- CSysNotice sn;
- sn.nCode = nCode;
- if(sErrorMsg != "" || nCode !=200)
- {
- sn.sMessage = sErrorMsg;
- }
- else
- {
- genSysNotice(&sn, sResponse);
- }
- emit sgnSysNotice(sn);
- }
- break;
- case RequestType::rtGetSoftwareConfig:
- {
- CGetSoftwareConfig gsc;
- gsc.nCode = nCode;
- if(sErrorMsg != "" || nCode !=200)
- {
- gsc.sMessage = sErrorMsg;
- }
- else
- {
- genSoftwareConfig(&gsc, sResponse);
- }
- emit sgnGetSoftwareConfig(gsc);
- }
- break;
- case RequestType::rtDownLoadFile:
- {
- CDownLoadFileInfo dfi;
- dfi.sFileName = requestPkg.sCommonStr;
- dfi.sModuleName = requestPkg.sCommonStr1;
- dfi.sAdditionStr = requestPkg.sAdditionStr;
- dfi.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- dfi.sMessage = sErrorMsg;
- }
- emit sgnDownLoadFile(dfi);
- }
- break;
- case RequestType::rtStudentClientConfig:
- {
- CStudentClientConfig scc;
- scc.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- scc.sMessage = sErrorMsg;
- }
- else
- {
- genStudentClientConfig(&scc, sResponse);
- }
- emit sgnStudentClientConfig(scc);
- }
- break;
- case RequestType::rtLoginLimit:
- {
- CLoginLimit ll;
- ll.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- ll.sMessage = sErrorMsg;
- }
- else
- {
- genLoginLimit(&ll, sResponse);
- }
- emit sgnLoginLimit(ll);
- }
- break;
- case RequestType::rtLogin://登录
- {
- CLoginInfo li;
- li.nCode = nCode;
- if(sErrorMsg != "" || nCode != 200)
- {
- li.sMessage = sErrorMsg;
- }
- else
- {
- genLoginInfo(&li, sResponse);
- }
- emit sgnLoginInfo(li);
- }
- break;
- case RequestType::rtLogout:
- {
- CLogout logout;
- logout.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- logout.sMessage = sErrorMsg;
- }
- else
- {
- genLogout(&logout, sResponse);
- }
- emit sgnLogout(logout);
- }
- break;
- case RequestType::rtAgreement:
- {
- CAgreement agm;
- agm.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- agm.sMessage = sErrorMsg;
- }
- else
- {
- genAgreement(&agm, sResponse);
- }
- emit sgnAgreement(agm);
- }
- break;
- case RequestType::rtGetStudentInfoBySession:
- {
- CGetStudentInfoBySession gsibs;
- gsibs.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gsibs.sMessage = sErrorMsg;
- }
- else
- {
- genGetStudentInfoBySession(&gsibs, sResponse);
- }
- emit sgnGetStudentInfoBySession(gsibs);
- }
- break;
- case RequestType::rtSpecialtyNameList:
- {
- CSpecialtyNameList snl;
- snl.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- snl.sMessage = sErrorMsg;
- }
- else
- {
- genSpecialtyNameList(&snl, sResponse);
- }
- emit sgnSpecialtyNameList(snl);
- }
- break;
- case RequestType::rtCheckExamInProgress:
- {
- CCheckExamInProgress ceip;
- ceip.nCode = nCode;
- ceip.sEnterType = requestPkg.sCommonStr;
- if (sErrorMsg != "" || nCode != 200)
- {
- ceip.sMessage = sErrorMsg;
- }
- else
- {
- genCheckExamInProgress(&ceip, sResponse);
- }
- emit sgnCheckExamInProgress(ceip);
- }
- break;
- case RequestType::rtGetStudentClientMenu:
- {
- CGetStudentClientMenu gcm;
- gcm.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gcm.sMessage = sErrorMsg;
- }
- else
- {
- genGetStudentClientMenu(&gcm, sResponse);
- }
- emit sgnGetStudentClientMenu(gcm);
- }
- break;
- case RequestType::rtAppDownLoadUrl:
- {
- CAppDownLoadUrl adlu;
- adlu.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- adlu.sMessage = sErrorMsg;
- }
- else
- {
- genAppDownLoadUrl(&adlu, sResponse);
- }
- emit sgnAppDownLoadUrl(adlu);
- }
- break;
- case RequestType::rtGetUserNoticeList:
- {
- CGetUserNoticeList gunl;
- gunl.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gunl.sMessage = sErrorMsg;
- }
- else
- {
- genGetUserNoticeList(&gunl, sResponse);
- }
- emit sgnGetUserNoticeList(gunl);
- }
- break;
- case RequestType::rtUpdateNoticeReadStatus:
- {
- CUpdateNoticeReadStatus unrs;
- unrs.nCode = nCode;
- unrs.sIds = requestPkg.sCommonStr;
- if (sErrorMsg != "" || nCode != 200)
- {
- unrs.sMessage = sErrorMsg;
- }
- emit sgnUpdateNoticeReadStatus(unrs);
- }
- break;
- case RequestType::rtQueryExamList:
- {
- CQueryExamList qel;
- qel.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- qel.sMessage = sErrorMsg;
- }
- else
- {
- genQueryExamList(&qel, sResponse);
- }
- emit sgnQueryExamList(qel);
- }
- break;
- case RequestType::rtQueryExamEndList:
- {
- CQueryExamEndList qeel;
- qeel.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- qeel.sMessage = sErrorMsg;
- }
- else
- {
- genQueryExamEndList(&qeel, sResponse);
- }
- emit sgnQueryExamEndList(qeel);
- }
- break;
- case RequestType::rtQueryHomeworkList:
- {
- CQueryHomeworkList qhl;
- qhl.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- qhl.sMessage = sErrorMsg;
- }
- else
- {
- genQueryHomeworkList(&qhl, sResponse);
- }
- emit sgnQueryHomeworkList(qhl);
- }
- break;
-
- case RequestType::rtQueryBatchList:
- {
- CQueryBatchList qbl;
- qbl.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- qbl.sMessage = sErrorMsg;
- }
- else
- {
- genQueryBatchList(&qbl, sResponse);
- }
- emit sgnQueryBatchList(qbl);
- }
- break;
- case RequestType::rtQueryPracticeCourseList:
- {
- CQueryPracticeCourseList qpcl;
- qpcl.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- qpcl.sMessage = sErrorMsg;
- }
- else
- {
- genQueryPracticeCourseList(&qpcl, sResponse);
- }
- emit sgnQueryPracticeCourseList(qpcl);
- }
- break;
- case RequestType::rtQueryPracticeRecordList:
- {
- CQueryPracticeRecordList qprl;
- qprl.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- qprl.sMessage = sErrorMsg;
- }
- else
- {
- genQueryPracticeRecordList(&qprl, sResponse);
- }
- emit sgnQueryPracticeRecordList(qprl);
- }
- break;
- case RequestType::rtGetPracticeDetailInfo:
- {
- CGetPracticeDetailInfo gpdi;
- gpdi.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gpdi.sMessage = sErrorMsg;
- }
- else
- {
- genGetPracticeDetailInfo(&gpdi, sResponse);
- }
- emit sgnGetPracticeDetailInfo(gpdi);
- }
- break;
- case RequestType::rtFindExamRecordDataEntity:
- {
- CFindExamRecordDataEntity ferde;
- ferde.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- ferde.sMessage = sErrorMsg;
- }
- else
- {
- genFindExamRecordDataEntity(&ferde, sResponse);
- }
- emit sgnFindExamRecordDataEntity(ferde);
- }
- break;
- case RequestType::rtGetCourseInfo:
- {
- CGetCourseInfo gci;
- gci.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gci.sMessage = sErrorMsg;
- }
- else
- {
- genGetCourseInfo(&gci, sResponse);
- }
- emit sgnGetCourseInfo(gci);
- }
- break;
- case RequestType::rtGetExamRecordQuestions:
- {
- CGetExamRecordQuestions gerq;
- gerq.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gerq.sMessage = sErrorMsg;
- }
- else
- {
- genGetExamRecordQuestions(&gerq, sResponse);
- }
- emit sgnGetExamRecordQuestions(gerq);
- }
- break;
- case RequestType::rtGetQuestion:
- {
- CGetQuestion gq;
- gq.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gq.sMessage = sErrorMsg;
- }
- else
- {
- genGetQuestion(&gq, sResponse);
- }
- emit sgnGetQuestion(gq);
- }
- break;
- case RequestType::rtGetOfflineCourse:
- {
- CGetOfflineCourse goc;
- goc.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- goc.sMessage = sErrorMsg;
- }
- else
- {
- genGetOfflineCourse(&goc, sResponse);
- }
- emit sgnGetOfflineCourse(goc);
- }
- break;
- case RequestType::rtGetOffLineExamAnswerSheet:
- {
- CGetOffLineExamAnswerSheet goeas;
- goeas.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- goeas.sMessage = sErrorMsg;
- }
- else
- {
- genGetOffLineExamAnswerSheet(&goeas, sResponse);
- }
- emit sgnGetOffLineExamAnswerSheet(goeas);
- }
- break;
- case RequestType::rtStartOfflineExam:
- {
- CStartOfflineExam soe;
- soe.nCode = nCode;
- soe.nRow = requestPkg.sCommonStr.toInt();
- if (sErrorMsg != "" || nCode != 200)
- {
- soe.sMessage = sErrorMsg;
- }
-
- emit sgnStartOfflineExam(soe);
- }
- break;
- case RequestType::rtGetOffLineExamPaper:
- {
- CGetOffLineExamPaper goep;
- goep.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- goep.sMessage = sErrorMsg;
- }
- else
- {
- QFile file(requestPkg.sCommonStr);
- if (file.open(QIODevice::WriteOnly))
- {
- qint64 nLen = file.write(sResponse.c_str(), sResponse.length());
- file.close();
- if (nLen != sResponse.length())
- {
- goep.nCode = 0;
- goep.sMessage = QString::fromLocal8Bit("保存试卷失败");
- }
- }
- else
- {
- goep.nCode = 0;
- goep.sMessage = QString::fromLocal8Bit("创建试卷失败");
- }
- genGetOffLineExamPaper(&goep, sResponse);
- }
- emit sgnGetOffLineExamPaper(goep);
- }
- break;
- case RequestType::rtPreviewOffLineExamPaper:
- {
- CPreviewOffLineExamPaper poep;
- poep.nCode = nCode;
- poep.nRow = requestPkg.sCommonStr.toInt();
- if (sErrorMsg != "" || nCode != 200)
- {
- poep.sMessage = sErrorMsg;
- }
- else
- {
- genPreviewOffLineExamPaper(&poep, sResponse);
- }
- emit sgnPreviewOffLineExamPaper(poep);
- }
- break;
- case RequestType::rtSubmitOfflinePaper:
- {
- CSubmitOfflinePaper sop;
- sop.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- sop.sMessage = sErrorMsg;
- }
- emit sgnSubmitOfflinePaper(sop);
- }
- break;
- case RequestType::rtQueryObjectiveScoreList:
- {
- CQueryObjectiveScoreList qosl;
- qosl.nCode = nCode;
- qosl.sExamStudentId = requestPkg.sCommonStr;
- if (sErrorMsg != "" || nCode != 200)
- {
- qosl.sMessage = sErrorMsg;
- }
- else
- {
- genQueryObjectiveScoreList(&qosl, sResponse);
- }
- emit sgnQueryObjectiveScoreList(qosl);
- }
- break;
- case RequestType::rtEditPassword:
- {
- CEditPassword ep;
- ep.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- ep.sMessage = sErrorMsg;
-
-
- }
- else
- {
- genEditPassword(&ep, sResponse);
- }
- emit sgnEditPassword(ep);
- }
- break;
- case RequestType::rtStartExamLimit:
- {
- CStartExamLimit sel;
- sel.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- sel.sMessage = sErrorMsg;
- }
- else
- {
- genStartExamLimit(&sel, sResponse);
- }
- emit sgnStartExamLimit(sel);
- }
- break;
- case RequestType::rtIpLimit:
- {
- CIpLimit il;
- il.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- il.sMessage = sErrorMsg;
- }
- else
- {
- genIpLimit(&il, sResponse);
- }
- emit sgnIpLimit(il);
- }
- break;
- case RequestType::rtGetExamProperty:
- {
- CGetExamProperty ep;
- ep.nCode = nCode;
- ep.sType = requestPkg.sCommonStr;
- if (sErrorMsg != "" || nCode != 200)
- {
- ep.sMessage = sErrorMsg;
- }
- else
- {
- genGetExamProperty(&ep, sResponse);
- }
- emit sgnGetExamProperty(ep);
- }
- break;
- case RequestType::rtFaceCheckEnabled:
- {
- CFaceCheckEnabled fce;
- fce.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- fce.sMessage = sErrorMsg;
- }
- else
- {
- genFaceCheckEnabled(&fce, sResponse);
- }
- emit sgnFaceCheckEnabled(fce);
- }
- break;
-
- case RequestType::rtLivenessEnabled:
- {
- CLivenessEnabled le;
- le.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- le.sMessage = sErrorMsg;
- }
- else
- {
- genLivenessEnabled(&le, sResponse);
- }
- emit sgnLivenessEnabled(le);
- }
- break;
- case RequestType::rtStartExam:
- {
- CStartExam se;
- se.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- se.sMessage = sErrorMsg;
- }
- else
- {
- genStartExam(&se, sResponse);
- }
- emit sgnStartExam(se);
- }
- break;
- case RequestType::rtGetExamRecordPaperStruct:
- {
- CGetExamRecordPaperStruct eps;
- eps.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- eps.sMessage = sErrorMsg;
- }
- else
- {
- genGetExamRecordPaperStruct(&eps, sResponse);
- }
- emit sgnGetExamRecordPaperStruct(eps);
- }
- break;
- case RequestType::rtGetExamById:
- {
- CGetExamById examInfo;
- examInfo.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- examInfo.sMessage = sErrorMsg;
- }
- else
- {
- genGetExamById(&examInfo, sResponse);
- }
- emit sgnGetExamById(examInfo);
- }
- break;
- case RequestType::rtWeiXinAnswerEnabled:
- {
- CWeiXinAnswerEnabled wxae;
- wxae.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- wxae.sMessage = sErrorMsg;
- }
- else
- {
- genWeiXinAnswerEnabled(&wxae, sResponse);
- }
- emit sgnWeiXinAnswerEnabled(wxae);
- }
- break;
- case RequestType::rtGetWXQrCode:
- {
- CGetWXQrCode wxc;
- wxc.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- wxc.sMessage = sErrorMsg;
- }
- else
- {
- genGetWXQrCode(&wxc, sResponse);
- }
- emit sgnGetWXQrCode(wxc);
- }
- break;
- case RequestType::rtSaveUploadedFileAcknowledgeStatus:
- {
- CSaveUploadedFileAcknowledgeStatus sufs;
- sufs.nCode = nCode;
- sufs.sFileUrl = requestPkg.sCommonStr;
- if (sErrorMsg != "" || nCode != 200)
- {
- sufs.sMessage = sErrorMsg;
- }
-
- emit sgnSaveUploadedFileAcknowledgeStatus(sufs);
- }
- break;
-
- case RequestType::rtFindExamQuestionList:
- {
- CFindExamQuestionList feql;
- feql.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- feql.sMessage = sErrorMsg;
- }
- else
- {
- genFindExamQuestionList(&feql, sResponse);
- }
- emit sgnFindExamQuestionList(feql);
- }
- break;
- case RequestType::rtGetQuestionContent:
- {
- CGetQuestionContent gqc;
- QStringList sl = requestPkg.sCommonStr.split(",");
- if (sl.count() == 2)
- {
- gqc.sQuestionId = sl[0];
- gqc.sOrder = sl[1];
- }
- gqc.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gqc.sMessage = sErrorMsg;
- }
- else
- {
- genGetQuestionContent(&gqc, sResponse);
- }
- emit sgnGetQuestionContent(gqc);
- }
- break;
- case RequestType::rtStartAnswer:
- {
- CStartAnswer sa;
- sa.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- sa.sMessage = sErrorMsg;
- }
- else
- {
- genStartAnswer(&sa, sResponse);
- }
- emit sgnStartAnswer(sa);
- }
- break;
- case RequestType::rtExamHeartbeat:
- {
- CExamHeartbeat ehb;
- ehb.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- ehb.sMessage = sErrorMsg;
- }
- else
- {
- genExamHeartbeat(&ehb, sResponse);
- }
- emit sgnExamHeartbeat(ehb);
- }
- break;
- case RequestType::rtSubmitQuestionAnswer:
- {
- CSubmitQuestionAnswer sqa;
- sqa.nCode = nCode;
- QStringList list = requestPkg.sCommonStr.split(",");
- if(list.count() == 2)
- {
- sqa.nOrder = list[0].toInt();
- sqa.nVersion = list[1].toInt();
- }
- if (sErrorMsg != "" || nCode != 200)
- {
- sqa.sMessage = sErrorMsg;
- }
- emit sgnSubmitQuestionAnswer(sqa);
- }
- break;
-
- case RequestType::rtEndExam:
- {
- CEndExam ee;
- ee.nCode = nCode;
- ee.sModuleName = requestPkg.sCommonStr;
- ee.bForce = requestPkg.sAdditionStr == "1";
- if (sErrorMsg != "" || nCode != 200)
- {
- ee.sMessage = sErrorMsg;
- }
- emit sgnEndExam(ee);
- }
- break;
- case RequestType::rtProcessUpload:
- {
- CProcessUpload pu;
- pu.sCommonStr = requestPkg.sCommonStr;
- pu.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- pu.sMessage = sErrorMsg;
- }
- else
- {
- genProcessUpload(&pu, sResponse);
- }
- emit sgnProcessUpload(pu);
- }
- break;
-
- case RequestType::rtSaveFaceCompareResult:
- {
- CBaseResponsePackage res;
- res.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- res.sMessage = sErrorMsg;
- }
- emit sgnSaveFaceCompareResult(res);
- }
- break;
-
- case RequestType::rtSaveFaceCaptureResult:
- {
- CBaseResponsePackage res;
- res.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- res.sMessage = sErrorMsg;
- }
- emit sgnSaveFaceCaptureResult(res);
- }
- break;
- case RequestType::rtSaveFaceLiveVerifyResult:
- {
- CBaseResponsePackage res;
- res.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- res.sMessage = sErrorMsg;
- }
- emit sgnSaveFaceLiveVerifyResult(res);
- }
- break;
- case RequestType::rtStartFaceLiveVerify:
- {
- CStartFaceLiveVerify sflv;
- sflv.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- sflv.sMessage = sErrorMsg;
- }
- else
- {
- genStartFaceLiveVerify(&sflv, sResponse);
- }
- emit sgnStartFaceLiveVerify(sflv);
- }
- break;
- case RequestType::rtGetOrgPropertiesByGroupWithoutCache:
- {
- CGetOrgPropertiesByGroupWithoutCache gop;
- gop.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- gop.sMessage = sErrorMsg;
- }
- else
- {
- genGetOrgPropertiesByGroupWithoutCache(&gop, sResponse);
- }
- emit sgnGetOrgPropertiesByGroupWithoutCache(gop);
- }
- break;
- case RequestType::rtGetEndExamInfo:
- {
- CGetEndExamInfo geei;
- geei.nCode = nCode;
- if (sErrorMsg != "" || nCode != 200)
- {
- geei.sMessage = sErrorMsg;
- }
- else
- {
- genGetEndExamInfo(&geei, sResponse);
- }
- emit sgnGetEndExamInfo(geei);
- }
- break;
- default:
- break;
- }
- }
- void CHttpBll::genUpgrade(CUpgrade *pUpgrade, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if(!reader.parse(sResponse, jsonRoot))
- {
- pUpgrade->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pUpgrade->sMessage << sResponse.c_str();
- }
- pUpgrade->sVersion = jsonRoot["version"].asString().c_str();
- pUpgrade->nBuild = jsonRoot["build"].asInt();
- pUpgrade->sContent = jsonRoot["content"].asString().c_str();
- pUpgrade->bForce = jsonRoot["force"].asBool();
- pUpgrade->sUpgradeUrl = jsonRoot["downUrl"].asString().c_str();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genAgreement(CAgreement *pAgreement, const std::string &sResponse)
- {
- try
- {
- std::string sRes = sResponse;
- if (sResponse.length() > 3 && sResponse[0] == -17 &&
- sResponse[1] == -69 &&
- sResponse[2] == -65)
- {
- sRes = sResponse.substr(3, sResponse.length() -3);
- }
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if(!reader.parse(sRes, jsonRoot))
- {
- pAgreement->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pAgreement->sMessage << sResponse.c_str();
- }
- pAgreement->sTitle = jsonRoot["title"].asString().c_str();
- pAgreement->nStaySeconds = jsonRoot["staySeconds"].asInt();
- pAgreement->sContent = jsonRoot["content"].toStyledString().c_str();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genStudentClientConfig(CStudentClientConfig *pStudentClientConfig, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pStudentClientConfig->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pStudentClientConfig->sMessage << sResponse.c_str();
- }
- pStudentClientConfig->sCusMenuLogoFileUrl = jsonRoot["CUS_MENU_LOGO_FILE_URL"].asString().c_str();
- pStudentClientConfig->sIdentityNumberLoginAlias = jsonRoot["IDENTITY_NUMBER_LOGIN_ALIAS"].asString().c_str();
- pStudentClientConfig->bIsCustomMenuLogo = QVariant(jsonRoot["IS_CUSTOM_MENU_LOGO"].asString().c_str()).toBool();
- QString loginType = jsonRoot["LOGIN_TYPE"].asString().c_str();
- QStringList ltList = loginType.split(",");
- for (QString sType : ltList)
- {
- if (sType == "STUDENT_CODE")
- {
- pStudentClientConfig->bStudentCodeLogin = true;
- }
- else if (sType == "IDENTITY_NUMBER")
- {
- pStudentClientConfig->bIdentifyNumberLogin = true;
- }
- }
- pStudentClientConfig->sLogoFileUrl = jsonRoot["LOGO_FILE_URL"].asString().c_str();
- pStudentClientConfig->sStudentClientBgPictureUrl = jsonRoot["STUDENT_CLIENT_BG_PICTURE_URL"].asString().c_str();
- pStudentClientConfig->sOeStudentSysName = jsonRoot["OE_STUDENT_SYS_NAME"].asString().c_str();
- QString preventCheating = jsonRoot["PREVENT_CHEATING_CONFIG"].asString().c_str();
- QStringList pcList = preventCheating.split(",");
- for (QString sType : pcList)
- {
- if (sType == "DISABLE_REMOTE_ASSISTANCE")
- {
- pStudentClientConfig->bDisableRemoteAssistance = true;
- }
- else if (sType == "FULL_SCREEN_TOP")
- {
- pStudentClientConfig->bFullScreenTop = true;
- }
- else if (sType == "DISABLE_MULTISCREEN")
- {
- pStudentClientConfig->bDisableMutiScreen = true;
- }
- else if (sType == "DISABLE_VIRTUAL_CAMERA")
- {
- pStudentClientConfig->bDisableVirtualCamera = true;
- }
- }
- pStudentClientConfig->sRootOrgId = jsonRoot["ROOT_ORG_ID"].asString().c_str();// " : "0",
- pStudentClientConfig->bShowQmthLogo = QVariant(jsonRoot["SHOW_QMTH_LOGO"].asString().c_str()).toBool();// " : "false",
- pStudentClientConfig->bShowStudentClientAppQrcode = QVariant(jsonRoot["SHOW_STUDENT_CLIENT_APP_QRCODE"].asString().c_str()).toBool();// " : "true",
- pStudentClientConfig->sStudentCodeLoginAlias = jsonRoot["STUDENT_CODE_LOGIN_ALIAS"].asString().c_str(); // " : "学号登录34s"
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genSysNotice(CSysNotice *pSysNotice, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pSysNotice->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pSysNotice->sMessage << sResponse.c_str();
- }
- pSysNotice->nId = jsonRoot["id"].asInt64();
- pSysNotice->nRootOrgId = jsonRoot["rootOrgId"].asInt64();
- pSysNotice->sContent = jsonRoot["content"].asString().c_str();
- pSysNotice->sStartTime = jsonRoot["startTime"].asString().c_str();
- pSysNotice->sEndTime = jsonRoot["endTime"].asString().c_str();
- pSysNotice->sTitle = jsonRoot["title"].asString().c_str();
- pSysNotice->bEnable = jsonRoot["enable"].asBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genSoftwareConfig(CGetSoftwareConfig *pSoftwareConfig, const std::string &sResponse)
- {
- if(!sResponse.empty())
- {
- pSoftwareConfig->sSoftwareConfig = std::string(sResponse.rbegin()+32, sResponse.rend()).c_str();
- }
- }
- void CHttpBll::genLoginLimit(CLoginLimit *pLoginLimit, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pLoginLimit->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pLoginLimit->sMessage << sResponse.c_str();
- }
- pLoginLimit->nCount = jsonRoot["count"].asInt64();
- pLoginLimit->bPass = jsonRoot["pass"].asBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genLoginInfo(CLoginInfo *pLoginInfo, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pLoginInfo->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pLoginInfo->sMessage << sResponse.c_str();
- }
- // pLoginInfo->nCode = jsonRoot["code"].asInt();
- if (jsonRoot["code"].asString() != "200")
- {
- pLoginInfo->nCode = 0;
- }
- pLoginInfo->sMessage = jsonRoot["desc"].asString().c_str();
- sKey = jsonRoot["content"]["key"].asString().c_str();
- sToken = jsonRoot["content"]["token"].asString().c_str();
- pLoginInfo->sUserType = jsonRoot["content"]["userType"].asString().c_str();
- pLoginInfo->nUserId = jsonRoot["content"]["userId"].asInt64();
- pLoginInfo->sDisplayName = jsonRoot["content"]["displayName"].asString().c_str();
- pLoginInfo->nRootOrgId = jsonRoot["content"]["rootOrgId"].asInt64();
- pLoginInfo->sRootOrgName = jsonRoot["content"]["rootOrgName"].asString().c_str();
- pLoginInfo->sCreationTime = jsonRoot["content"]["creationTime"].asString().c_str();
- pLoginInfo->sClientIp = jsonRoot["content"]["clientIp"].asString().c_str();
- pLoginInfo->nSessionTimeout = jsonRoot["content"]["sessionTimeout"].asInt64();
- pLoginInfo->bPasswordWeak = jsonRoot["content"]["passwordWeak"].asBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genLogout(CLogout *pLogout, const std::string &sResponse)
- {
- }
- void CHttpBll::genEditPassword(CEditPassword *pEditPassword, const std::string &sResponse)
- {
- }
- void CHttpBll::genGetStudentClientMenu(CGetStudentClientMenu *pGetStudentClientMenu, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetStudentClientMenu->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetStudentClientMenu->sMessage << sResponse.c_str();
- }
- int nSize = jsonRoot.size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jMenuItem = jsonRoot[i];
- CStudentClientMenu scm;
- scm.nId = jMenuItem["id"].asInt64();
- scm.sCode = jMenuItem["code"].asString().c_str();
- scm.sName = jMenuItem["name"].asString().c_str();
- pGetStudentClientMenu->vMenus.push_back(scm);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetStudentInfoBySession(CGetStudentInfoBySession *pGetStudentInfoBySession, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetStudentInfoBySession->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetStudentInfoBySession->sMessage << sResponse.c_str();
- }
- pGetStudentInfoBySession->nId = jsonRoot["id"].asInt64();
- pGetStudentInfoBySession->sName = jsonRoot["name"].asString().c_str();
- pGetStudentInfoBySession->nOrgId = jsonRoot["orgId"].asInt64();
- pGetStudentInfoBySession->sOrgCode = jsonRoot["orgCode"].asString().c_str();
- pGetStudentInfoBySession->sOrgName = jsonRoot["orgName"].asString().c_str();
- QString sStudentCode = "";
- int nSize = jsonRoot["studentCodeList"].size();
- for (int i = 0; i < nSize; ++i)
- {
- if (sStudentCode.isEmpty())
- {
- sStudentCode = jsonRoot["studentCodeList"][i].asString().c_str();
- }
- else
- {
- sStudentCode = sStudentCode + "," + jsonRoot["studentCodeList"][i].asString().c_str();
- }
- }
- pGetStudentInfoBySession->sStudentCode = sStudentCode;
- pGetStudentInfoBySession->sIdentityNumber = jsonRoot["identityNumber"].asString().c_str();
- pGetStudentInfoBySession->sPhotoPath = jsonRoot["photoPath"].asString().c_str();
- pGetStudentInfoBySession->bEnable = jsonRoot["enable"].asBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genSpecialtyNameList(CSpecialtyNameList *pSpecialtyNameList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pSpecialtyNameList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pSpecialtyNameList->sMessage << sResponse.c_str();
- }
- QString sSpecialtyName = "";
- int nSize = jsonRoot.size();
- for (int i = 0; i < nSize; ++i)
- {
- if (sSpecialtyName.isEmpty())
- {
- sSpecialtyName = jsonRoot[i].asString().c_str();
- }
- else
- {
- sSpecialtyName = sSpecialtyName + "," + jsonRoot[i].asString().c_str();
- }
- }
- pSpecialtyNameList->sSpecialtyName = sSpecialtyName;
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetUserNoticeList(CGetUserNoticeList *pGetUserNoticeList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetUserNoticeList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetUserNoticeList->sMessage << sResponse.c_str();
- }
- int nSize = jsonRoot.size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jNoticeItem = jsonRoot[i];
- CNoticeInfo ni;
- ni.nId = jNoticeItem["id"].asInt64();
- ni.sTitle = jNoticeItem["title"].asString().c_str();
- ni.sContent = jNoticeItem["content"].asString().c_str();
- ni.sPublisher = jNoticeItem["publisher"].asString().c_str();
- ni.sPublishTime = jNoticeItem["publishTime"].asString().c_str();
- ni.bHasRead = jNoticeItem["hasRead"].asBool();
- ni.bHasRecalled = jNoticeItem["hasRecalled"].isNull() ? false : jNoticeItem["hasRecalled"].asBool();
- pGetUserNoticeList->vNoticeList.push_back(ni);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genAppDownLoadUrl(CAppDownLoadUrl *pAppDownLoadUrl, const std::string &sResponse)
- {
- pAppDownLoadUrl->sUrl = sResponse.c_str();
- }
- void CHttpBll::genAppEnabled(CAppEnabled *pAppEnabled, const std::string &sResponse)
- {
- try
- {
- pAppEnabled->bEnable = QVariant(sResponse.c_str()).toBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genQueryBatchList(CQueryBatchList *pQueryBatchList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pQueryBatchList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pQueryBatchList->sMessage << sResponse.c_str();
- }
- int nSize = jsonRoot.size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jBatchItem = jsonRoot[i];
- CBatchInfo bi;
- bi.nId = jBatchItem["id"].asInt64();
- bi.sName = jBatchItem["name"].asString().c_str();
- bi.sExamType = jBatchItem["examType"].asString().c_str();
- pQueryBatchList->vBatchList.push_back(bi);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetExamProperty(CGetExamProperty *pGetExamProperty, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetExamProperty->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetExamProperty->sMessage << sResponse.c_str();
- }
- if (jsonRoot.isMember("BEFORE_EXAM_REMARK"))
- {
- pGetExamProperty->sBeforeExamRemark = jsonRoot["BEFORE_EXAM_REMARK"].asString().c_str();
- }
- if (jsonRoot.isMember("CHECK_ENVIRONMENT"))
- {
- pGetExamProperty->bCheckEnvironment = QVariant(jsonRoot["CHECK_ENVIRONMENT"].asString().c_str()).toBool();
- }
- if (jsonRoot.isMember("WARN_THRESHOLD"))
- {
- pGetExamProperty->nWarnThreshold = QVariant(jsonRoot["WARN_THRESHOLD"].asString().c_str()).toInt();
- }
- if (jsonRoot.isMember("IS_FACE_CHECK"))
- {
- pGetExamProperty->bIsFaceCheck = QVariant(jsonRoot["IS_FACE_CHECK"].asString().c_str()).toBool();
- }
- if (jsonRoot.isMember("SNAPSHOT_INTERVAL"))
- {
- pGetExamProperty->nSnapshotInterval = QVariant(jsonRoot["SNAPSHOT_INTERVAL"].asString().c_str()).toInt();
- }
- if (jsonRoot.isMember("FACE_VERIFY_START_MINUTE"))
- {
- pGetExamProperty->nFaceVerifyStartMinute = QVariant(jsonRoot["FACE_VERIFY_START_MINUTE"].asString().c_str()).toInt();
- }
- if (jsonRoot.isMember("FACE_VERIFY_END_MINUTE"))
- {
- pGetExamProperty->nFaceVerifyEndMinute = QVariant(jsonRoot["FACE_VERIFY_END_MINUTE"].asString().c_str()).toInt();
- }
- if (jsonRoot.isMember("IS_STRANGER_ENABLE"))
- {
- pGetExamProperty->bIsStrangerEnable = QVariant(jsonRoot["IS_STRANGER_ENABLE"].asString().c_str()).toBool();
- }
- if (jsonRoot.isMember("PRACTICE_TYPE"))
- {
- pGetExamProperty->sPracticeType = jsonRoot["PRACTICE_TYPE"].asString().c_str();
- }
- if (jsonRoot.isMember("FREEZE_TIME"))
- {
- pGetExamProperty->nFreezeTime = QVariant(jsonRoot["FREEZE_TIME"].asString().c_str()).toInt();
- }
- if (jsonRoot.isMember("AFTER_EXAM_REMARK"))
- {
- pGetExamProperty->sAfterExamRemark = jsonRoot["AFTER_EXAM_REMARK"].asString().c_str();
- }
- if (jsonRoot.isMember("IS_OBJ_SCORE_VIEW"))
- {
- pGetExamProperty->bIsObjScoreView = QVariant(jsonRoot["IS_OBJ_SCORE_VIEW"].asString().c_str()).toBool();
- }
- if (jsonRoot.isMember("SHOW_CHEATING_REMARK"))
- {
- pGetExamProperty->bShowCheatingRemark = QVariant(jsonRoot["SHOW_CHEATING_REMARK"].asString().c_str()).toBool();
- }
- if (jsonRoot.isMember("CHEATING_REMARK"))
- {
- pGetExamProperty->sCheatingRemark = jsonRoot["CHEATING_REMARK"].asString().c_str();
- }
- if (jsonRoot.isMember("IS_FACE_VERIFY_BEFORE"))
- {
- pGetExamProperty->bIsLivenessBefore = QVariant(jsonRoot["IS_FACE_VERIFY_BEFORE"].asString().c_str()).toBool();
- }
- if (jsonRoot.isMember("OFFLINE_UPLOAD_FILE_TYPE"))
- {
- QString sFileType = jsonRoot["OFFLINE_UPLOAD_FILE_TYPE"].asString().c_str();
- Json::Reader reader;
- Json::Value jFileType = Json::Value::null;
- if (!reader.parse(sFileType.toStdString(), jFileType))
- {
- pGetExamProperty->sMessage = QString::fromLocal8Bit("解析文件类型异常!");
- pGetExamProperty->nCode = 0;
- }
- int nSize = jFileType.size();
- for (int i = 0; i < nSize; ++i)
- {
- pGetExamProperty->vOfflineUploadFileType.push_back(jFileType[i].asString().c_str());
- }
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genStartExamLimit(CStartExamLimit *pStartExamLimit, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pStartExamLimit->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pStartExamLimit->sMessage << sResponse.c_str();
- }
- pStartExamLimit->nCount = jsonRoot["count"].asInt();
- pStartExamLimit->bPass = jsonRoot["pass"].asBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genIpLimit(CIpLimit *pIpLimit, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pIpLimit->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pIpLimit->sMessage << sResponse.c_str();
- }
- pIpLimit->bLimited = jsonRoot["limited"].asBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genStartExam(CStartExam *pStartExam, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pStartExam->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pStartExam->sMessage << sResponse.c_str();
- }
- pStartExam->sCourseCode = jsonRoot["courseCode"].asString().c_str();
- pStartExam->sCourseName = jsonRoot["courseName"].asString().c_str();
- pStartExam->nExamRecordDataId = jsonRoot["examRecordDataId"].asInt64();
- pStartExam->nFaceVerifyMinute = jsonRoot["faceVerifyMinute"].asInt();
- pStartExam->sStudentCode = jsonRoot["studentCode"].asString().c_str();
- pStartExam->sStudentName = jsonRoot["studentName"].asString().c_str();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genFaceCheckEnabled(CFaceCheckEnabled *pFaceCheckEnabled, const std::string &sResponse)
- {
- try
- {
- pFaceCheckEnabled->bEnabled = QVariant(sResponse.c_str()).toBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genLivenessEnabled(CLivenessEnabled *pLivenessEnabled, const std::string &sResponse)
- {
- try
- {
- pLivenessEnabled->bEnabled = QVariant(sResponse.c_str()).toBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genWeiXinAnswerEnabled(CWeiXinAnswerEnabled *pWeiXinAnswerEnabled, const std::string &sResponse)
- {
- try
- {
- pWeiXinAnswerEnabled->bEnabled = QVariant(sResponse.c_str()).toBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetExamById(CGetExamById *pGetExamById, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetExamById->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetExamById->sMessage << sResponse.c_str();
- }
- pGetExamById->nId = jsonRoot["id"].asInt64();
- pGetExamById->sCode = jsonRoot["code"].asString().c_str();
- pGetExamById->nRootOrgId = jsonRoot["rootOrgId"].asInt64();
- pGetExamById->sBeginTime = jsonRoot["beginTime"].asString().c_str();
- pGetExamById->sEndTime = jsonRoot["endTime"].asString().c_str();
- pGetExamById->sName = jsonRoot["name"].asString().c_str();
- pGetExamById->sExamType = jsonRoot["examType"].asString().c_str();
- pGetExamById->nDuration = jsonRoot["duration"].asInt64();
- pGetExamById->bEnable = jsonRoot["enable"].asBool();
- pGetExamById->bStarted = jsonRoot["started"].asBool();
- pGetExamById->bIpLimitSettingsEnabled = jsonRoot["ipLimitSettingsEnabled"].asBool();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genStartAnswer(CStartAnswer *pStartAnswer, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pStartAnswer->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pStartAnswer->sMessage << sResponse.c_str();
- }
- pStartAnswer->nDuration = jsonRoot["duration"].asInt64();
- pStartAnswer->nExamRecordDataId = jsonRoot["examRecordDataId"].asInt64();
- pStartAnswer->nUsedExamSeconds = jsonRoot["usedExamSeconds"].asInt64();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetQuestion(CGetQuestion *pGetQuestion, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetQuestion->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetQuestion->sMessage << sResponse.c_str();
- }
- pGetQuestion->sId = jsonRoot["id"].asString().c_str();
- pGetQuestion->sBody = jsonRoot["masterVersion"]["body"].isNull() ? "" : jsonRoot["masterVersion"]["body"].asString().c_str();
- pGetQuestion->sVersion = jsonRoot["masterVersion"]["version"].asString().c_str();
- pGetQuestion->bhasAudios = jsonRoot["masterVersion"]["hasAudios"].asBool();
- int nSize = jsonRoot["masterVersion"]["questionUnitList"].size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jQuestionItem = jsonRoot["masterVersion"]["questionUnitList"][i];
- CSubQuestion sq;
- sq.sQuestionType = jQuestionItem["questionType"].asString().c_str();
- sq.sBody = jQuestionItem["body"].asString().c_str();
- //sq.sQuestionType = jQuestionItem["questionType"].asString().c_str();
- int nOptionSize = jQuestionItem["questionOptionList"].size();
- for (int j = 0; j < nOptionSize; ++j)
- {
- Json::Value jOption = jQuestionItem["questionOptionList"][j];
- COption o;
- o.sBody = jOption["body"].asString().c_str();
- sq.vOptions.push_back(o);
- }
- int nAnswerSize = jQuestionItem["rightAnswer"].size();
- for (int k = 0; k < nAnswerSize; ++k)
- {
- Json::Value jAnswer = jQuestionItem["rightAnswer"][k];
- sq.vRightAnswer.push_back(jAnswer.asString().c_str());
- }
- pGetQuestion->vSubQuestion.push_back(sq);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetQuestionContent(CGetQuestionContent *pGetQuestionContent, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetQuestionContent->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetQuestionContent->sMessage << sResponse.c_str();
- }
- pGetQuestionContent->sBody = jsonRoot["body"].isNull() ? "" : jsonRoot["body"].asString().c_str();
- pGetQuestionContent->sVersion = jsonRoot["version"].asString().c_str();
- pGetQuestionContent->bhasAudios = jsonRoot["hasAudios"].asBool();
- int nSize = jsonRoot["questionUnitList"].size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jQuestionItem = jsonRoot["questionUnitList"][i];
- CSubQuestion sq;
- sq.sQuestionType = jQuestionItem["questionType"].asString().c_str();
- sq.sBody = jQuestionItem["body"].asString().c_str();
- sq.sAnswerType = jQuestionItem["answerType"].asString().c_str();
- int nOptionSize = jQuestionItem["questionOptionList"].size();
- for (int j = 0; j < nOptionSize; ++j)
- {
- Json::Value jOption = jQuestionItem["questionOptionList"][j];
- COption o;
- o.sBody = jOption["body"].asString().c_str();
- sq.vOptions.push_back(o);
- }
- for (int jq = 0; jq < jQuestionItem["optionPermutation"].size(); ++jq)
- {
- Json::Value Item = jQuestionItem["optionPermutation"][jq];
- sq.voptionPermutation.push_back(Item.asInt());
- }
- int nAnswerSize = jQuestionItem["rightAnswer"].size();
- for (int k = 0; k < nAnswerSize; ++k)
- {
- Json::Value jAnswer = jQuestionItem["rightAnswer"][k];
- sq.vRightAnswer.push_back(jAnswer.asString().c_str());
- }
- pGetQuestionContent->vSubQuestion.push_back(sq);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genExamCourseInfo(const Json::Value &jExamItem, CExamCourseInfo &eci)
- {
- try
- {
- eci.nAllowExamCount = jExamItem["allowExamCount"].asInt();
- eci.bAppExamEnabled = jExamItem["appExamEnabled"].asBool();
- eci.sCourseCode = jExamItem["courseCode"].asString().c_str();
- eci.nCourseId = jExamItem["courseId"].asInt64();
- eci.sCourseLevel = jExamItem["courseLevel"].asString().c_str();
- eci.sCourseName = jExamItem["courseName"].asString().c_str();
- eci.sEndTime = jExamItem["endTime"].asString().c_str();
- eci.bExamCycleEnabled = jExamItem["examCycleEnabled"].asBool();
- int nWeekSize = jExamItem["examCycleWeek"].size();
- for(int i =0; i < nWeekSize; ++i)
- {
- eci.vExamCycleWeek.push_back(jExamItem["examCycleWeek"][i].asInt());
- }
-
- int nCycleTimeRangeSize = jExamItem["examCycleTimeRange"].size();
- for(int i = 0; i < nCycleTimeRangeSize; ++i)
- {
- Json::Value jTimeRange = jExamItem["examCycleTimeRange"][i]["timeRange"];
- int nTimeRangeSize = jTimeRange.size();
- QStringList sTimeRangeList;
- for(int j = 0; j < nTimeRangeSize; ++j)
- {
- sTimeRangeList<<jTimeRange[j].asString().c_str();
- }
- eci.sExamCycleTimeRange<<sTimeRangeList.join("~");
- }
- //eci.sCourseCode = jExamItem["examCycleTimeRange"].asString().c_str();
- //eci.sCourseCode = jExamItem["examCycleWeek"].asString().c_str();
- eci.nExamId = jExamItem["examId"].asInt64();
- eci.sExamName = jExamItem["examName"].asString().c_str();
- eci.sExamStatus = jExamItem["examStatus"].asString().c_str();
- eci.nExamStudentId = jExamItem["examStudentId"].asInt64();
- eci.bFaceCheck = jExamItem["faceCheck"].asBool();
- eci.bFaceEnable = jExamItem["faceEnable"].asBool();
- eci.sIdentityNumber = jExamItem["identityNumber"].asString().c_str();
- eci.bIsFinished = jExamItem["isFinished"].asBool();
- eci.bIsObjScoreView = jExamItem["isObjScoreView"].asBool();
- eci.bIsPhotoUpload = jExamItem["isPhotoUpload"].asBool();
- eci.nOrgId = jExamItem["orgId"].asInt64();
- eci.sOrgName = jExamItem["orgName"].asString().c_str();
- eci.nPaperMins = jExamItem["paperMins"].asInt();
- eci.nRootOrgId = jExamItem["rootOrgId"].asInt64();
- eci.sSpecialtyLevel = jExamItem["specialtyLevel"].asString().c_str();
- eci.sSpecialtyName = jExamItem["specialtyName"].asString().c_str();
- eci.sStartTime = jExamItem["startTime"].asString().c_str();
- eci.sStudentCode = jExamItem["studentCode"].asString().c_str();
- eci.sStudentName = jExamItem["studentName"].asString().c_str();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genQueryExamList(CQueryExamList *pQueryExamList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pQueryExamList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pQueryExamList->sMessage << sResponse.c_str();
- }
- int nExamSize = jsonRoot.size();
- for (int i = 0; i < nExamSize; ++i)
- {
- Json::Value jExamItem = jsonRoot[i];
- CExamCourseInfo eci;
- genExamCourseInfo(jExamItem, eci);
- pQueryExamList->vOnlieExamList.push_back(eci);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genQueryExamEndList(CQueryExamEndList *pQueryExamEndList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pQueryExamEndList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pQueryExamEndList->sMessage << sResponse.c_str();
- }
- int nExamSize = jsonRoot.size();
- for (int i = 0; i < nExamSize; ++i)
- {
- Json::Value jExamItem = jsonRoot[i];
- CExamCourseInfo eci;
- genExamCourseInfo(jExamItem, eci);
- pQueryExamEndList->vOnlieEndExamList.push_back(eci);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genQueryObjectiveScoreList(CQueryObjectiveScoreList *pQueryObjectiveScoreList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pQueryObjectiveScoreList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pQueryObjectiveScoreList->sMessage << sResponse.c_str();
- }
- int nScoreSize = jsonRoot.size();
- for (int i = 0; i < nScoreSize; ++i)
- {
- Json::Value jScore = jsonRoot[i];
- CObjectiveScore os;
- os.sEndTime = jScore["endTime"].asString().c_str();
- os.nExamOrder = jScore["examOrder"].asInt();
- os.nExamRecordDataId = jScore["examRecordDataId"].asInt64();
- os.bIsAuditing = jScore["isAuditing"].asBool();
- os.bIsExamEnded = jScore["isExamEnded"].asBool();
- os.bIsIllegality = jScore["isIllegality"].asBool();
- os.fObjectiveScore = jScore["objectiveScore"].asDouble();
- os.sStartTime = jScore["startTime"].asString().c_str();
- pQueryObjectiveScoreList->vObjectiveScore.push_back(os);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genQueryHomeworkList(CQueryHomeworkList *pQueryHomeworkList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pQueryHomeworkList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pQueryHomeworkList->sMessage << sResponse.c_str();
- }
- int nExamSize = jsonRoot.size();
- for (int i = 0; i < nExamSize; ++i)
- {
- Json::Value jExamItem = jsonRoot[i];
- CExamCourseInfo eci;
- genExamCourseInfo(jExamItem, eci);
- pQueryHomeworkList->vHomeworkExamList.push_back(eci);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genQueryPracticeCourseList(CQueryPracticeCourseList *pQueryPracticeCourseList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pQueryPracticeCourseList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pQueryPracticeCourseList->sMessage << sResponse.c_str();
- }
- int nExamSize = jsonRoot.size();
- for (int i = 0; i < nExamSize; ++i)
- {
- Json::Value jExamItem = jsonRoot[i];
- CPracticeCourseInfo pci;
- pci.fAveObjectiveAccuracy = jExamItem["aveObjectiveAccuracy"].asDouble();
- pci.sCourseCode = jExamItem["courseCode"].asString().c_str();
- pci.sCourseName = jExamItem["courseName"].asString().c_str();
- pci.sEndTime = jExamItem["endTime"].asString().c_str();
- pci.bExamCycleEnabled = jExamItem["examCycleEnabled"].asBool();
- //pci.sExamCycleTimeRange = jExamItem["examCycleTimeRange"].asDouble();
- //pci.sExamCycleWeek = jExamItem["examCycleWeek"].asDouble();
- int nWeekSize = jExamItem["examCycleWeek"].size();
- for(int i = 0; i < nWeekSize; ++i)
- {
- pci.vExamCycleWeek.push_back(jExamItem["examCycleWeek"][i].asInt());
- }
- int nCycleTimeRangeSize = jExamItem["examCycleTimeRange"].size();
- for(int i = 0; i < nCycleTimeRangeSize; ++i)
- {
- Json::Value jTimeRange = jExamItem["examCycleTimeRange"][i]["timeRange"];
- int nTimeRangeSize = jTimeRange.size();
- QStringList sTimeRangeList;
- for(int j = 0; j < nTimeRangeSize; ++j)
- {
- sTimeRangeList<<jTimeRange[j].asString().c_str();
- }
- pci.sExamCycleTimeRange<<sTimeRangeList.join("~");
- }
- pci.nExamId = jExamItem["examId"].asInt64();
- pci.sExamName = jExamItem["examName"].asString().c_str();
- pci.nExamStudentId = jExamItem["examStudentId"].asInt64();
- pci.sExamType = jExamItem["examType"].asString().c_str();
- pci.fMaxObjectiveAccuracy = jExamItem["maxObjectiveAccuracy"].asDouble();
- pci.nPracticeCount = jExamItem["practiceCount"].asInt();
- pci.fRecentObjectiveAccuracy = jExamItem["recentObjectiveAccuracy"].asDouble();
- pci.sStartTime = jExamItem["startTime"].asString().c_str();
- pci.sStudentCode = jExamItem["studentCode"].asString().c_str();
- pci.sStudentName = jExamItem["studentName"].asString().c_str();
- pQueryPracticeCourseList->vPracticeCourseInfo.push_back(pci);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genQueryPracticeRecordList(CQueryPracticeRecordList *pQueryPracticeRecordList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pQueryPracticeRecordList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pQueryPracticeRecordList->sMessage << sResponse.c_str();
- }
- int nSize = jsonRoot.size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jPracticeItem = jsonRoot[i];
- CPracticeRecord pr;
- pr.sCourseCode = jPracticeItem["courseCode"].asString().c_str();
- pr.sCourseName = jPracticeItem["courseName"].asString().c_str();
- pr.sEndTime = jPracticeItem["endTime"].asString().c_str();
- pr.sExamName = jPracticeItem["examName"].asString().c_str();
- pr.nFailQuestionNum = jPracticeItem["failQuestionNum"].asInt();
- pr.nId = jPracticeItem["id"].asInt64();
- pr.nNotAnsweredCount = jPracticeItem["notAnsweredCount"].asInt();
- pr.fObjectiveAccuracy = jPracticeItem["objectiveAccuracy"].asDouble();
- pr.nObjectiveNum = jPracticeItem["objectiveNum"].asInt();
- pr.sStartTime = jPracticeItem["startTime"].asString().c_str();
- pr.nSuccQuestionNum = jPracticeItem["succQuestionNum"].asInt();
- pr.nTotalQuestionCount = jPracticeItem["totalQuestionCount"].asInt();
- pr.nUsedExamTime = jPracticeItem["usedExamTime"].asInt64();
- pQueryPracticeRecordList->vPracticeRecordList.push_back(pr);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetPracticeDetailInfo(CGetPracticeDetailInfo *pGetPracticeDetailInfo, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetPracticeDetailInfo->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetPracticeDetailInfo->sMessage << sResponse.c_str();
- }
- pGetPracticeDetailInfo->sCourseCode = jsonRoot["courseCode"].asString().c_str();
- pGetPracticeDetailInfo->sCourseName = jsonRoot["courseName"].asString().c_str();
- pGetPracticeDetailInfo->nId = jsonRoot["id"].asInt64();
- pGetPracticeDetailInfo->fObjectiveAccuracy = jsonRoot["objectiveAccuracy"].asDouble();
- int nSize = jsonRoot["paperStructInfos"].size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jPaperStructInfo = jsonRoot["paperStructInfos"][i];
- CPracticePaperStructInfo ppsi;
- ppsi.nCount = jPaperStructInfo["count"].asInt();
- ppsi.nFailQuestionNum = jPaperStructInfo["failQuestionNum"].asInt();
- ppsi.nIndex = jPaperStructInfo["index"].asInt();
- ppsi.nNotAnsweredCount = jPaperStructInfo["notAnsweredCount"].asInt();
- ppsi.nQuestionCount = jPaperStructInfo["questionCount"].asInt();
- ppsi.sQuestionType = jPaperStructInfo["questionType"].asString().c_str();
- ppsi.sScore = jPaperStructInfo["score"].asString().c_str();
- ppsi.nSuccQuestionNum = jPaperStructInfo["succQuestionNum"].asInt();
- ppsi.sTitle = jPaperStructInfo["title"].asString().c_str();
- ppsi.fTotalScore = jPaperStructInfo["totalScore"].asDouble();
- pGetPracticeDetailInfo->vPracticePaperStructList.push_back(ppsi);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genFindExamRecordDataEntity(CFindExamRecordDataEntity *pFindExamRecordDataEntity, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pFindExamRecordDataEntity->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pFindExamRecordDataEntity->sMessage << sResponse.c_str();
- }
- pFindExamRecordDataEntity->nExamId = jsonRoot["examRecord"]["examId"].asInt64();
- pFindExamRecordDataEntity->sPaperType = jsonRoot["examRecord"]["paperType"].asString().c_str();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetExamRecordQuestions(CGetExamRecordQuestions *pGetExamRecordQuestions, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetExamRecordQuestions->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetExamRecordQuestions->sMessage << sResponse.c_str();
- }
- int nSize = jsonRoot["examQuestionEntities"].size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jQuestionItem = jsonRoot["examQuestionEntities"][i];
- CAnsweredQuestion aq;
- aq.sAnswerType = jQuestionItem["answerType"].asString().c_str();
- aq.sAudioPlayTimes = jQuestionItem["audioPlayTimes"].isNull() ? "" : jQuestionItem["audioPlayTimes"].asString().c_str();
- aq.sCorrectAnswer = jQuestionItem["correctAnswer"].isNull() ? "" : jQuestionItem["correctAnswer"].asString().c_str();
- //aq.sExamQuestionTempId = jQuestionItem["examQuestionTempId"].asString().c_str();
- aq.nExamRecordDataId = jQuestionItem["examRecordDataId"].asInt64();
- aq.bIsAnswer = jQuestionItem["isAnswer"].asBool();
- //aq.bIsInMongo = jQuestionItem["isInMongo"].asBool();
- aq.bIsSign = jQuestionItem["isSign"].asBool();
- aq.nMainNumber = jQuestionItem["mainNumber"].asInt();
- int nOptionSize = jQuestionItem["optionPermutation"].size();
- for (int j = 0; j < nOptionSize; ++j)
- {
- aq.vOptionPermutation.push_back(jQuestionItem["optionPermutation"][i].asInt());
- }
- aq.nOrder = jQuestionItem["order"].asInt();
- aq.sQuestionId = jQuestionItem["questionId"].asString().c_str();
- aq.fQuestionScore = jQuestionItem["questionScore"].asDouble();
- aq.sQuestionType = jQuestionItem["questionType"].asString().c_str();
- aq.sStudentAnswer = jQuestionItem["studentAnswer"].asString().c_str();
- aq.fStudentScore = jQuestionItem["studentScore"].asDouble();
- pGetExamRecordQuestions->vExamRecordQuestions.push_back(aq);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetOfflineCourse(CGetOfflineCourse *pGetOfflineCourse, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetOfflineCourse->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetOfflineCourse->sMessage << sResponse.c_str();
- }
- int nSize = jsonRoot.size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jCourseInfo = jsonRoot[i];
- COfflineCourseInfo oci;
- oci.sCourseCode = jCourseInfo["courseCode"].asString().c_str();
- oci.sCourseLevel = jCourseInfo["courseLevel"].asString().c_str();
- oci.sCourseName = jCourseInfo["courseName"].asString().c_str();
- oci.sEndTime = jCourseInfo["endTime"].asString().c_str();
- oci.nExamId = jCourseInfo["examId"].asInt64();
- oci.sExamName = jCourseInfo["examName"].asString().c_str();
- oci.nExamRecordDataId = jCourseInfo["examRecordDataId"].asInt64();
- oci.nExamStudentId = jCourseInfo["examStudentId"].asInt64();
- oci.bIsvalid = jCourseInfo["isvalid"].asBool();
- oci.sOrgName = jCourseInfo["orgName"].asString().c_str();
- oci.sPaperId = jCourseInfo["paperId"].asString().c_str();
- oci.sSpecialtyName = jCourseInfo["specialtyName"].asString().c_str();
- oci.sStartTime = jCourseInfo["startTime"].asString().c_str();
- oci.sStatus = jCourseInfo["status"].asString().c_str();
- oci.sStudentCode = jCourseInfo["studentCode"].asString().c_str();
- oci.sStudentName = jCourseInfo["studentName"].asString().c_str();
- int nFileSize = jCourseInfo["offlineFiles"].size();
- for (int j = 0; j < nFileSize; ++j)
- {
- Json::Value jFileItem = jCourseInfo["offlineFiles"][j];
- COfflineFileInfo ofi;
- ofi.nExamRecordDataId = jFileItem["examRecordDataId"].asInt64();
- ofi.sFileType = jFileItem["fileType"].asString().c_str();
- ofi.nId = jFileItem["id"].asInt64();
- ofi.sOfflineFileName = jFileItem["offlineFileName"].asString().c_str();
- ofi.sOfflineFileUrl = jFileItem["offlineFileUrl"].asString().c_str();
- ofi.sOriginalFileName = jFileItem["originalFileName"].asString().c_str();
- ofi.sProperties = jFileItem["properties"].asString().c_str();
- ofi.sSuffix = jFileItem["suffix"].asString().c_str();
- oci.vOfflineFileInfo.push_back(ofi);
- }
- pGetOfflineCourse->vOfflineCourseInfo.push_back(oci);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetOffLineExamAnswerSheet(CGetOffLineExamAnswerSheet *pGetOffLineExamAnswerSheet, const std::string &sResponse)
- {
- pGetOffLineExamAnswerSheet->sAnswerSheetUrl = sResponse.c_str();
- }
- void CHttpBll::genGetOffLineExamPaper(CGetOffLineExamPaper *pGetOffLineExamPaper, const std::string &sResponse)
- {
-
- }
- void CHttpBll::genPreviewOffLineExamPaper(CPreviewOffLineExamPaper *pPreviewOffLineExamPaper, const std::string &sResponse)
- {
- pPreviewOffLineExamPaper->sUrl = sResponse.c_str();
- }
- void CHttpBll::genCheckExamInProgress(CCheckExamInProgress *pCheckExamInProgress, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pCheckExamInProgress->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pCheckExamInProgress->sMessage << sResponse.c_str();
- }
- if (jsonRoot["data"].isNull())
- {
- pCheckExamInProgress->bHasExamInProgress = false;
- }
- else
- {
- pCheckExamInProgress->bHasExamInProgress = true;
- pCheckExamInProgress->nInterruptNum = jsonRoot["data"]["interruptNum"].asInt();
- pCheckExamInProgress->nMaxInterruptNum = jsonRoot["data"]["maxInterruptNum"].asInt();
- pCheckExamInProgress->bIsExceed = jsonRoot["data"]["isExceed"].asBool();
- pCheckExamInProgress->nExamRecordDataId = jsonRoot["data"]["examRecordDataId"].asInt64();
- pCheckExamInProgress->nExamId = jsonRoot["data"]["examId"].asInt64();
- pCheckExamInProgress->nUsedTime = jsonRoot["data"]["usedTime"].asInt64();
- pCheckExamInProgress->nFaceVerifyMinute = jsonRoot["data"]["faceVerifyMinute"].asInt();
- pCheckExamInProgress->sExamType = jsonRoot["data"]["examType"].asString().c_str();
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetCourseInfo(CGetCourseInfo *pGetCourseInfo, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetCourseInfo->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetCourseInfo->sMessage << sResponse.c_str();
- }
- pGetCourseInfo->sCourseName = jsonRoot["courseName"].asString().c_str();
- pGetCourseInfo->sCourseCode = jsonRoot["courseCode"].asString().c_str();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genExamHeartbeat(CExamHeartbeat *pExamHeartbeat, const std::string &sResponse)
- {
- pExamHeartbeat->nLeftTime = QString(sResponse.c_str()).toLongLong();
- }
- void CHttpBll::genFindExamQuestionList(CFindExamQuestionList *pFindExamQuestionList, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pFindExamQuestionList->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pFindExamQuestionList->sMessage << sResponse.c_str();
- }
- int nSize = jsonRoot.size();
- for (int i = 0; i < nSize; ++i)
- {
- Json::Value jQuestionItem = jsonRoot[i];
- CAnsweredQuestion aq;
- aq.sAnswerType = jQuestionItem["answerType"].asString().c_str();
- aq.sAudioPlayTimes = jQuestionItem["audioPlayTimes"].isNull() ? "" :jQuestionItem["audioPlayTimes"].asString().c_str();
- aq.sCorrectAnswer = jQuestionItem["correctAnswer"].isNull() ? "" : jQuestionItem["correctAnswer"].asString().c_str();
- aq.sExamQuestionTempId = jQuestionItem["examQuestionTempId"].asString().c_str();
- aq.nExamRecordDataId = jQuestionItem["examRecordDataId"].asInt64();
- aq.bIsAnswer = jQuestionItem["isAnswer"].asBool();
- aq.bIsInMongo = jQuestionItem["isInMongo"].asBool();
- aq.bIsSign = jQuestionItem["isSign"].asBool();
- aq.nMainNumber = jQuestionItem["mainNumber"].asInt();
- int nOptionSize = jQuestionItem["optionPermutation"].size();
- for (int j = 0; j < nOptionSize; ++j)
- {
- aq.vOptionPermutation.push_back(jQuestionItem["optionPermutation"][i].asInt());
- }
- aq.nOrder = jQuestionItem["order"].asInt();
- aq.sQuestionId = jQuestionItem["questionId"].asString().c_str();
- aq.fQuestionScore = jQuestionItem["questionScore"].asDouble();
- aq.sQuestionType = jQuestionItem["questionType"].asString().c_str();
- aq.sStudentAnswer = jQuestionItem["studentAnswer"].asString().c_str();
- aq.fStudentScore = jQuestionItem["studentScore"].asDouble();
- pFindExamQuestionList->vAnsweredQuestion.push_back(aq);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetExamRecordPaperStruct(CGetExamRecordPaperStruct *pGetExamRecordPaperStruct, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetExamRecordPaperStruct->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetExamRecordPaperStruct->sMessage << sResponse.c_str();
- }
- pGetExamRecordPaperStruct->sPaperId = jsonRoot["id"].asString().c_str();
- pGetExamRecordPaperStruct->sPaperName = jsonRoot["defaultPaper"]["name"].asString().c_str();
- pGetExamRecordPaperStruct->bFullyObjective = jsonRoot["defaultPaper"]["fullyObjective"].asBool();
- int nGroupSize = jsonRoot["defaultPaper"]["questionGroupList"].size();
- int nOrder = 1;
- for (int i = 0; i < nGroupSize; ++i)
- {
- Json::Value jGroupItem = jsonRoot["defaultPaper"]["questionGroupList"][i];
- CPaperGroupStruct pgs;
- pgs.sGroupName = jGroupItem["groupName"].asString().c_str();
- pgs.fGroupScore = jGroupItem["groupScore"].asDouble();
- pgs.nNumber = i + 1;
- int nQuestionSize = jGroupItem["questionWrapperList"].size();
- int nShowIndex = 1;
- int nTotalSubquestion = 0;
- for (int j = 0; j < nQuestionSize; ++j)
- {
- Json::Value jQuestionItem = jGroupItem["questionWrapperList"][j];
- CQuestionStruct qs;
- qs.sQuestionId = jQuestionItem["questionId"].asString().c_str();
- qs.sVersion = jQuestionItem["version"].asString().c_str();
- qs.fQuestionScore = jQuestionItem["questionScore"].asDouble();
- qs.nLimitedPlayTimes = jQuestionItem["limitedPlayTimes"].asInt();
- qs.nPlayedTimes = jQuestionItem["playedTimes"].asInt();
- qs.nTimeLimit = jQuestionItem["timeLimit"].asInt();
- int mSubQuestionSize = jQuestionItem["questionUnitWrapperList"].size();
- nTotalSubquestion += mSubQuestionSize;
- for (int k = 0; k < mSubQuestionSize; ++k)
- {
- Json::Value jSubQuestionItem = jQuestionItem["questionUnitWrapperList"][k];
- CSubQuestionStruct sqs;
- sqs.sQuestionType = jSubQuestionItem["questionType"].asString().c_str();
- sqs.sAnswerType = jSubQuestionItem["answerType"].asString().c_str();
- sqs.fQuestionScore = jSubQuestionItem["questionScore"].asDouble();
- sqs.nLimitedPlayTimes = qs.nLimitedPlayTimes;
- for (int jq = 0; jq < jSubQuestionItem["optionPermutation"].size(); ++jq)
- {
- Json::Value Item = jSubQuestionItem["optionPermutation"][jq];
- sqs.voptionPermutation.push_back(Item.asInt());
- }
- sqs.nShowNumber = nShowIndex;
- sqs.nOrder = nOrder;
- nShowIndex++;
- nOrder++;
- qs.vSubQuestionStruct.push_back(sqs);
- }
- pgs.vQuestionStruct.push_back(qs);
- }
- pgs.nTotalSubquestion = nTotalSubquestion;
- pGetExamRecordPaperStruct->vPaperGroupStruct.push_back(pgs);
- }
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetEndExamInfo(CGetEndExamInfo *pGetEndExamInfo, const std::string &sResponse)
- {
- try
- {
- if (sResponse == "")
- {
- pGetEndExamInfo->bIsCalculate = true;
- return;
- }
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pGetEndExamInfo->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pGetEndExamInfo->sMessage << sResponse.c_str();
- }
- pGetEndExamInfo->nExamRecordDataId = jsonRoot["examRecordDataId"].asInt64();
- pGetEndExamInfo->bIsWarn = jsonRoot["isWarn"].asBool();
- pGetEndExamInfo->fObjectiveAccuracy = jsonRoot["objectiveAccuracy"].asDouble();
- pGetEndExamInfo->fObjectiveScore = jsonRoot["objectiveScore"].asInt64();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
-
- }
- void CHttpBll::genGetWXQrCode(CGetWXQrCode *pGetWXQrCode, const std::string &sResponse)
- {
- pGetWXQrCode->sUrl = sResponse.c_str();
- }
- void CHttpBll::genProcessUpload(CProcessUpload *pProcessUpload, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pProcessUpload->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pProcessUpload->sMessage << sResponse.c_str();
- }
- pProcessUpload->sFileUrl = jsonRoot["fileUrl"].asString().c_str();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genGetOrgPropertiesByGroupWithoutCache(CGetOrgPropertiesByGroupWithoutCache *pOrgProperties, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pOrgProperties->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pOrgProperties->sMessage << sResponse.c_str();
- }
- pOrgProperties->nActionNum = QVariant(jsonRoot["ACTION_NUM"].asString().c_str()).toInt();
- pOrgProperties->sActionOptions = jsonRoot["ACTION_OPTIONS"].asString().c_str();
- pOrgProperties->sActionOrder = jsonRoot["ACTION_ORDER"].asString().c_str();
- pOrgProperties->nActionDuration = QVariant(jsonRoot["ACTION_DURATION"].asString().c_str()).toInt();
- pOrgProperties->nActionAlert = QVariant(jsonRoot["ACTION_ALERT"].asString().c_str()).toInt();
- pOrgProperties->nAllActionDuration = QVariant(jsonRoot["ALL_ACTION_DURATION"].asString().c_str()).toInt();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
- void CHttpBll::genStartFaceLiveVerify(CStartFaceLiveVerify *pStartFaceLiveVerify, const std::string &sResponse)
- {
- try
- {
- Json::Reader reader;
- Json::Value jsonRoot = Json::Value::null;
- if (!reader.parse(sResponse, jsonRoot))
- {
- pStartFaceLiveVerify->sMessage = QString::fromLocal8Bit("解析后台返回环境信息json异常!");
- myDebug() << pStartFaceLiveVerify->sMessage << sResponse.c_str();
- }
- pStartFaceLiveVerify->nFaceLiveVerifyId = jsonRoot["faceLiveVerifyId"].asInt64();
- pStartFaceLiveVerify->nStartMinute = jsonRoot["startMinute"].asInt();
- pStartFaceLiveVerify->nTimes = jsonRoot["times"].asInt();
- }
- catch (const std::exception &e)
- {
- myServerLog()<<sResponse.c_str()<<",exception error"<<e.what();
- }
- }
|