pbl.js 186 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105
  1. // ROUTES FOR OUR API
  2. // =============================================================================
  3. var express = require("express");
  4. var request = require("request");
  5. var bcrypt = require("bcryptjs");
  6. var router = express.Router(); // get an instance of the express Router
  7. const querystring = require("querystring");
  8. var mysql = require("./mysql");
  9. // const _mysqlLabor = ["123.58.32.151", "pbl"]; //edu數據庫信息
  10. // const _mysqluser = ["123.58.32.151", "cocorobouser"]; //用户数据库信息
  11. const _mysqlLabor = ["172.16.12.5", "pbl"]; //edu數據庫信息
  12. const _mysqluser = ["172.16.12.5", "cocorobouser"]; //edu數據庫信息
  13. var crypto = require("crypto");
  14. var https = require("https");
  15. //統壹處理區域
  16. router.use(async function(req, res, next) {
  17. await asynnext(req, res, next);
  18. //// make sure we go to the next routes and don't stop here
  19. //res.end("");
  20. });
  21. /**
  22. * @des 參數解釋同上
  23. */
  24. function asynnext(req, res, next) {
  25. //異步處理
  26. return new Promise(async(resolve, reject) => {
  27. next();
  28. //resolve(true);aa
  29. });
  30. }
  31. /*測試*/
  32. router.route("/a").all((req, res, next) => {
  33. var json = queryString(req.url);
  34. getmysql(req, res, "a", json["ph"], json["pa"]);
  35. });
  36. router.route("/b").all((req, res, next) => {
  37. var json = queryString(req.url);
  38. getmysql(req, res, "b", json["ph"], json["pa"]);
  39. });
  40. /* 注册接口 */
  41. router.route("/register").post(function(req, res, next) {
  42. //mode的处理
  43. if (req.body[0]) {
  44. // 0 用户名 1 用户密码 2用户身份 3 第三方id(可有可无)
  45. p = Object.values(req.body[0]); //获取用户密码
  46. //没有第三方id的处理
  47. // if (p.length < 4) {
  48. // p.push("")
  49. // }
  50. p[1] = bcrypt.hashSync(p[1], bcrypt.genSaltSync(10));
  51. //密码加密
  52. // bcrypt.hash(p[1], 10, function (err, hash) {
  53. // if (err) {
  54. // return next(err);
  55. // }
  56. // p[1] = hash;
  57. // });
  58. //参数拼接,注册
  59. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "register");
  60. //返回注册用户数据
  61. // mysql.usselect(p, function (ret) {
  62. // res.end(ret);
  63. // });
  64. mysql.usselect(p, function(ret) {
  65. res.end(JSON.stringify(ret));
  66. });
  67. }
  68. });
  69. /*登录接口*/
  70. router.route("/login").all((req, res, next) => {
  71. //mode的处理
  72. if (req.body[0]) {
  73. // 0 用户名 1 用户密码
  74. c = Object.values(req.body[0]); //获取用户密码
  75. p = [c[0]];
  76. // p[1] = bcrypt.hashSync(p[1], bcrypt.genSaltSync(10));
  77. var _password = [c[0]];
  78. _password.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectPassword");
  79. mysql.usselect(_password, function(ret) {
  80. var _ret = ret;
  81. var paJ = _ret[0][0].userpassword;
  82. bcrypt.compare(c[1], paJ, function(err, result) {
  83. // console.log(result)
  84. if (result) {
  85. //参数拼接,登录
  86. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectLogin");
  87. //执行存储过程
  88. mysql.usselect(p, function(ret) {
  89. res.end(JSON.stringify({ status: "1", ...ret }));
  90. });
  91. } else {
  92. res.end(JSON.stringify([{ status: "0" }]));
  93. }
  94. });
  95. });
  96. // console.log(isEqual)
  97. }
  98. });
  99. /*手机登录接口*/
  100. router.route("/phoneLogin").all((req, res, next) => {
  101. //mode的处理
  102. if (req.body[0]) {
  103. // 0 用户名 1 用户密码
  104. c = Object.values(req.body[0]); //获取用户密码
  105. p = [c[0]];
  106. // p[1] = bcrypt.hashSync(p[1], bcrypt.genSaltSync(10));
  107. var _password = [c[0]];
  108. _password.unshift(_mysqluser[0], _mysqluser[1], "selectPassword");
  109. mysql.usselect(_password, function(ret) {
  110. if (ret[0].length) {
  111. var _ret = ret;
  112. var paJ = _ret[0][0].password;
  113. let uid = _ret[0][0].userid;
  114. let duid = [uid];
  115. bcrypt.compare(c[1], paJ, function(err, result) {
  116. // console.log(result)
  117. if (result) {
  118. //参数拼接,登录
  119. duid.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectUser");
  120. //执行存储过程
  121. mysql.usselect(duid, function(ret) {
  122. res.end(JSON.stringify({ status: "1", ...ret }));
  123. });
  124. } else {
  125. res.end(JSON.stringify([{ status: "0" }]));
  126. }
  127. });
  128. } else {
  129. res.end(JSON.stringify([{ status: "0" }]));
  130. }
  131. });
  132. // console.log(isEqual)
  133. }
  134. });
  135. // 图片转base64
  136. router.route("/imgToBase64").all((req, res, next) => {
  137. var json = queryString(req.url);
  138. //mode的处理
  139. https.get(json["img"], function(res2) {
  140. var chunks = [];
  141. var size = 0;
  142. res2.on("data", function(chunk) {
  143. chunks.push(chunk);
  144. size += chunk.length; //累加缓冲数据的长度
  145. });
  146. res2.on("end", function(err) {
  147. var data = Buffer.concat(chunks, size);
  148. var base64Img = data.toString("base64");
  149. res.end(JSON.stringify([{ img: `data:image/png;base64,${base64Img}` }]));
  150. });
  151. });
  152. });
  153. router.route("/download").all(async(req, res, next) => {
  154. var json = queryString(req.url);
  155. // 查询文件名和下载链接
  156. const fileName = json["name"];
  157. const link = json["url"];
  158. // 发送下载请求
  159. request.get(link, (err, response) => {
  160. if (err) {
  161. res.status(500).end("Internal Server Error");
  162. return;
  163. }
  164. https.get(link, function(res2) {
  165. var chunks = [];
  166. var size = 0;
  167. res2.on("data", function(chunk) {
  168. chunks.push(chunk);
  169. size += chunk.length; //累加缓冲数据的长度
  170. });
  171. res2.on("end", function(err) {
  172. var data = Buffer.concat(chunks, size);
  173. var base64Img = data.toString("base64");
  174. res.end(JSON.stringify({ response, data }));
  175. });
  176. });
  177. });
  178. });
  179. /*登录接口*/
  180. router.route("/loginRace").all((req, res, next) => {
  181. //mode的处理
  182. if (req.body[0]) {
  183. // 0 用户名 1 用户密码
  184. c = Object.values(req.body[0]); //获取用户密码
  185. p = [c[0]];
  186. // p[1] = bcrypt.hashSync(p[1], bcrypt.genSaltSync(10));
  187. var _password = [c[0]];
  188. _password.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectPasswordRace");
  189. mysql.usselect(_password, function(ret) {
  190. var _ret = ret;
  191. var paJ = _ret[0][0].password;
  192. bcrypt.compare(c[1], paJ, function(err, result) {
  193. // console.log(result)
  194. if (result) {
  195. //参数拼接,登录
  196. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectLoginRace");
  197. //执行存储过程
  198. mysql.usselect(p, function(ret) {
  199. res.end(JSON.stringify({ status: "1", ...ret }));
  200. });
  201. } else {
  202. res.end(JSON.stringify([{ status: "0" }]));
  203. }
  204. });
  205. });
  206. // console.log(isEqual)
  207. }
  208. });
  209. /* 修改密码接口 */
  210. router.route("/updatePassword").post(function(req, res, next) {
  211. //mode的处理
  212. if (req.body[0]) {
  213. let p = [req.body[0].userid];
  214. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "getPassword"); //執行存儲過程
  215. mysql.usselect(p, function(ret) {
  216. var paJ = ret[0][0].password;
  217. var op = bcrypt.hashSync(req.body[0].opassword, bcrypt.genSaltSync(10));
  218. bcrypt.compare(req.body[0].opassword, paJ, function(err, result) {
  219. // console.log(result)
  220. if (result) {
  221. let p2 = [
  222. req.body[0].userid,
  223. bcrypt.hashSync(req.body[0].password, bcrypt.genSaltSync(10)),
  224. ];
  225. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updatePassword"); //執行存儲過程
  226. mysql.usselect(p2, function(ret) {
  227. res.end(JSON.stringify([{ success: 1 }]));
  228. });
  229. } else {
  230. res.end(JSON.stringify([{ success: 0 }]));
  231. }
  232. });
  233. });
  234. }
  235. });
  236. /* 赛事修改密码 */
  237. router.route("/updatePassword1").post(function(req, res, next) {
  238. //mode的处理
  239. if (req.body[0]) {
  240. let p = [req.body[0].userid];
  241. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "getPassword1"); //執行存儲過程
  242. mysql.usselect(p, function(ret) {
  243. var paJ = ret[0][0].password;
  244. var op = bcrypt.hashSync(req.body[0].opassword, bcrypt.genSaltSync(10));
  245. bcrypt.compare(req.body[0].opassword, paJ, function(err, result) {
  246. // console.log(result)
  247. if (result) {
  248. let p2 = [
  249. req.body[0].userid,
  250. bcrypt.hashSync(req.body[0].password, bcrypt.genSaltSync(10)),
  251. ];
  252. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updatePassword1"); //執行存儲過程
  253. mysql.usselect(p2, function(ret) {
  254. res.end(JSON.stringify([{ success: 1 }]));
  255. });
  256. } else {
  257. res.end(JSON.stringify([{ success: 0 }]));
  258. }
  259. });
  260. });
  261. }
  262. });
  263. /* 找寻重复手机号 */
  264. router.route("/findPhone").all((req, res, next) => {
  265. var json = queryString(req.url);
  266. getmysql(req, res, "findPhone", json["un"]);
  267. });
  268. /* 找寻是否有此账号 */
  269. router.route("/findUsername").all((req, res, next) => {
  270. var json = queryString(req.url);
  271. getmysql(req, res, "findUsername", json["un"]);
  272. });
  273. /* 找寻重复邮箱 */
  274. router.route("/findMail").all((req, res, next) => {
  275. var json = queryString(req.url);
  276. usergetmysql(req, res, "findMail", json["un"]);
  277. });
  278. /* 找寻重复学号 */
  279. router.route("/findSid").all((req, res, next) => {
  280. var json = queryString(req.url);
  281. getmysql(req, res, "findSid", json["un"]);
  282. });
  283. /* 新增班级 */
  284. router.route("/insertClass").all((req, res, next) => {
  285. var json = queryString(req.url);
  286. getmysql(req, res, "insertClass", json["name"], json["oid"], json["uid"]);
  287. });
  288. /* 新增教研室 */
  289. router.route("/insertTeacherOffice").all((req, res, next) => {
  290. var json = queryString(req.url);
  291. getmysql(req, res, "insertTeacherOffice", json["name"], json["oid"], json["uid"]);
  292. });
  293. /* 新增年级 */
  294. router.route("/insertGrade").all((req, res, next) => {
  295. var json = queryString(req.url);
  296. getmysql(req, res, "insertGrade", json["name"], json["oid"], json["uid"]);
  297. });
  298. /* 修改班级 */
  299. router.route("/updateClass").all((req, res, next) => {
  300. var json = queryString(req.url);
  301. getmysql(req, res, "updateClass", json["id"], json["n"], json["oid"]);
  302. });
  303. // 修改教研室
  304. router.route("/updateTeacherOffice").all((req, res, next) => {
  305. var json = queryString(req.url);
  306. getmysql(req, res, "updateTeacherOffice", json["id"], json["n"], json["oid"]);
  307. });
  308. /* 修改年级 */
  309. router.route("/updateGrade").all((req, res, next) => {
  310. var json = queryString(req.url);
  311. getmysql(req, res, "updateGrade", json["id"], json["n"], json["oid"]);
  312. });
  313. /* 查询班级 */
  314. router.route("/selectClass").all((req, res, next) => {
  315. var json = queryString(req.url);
  316. getmysql(req, res, "selectClass", json["cu"], json["oid"], json["cn"], json["page"], 10);
  317. });
  318. // 教研室查询
  319. router.route("/selectTeacherOffice").all((req, res, next) => {
  320. var json = queryString(req.url);
  321. getmysql(req, res, "selectTeacherOffice", json["cu"], json["oid"], json["cn"], json["page"], 10);
  322. });
  323. /* 查询班级 */
  324. router.route("/selectClass2").all((req, res, next) => {
  325. var json = queryString(req.url);
  326. getmysql(req, res, "selectClass2", json["cid"], json["oid"], json["cn"], json["page"], 10);
  327. });
  328. /* 查询年级 */
  329. router.route("/selectGrade").all((req, res, next) => {
  330. var json = queryString(req.url);
  331. getmysql(req, res, "selectGrade", json["cu"], json["oid"], json["cn"], json["page"], 10);
  332. });
  333. /* 删除班级 */
  334. router.route("/deleteClass").all((req, res, next) => {
  335. var json = queryString(req.url);
  336. getmysql(req, res, "deleteClass", json["id"]);
  337. });
  338. /* 删除年级 */
  339. router.route("/deleteGrade").all((req, res, next) => {
  340. var json = queryString(req.url);
  341. getmysql(req, res, "deleteGrade", json["id"]);
  342. });
  343. /* 查询学校 */
  344. router.route("/selectOrg").all((req, res, next) => {
  345. var json = queryString(req.url);
  346. getmysql(req, res, "selectOrg");
  347. });
  348. /* 查询组织 */
  349. router.route("/selectorg2").all((req, res, next) => {
  350. var json = queryString(req.url);
  351. getmysql(req, res, "selectorg2");
  352. });
  353. /* 修改学校名称 */
  354. router.route("/updateSN").all((req, res, next) => {
  355. var json = queryString(req.url);
  356. getmysql(req, res, "updateSchoolName", json["oid"], json["n"]);
  357. });
  358. /* 教师端修改学校名称 */
  359. router.route("/updateSchoolByOrg").all((req, res, next) => {
  360. var json = queryString(req.url);
  361. getmysql(req, res, "updateSchoolByOrg", json["n"], json["d"], json["id"]);
  362. });
  363. /* 教师端查询未联结学校 */
  364. router.route("/selectNoCSchool").all((req, res, next) => {
  365. var json = queryString(req.url);
  366. getmysql(req, res, "selectNoCSchool");
  367. });
  368. /* 教师端新增或修改联结学校 */
  369. router.route("/addNoSchool").all((req, res, next) => {
  370. var json = queryString(req.url);
  371. getmysql(req, res, "addNoSchool", json["id"], json["coid"]);
  372. });
  373. /* 新增学生 */
  374. router.route("/insertStudent").all((req, res, next) => {
  375. var json = queryString(req.url);
  376. json["userpassword"] = bcrypt.hashSync(
  377. json["userpassword"],
  378. bcrypt.genSaltSync(10)
  379. );
  380. getmysql(
  381. req,
  382. res,
  383. "insertStudent",
  384. json["ph"],
  385. json["username"],
  386. json["userpassword"],
  387. json["type"],
  388. json["oid"],
  389. json["tid"],
  390. json["cid"]
  391. );
  392. });
  393. // /* 新增学生 */
  394. // router.route('/iStudent').all((req, res, next) => {
  395. // var json = queryString(req.url);
  396. // json['userpassword'] = bcrypt.hashSync(json['userpassword'], bcrypt.genSaltSync(10))
  397. // getmysql(req, res, "insertStudent", json['ph'], json['username'], json['userpassword'], json['type'], json['oid'], json['tid'], json['cid']);
  398. // });
  399. /* 查询学生 */
  400. router.route("/selectStudent").all((req, res, next) => {
  401. var json = queryString(req.url);
  402. getmysql(
  403. req,
  404. res,
  405. "selectStudent",
  406. json["oid"],
  407. json["cu"],
  408. json["cn"],
  409. json["page"],
  410. 10
  411. );
  412. });
  413. /* ppt根据学校查询学生 */
  414. router.route("/selectStudentByScoolPPt").all((req, res, next) => {
  415. var json = queryString(req.url);
  416. getmysql(req, res, "selectStudentByScoolPPt", json["oid"], json["cid"]);
  417. });
  418. /* 查询学校底下的所有学生 */
  419. router.route("/selectOrgStu").all((req, res, next) => {
  420. var json = queryString(req.url);
  421. getmysql(req, res, "selectOrgStu", json["oid"]);
  422. });
  423. /* 查询学生 */
  424. router.route("/selectStudentAdd").all((req, res, next) => {
  425. var json = queryString(req.url);
  426. getmysql(req, res, "selectStudentAdd", json["oid"], json["cu"], json["cn"]);
  427. });
  428. /* 查询老师 */
  429. router.route("/selectTeacherAdd").all((req, res, next) => {
  430. var json = queryString(req.url);
  431. getmysql(req, res, "selectTeacherAdd", json["oid"], json["cu"], json["cn"]);
  432. });
  433. /* 查询老师 */
  434. router.route("/selectTeacherAddOrg").all((req, res, next) => {
  435. var json = queryString(req.url);
  436. getmysql(
  437. req,
  438. res,
  439. "selectTeacherAddOrg",
  440. json["oid"],
  441. json["cu"],
  442. json["cn"]
  443. );
  444. });
  445. /* 查询学生 */
  446. router.route("/selectStudentAddOrg").all((req, res, next) => {
  447. var json = queryString(req.url);
  448. getmysql(
  449. req,
  450. res,
  451. "selectStudentAddOrg",
  452. json["oid"],
  453. json["cu"],
  454. json["cn"]
  455. );
  456. });
  457. /* 查询全部用户 */
  458. router.route("/selectUserAddOrg").all((req, res, next) => {
  459. var json = queryString(req.url);
  460. getmysql(req, res, "selectUserAddOrg", json["oid"], json["cu"], json["cn"]);
  461. });
  462. /* 查询全部用户 */
  463. router.route("/selectUserAdd").all((req, res, next) => {
  464. var json = queryString(req.url);
  465. getmysql(req, res, "selectUserAdd", json["oid"], json["cu"], json["cn"]);
  466. });
  467. /* 查询全部用户 */
  468. router.route("/selectUserByOidS").all((req, res, next) => {
  469. var json = queryString(req.url);
  470. getmysql(
  471. req,
  472. res,
  473. "selectUserByOidS",
  474. json["oid"],
  475. json["org"],
  476. json["cu"],
  477. json["cn"]
  478. );
  479. });
  480. /* 查询全部用户 */
  481. router.route("/selectUserByOidS2").all((req, res, next) => {
  482. var json = queryString(req.url);
  483. getmysql(
  484. req,
  485. res,
  486. "selectUserByOidS2",
  487. json["oid"],
  488. json["org"],
  489. json["cu"],
  490. json["cn"],
  491. json["page"],
  492. json["pageSize"]
  493. );
  494. });
  495. /* 查询全部用户 */
  496. router.route("/selectUserByOidS2Studio").all((req, res, next) => {
  497. var json = queryString(req.url);
  498. getmysql(
  499. req,
  500. res,
  501. "selectUserByOidS2Studio",
  502. json["oid"],
  503. json["org"],
  504. json["cu"],
  505. json["cn"],
  506. json["page"],
  507. json["pageSize"]
  508. );
  509. });
  510. /* 查询班级是否有重复 */
  511. router.route("/selectC").all((req, res, next) => {
  512. var json = queryString(req.url);
  513. getmysql(req, res, "selectC", json["className"]);
  514. });
  515. /* 查询学校是否有重复 */
  516. router.route("/selectS").all((req, res, next) => {
  517. var json = queryString(req.url);
  518. getmysql(req, res, "selectS", json["schoolName"]);
  519. });
  520. /* 修改个人信息 */
  521. router.route("/updateUser").all((req, res, next) => {
  522. postmysql(req, res, "updateUser");
  523. });
  524. //查询老师的信息
  525. router.route("/getUser").all((req, res, next) => {
  526. var json = queryString(req.url);
  527. getmysql(req, res, "selectUserDeail", json["uid"]);
  528. });
  529. //查询老师的信息
  530. router.route("/getRaceUser").all((req, res, next) => {
  531. var json = queryString(req.url);
  532. getmysql(req, res, "getRaceUser", json["uid"]);
  533. });
  534. router.route("/selectUser").all((req, res, next) => {
  535. var json = queryString(req.url);
  536. getmysql(req, res, "selectUser", json["userid"]);
  537. });
  538. //查询教师端消息
  539. router.route("/getNewsTeacher").all((req, res, next) => {
  540. var json = queryString(req.url);
  541. getmysql(req, res, "selectNew", json["uid"], json["page"], 10);
  542. });
  543. //查询教师端消息
  544. router.route("/selectNotice").all((req, res, next) => {
  545. var json = queryString(req.url);
  546. getmysql(
  547. req,
  548. res,
  549. "selectNotice",
  550. json["uid"],
  551. json["oid"],
  552. json["org"],
  553. json["page"],
  554. 10
  555. );
  556. });
  557. //查询教师端消息
  558. router.route("/selectNotice2").all((req, res, next) => {
  559. var json = queryString(req.url);
  560. getmysql(req, res, "selectNotice2", json["uid"], json["oid"], json["org"]);
  561. });
  562. //查询教师端消息
  563. router.route("/addNotice").all((req, res, next) => {
  564. postmysql(req, res, "addNotice");
  565. });
  566. //查询教师端消息
  567. router.route("/deleteNotice").all((req, res, next) => {
  568. postmysql(req, res, "deleteNotice");
  569. });
  570. //查询通知详情
  571. router.route("/selectNewDetail").all((req, res, next) => {
  572. var json = queryString(req.url);
  573. getmysql(req, res, "selectNewDetail", json["nid"]);
  574. });
  575. //查出分组分类
  576. router.route("/getGroup").all((req, res, next) => {
  577. getmysql(req, res, "selectGroupTeacher");
  578. });
  579. //查询这个老师底下的学生提交的作业
  580. router.route("/getWorks").all((req, res, next) => {
  581. //已经不用
  582. var json = queryString(req.url);
  583. getmysql(req, res, "selectWorks", json["cn"], json["cid"], json["page"], 10);
  584. });
  585. //查询项目
  586. router.route("/getProject").all((req, res, next) => {
  587. var json = queryString(req.url);
  588. getmysql(
  589. req,
  590. res,
  591. "selectProject",
  592. json["type"],
  593. json["uid"],
  594. json["oid"],
  595. json["cn"],
  596. json["page"],
  597. 10
  598. );
  599. });
  600. //新评价查询项目
  601. router.route("/getProject1").all((req, res, next) => {
  602. //已经不用
  603. var json = queryString(req.url);
  604. getmysql(
  605. req,
  606. res,
  607. "selectProject1",
  608. json["uid"],
  609. json["cid"],
  610. json["eid"],
  611. json["cn"],
  612. json["page"],
  613. 10
  614. );
  615. });
  616. //查询项目
  617. router.route("/getMyProject").all((req, res, next) => {
  618. var json = queryString(req.url);
  619. getmysql(req, res, "selectMyProject", json["uid"], json["page"], 10);
  620. });
  621. //查询项目成员
  622. router.route("/selectProjectStudent").all((req, res, next) => {
  623. var json = queryString(req.url);
  624. getmysql(req, res, "select_student", json["cn"], json["oid"], json["uid"]);
  625. });
  626. //查询Banner列表
  627. router.route("/selectBannerList").all((req, res, next) => {
  628. var json = queryString(req.url);
  629. getmysql(req, res, "selectBannerList", json["page"], 10);
  630. });
  631. //查询Banner列表
  632. router.route("/selectAllBanner").all((req, res, next) => {
  633. var json = queryString(req.url);
  634. getmysql(req, res, "selectAllBanner", json["t"]);
  635. });
  636. //新增Banner
  637. router.route("/insertBannerList").all((req, res, next) => {
  638. postmysql(req, res, "insertBannerList");
  639. });
  640. //删除提交的作业
  641. router.route("/deleteCourseWork").all((req, res, next) => {
  642. postmysql(req, res, "deleteCourseWork");
  643. });
  644. //删除提交的作业
  645. router.route("/deleteCourseWorkS").all((req, res, next) => {
  646. postmysql(req, res, "deleteCourseWorkS");
  647. });
  648. //删除Banner
  649. router.route("/deleteBannerList").all((req, res, next) => {
  650. var json = queryString(req.url);
  651. getmysql(req, res, "deleteBannerList", json["id"]);
  652. });
  653. //新增课程
  654. router.route("/addWork").all((req, res, next) => {
  655. postmysql(req, res, "insert_teacher_work");
  656. });
  657. //点赞评论
  658. router.route("/insertComment").all((req, res, next) => {
  659. postmysql(req, res, "insertComment");
  660. });
  661. //点赞评论
  662. router.route("/getComment").all((req, res, next) => {
  663. postmysql(req, res, "getComment");
  664. });
  665. //取消点赞
  666. router.route("/deleteComment").all((req, res, next) => {
  667. var json = queryString(req.url);
  668. getmysql(req, res, "deleteComment", json["wid"], json["lid"]);
  669. });
  670. //删除评论
  671. router.route("/deleteComment2").all((req, res, next) => {
  672. var json = queryString(req.url);
  673. getmysql(req, res, "deleteComment2", json["id"]);
  674. });
  675. //上传批注图片
  676. router.route("/updateCourseWorks").all((req, res, next) => {
  677. postmysql(req, res, "updateCourseWorks");
  678. });
  679. //上传文件
  680. router.route("/addCourseWorks").all((req, res, next) => {
  681. postmysql(req, res, "addCourseWorks");
  682. });
  683. //上传文件
  684. router.route("/addCourseWorksS").all((req, res, next) => {
  685. postmysql(req, res, "addCourseWorksS");
  686. });
  687. //上传文件
  688. router.route("/addCourseWorksS2").all((req, res, next) => {
  689. postmysql(req, res, "addCourseWorksS2");
  690. });
  691. //修改作业名字
  692. router.route("/updateSCourseName").all((req, res, next) => {
  693. postmysql(req, res, "updateSCourseName");
  694. });
  695. //可上传多个文件
  696. router.route("/addCourseWorksR").all((req, res, next) => {
  697. postmysql(req, res, "addCourseWorksR");
  698. });
  699. //上传文件
  700. router.route("/addCourseWorksTeacher").all((req, res, next) => {
  701. postmysql(req, res, "addCourseWorksTeacher");
  702. });
  703. //上传文件
  704. router.route("/addCourseWorks2").all((req, res, next) => {
  705. var json = queryString(req.url);
  706. postmysql(
  707. req,
  708. res,
  709. "addCourseWorks",
  710. json["uid"],
  711. json["cid"],
  712. json["stage"],
  713. json["task"],
  714. json["tool"],
  715. json["content"],
  716. json["type"]
  717. );
  718. });
  719. //上传文件
  720. router.route("/addCourseWorks3").all((req, res, next) => {
  721. var json = queryString(req.url);
  722. getmysql(
  723. req,
  724. res,
  725. "addCourseWorks2",
  726. json["uid"],
  727. json["cid"],
  728. json["stage"],
  729. json["task"],
  730. json["tool"],
  731. json["content"],
  732. json["type"],
  733. json["atool"]
  734. );
  735. });
  736. //上传文件
  737. router.route("/addCourseWorks3-2").all((req, res, next) => {
  738. var json = queryString(req.url);
  739. postmysql(req, res, "addCourseWorks2");
  740. });
  741. //上传文件
  742. router.route("/addCourseWorks2Inter").all((req, res, next) => {
  743. var json = queryString(req.url);
  744. postmysql(req, res, "addCourseWorks2Inter");
  745. });
  746. //上传文件
  747. router.route("/addCourseWorks4").all((req, res, next) => {
  748. postmysql3(req, res, "addCourseWorks3");
  749. });
  750. //上传文件
  751. router.route("/addCourseWorks4-u").all((req, res, next) => {
  752. postmysql2(req, res, "addCourseWorks3");
  753. });
  754. //上传文件
  755. router.route("/addCourseWorks4E").all((req, res, next) => {
  756. postmysql3(req, res, "addCourseWorks3E");
  757. });
  758. //上传文件
  759. router.route("/addCourseWorks4s").all((req, res, next) => {
  760. postmysql3(req, res, "addCourseWorks4s");
  761. });
  762. //上传文件
  763. router.route("/addCourseWorks4s2").all((req, res, next) => {
  764. postmysql3(req, res, "addCourseWorks4s2");
  765. });
  766. //上传文件
  767. router.route("/addCourseWorks5").all((req, res, next) => {
  768. postmysql(req, res, "addCourseWorks3");
  769. });
  770. //上传批量文件
  771. router.route("/addCourseWorksPl").all((req, res, next) => {
  772. if (req.body[0]) {
  773. var p = Object.values(req.body[0]);
  774. let ateacher = p[0];
  775. let cid = p[1];
  776. let stage = p[2];
  777. let task = p[3];
  778. let tool = p[4];
  779. let files = JSON.parse(p[5]);
  780. for (let i = 0; i < files.length; i++) {
  781. var k = [
  782. files[i].username,
  783. cid,
  784. stage,
  785. task,
  786. tool,
  787. files[i].url,
  788. files[i].fileType,
  789. ateacher,
  790. "50",
  791. ];
  792. k.unshift(_mysqlLabor[0], _mysqlLabor[1], "addCourseWorksPl");
  793. //執行存儲過程
  794. mysql.usselect(k, function(ret) {
  795. if (i == files.length - 1) {
  796. res.end(JSON.stringify(ret));
  797. }
  798. });
  799. }
  800. }
  801. });
  802. //修改课程权限(学生是否能查看所有作业)
  803. router.route("/updateCourseSLook").all((req, res, next) => {
  804. var json = queryString(req.url);
  805. getmysql(req, res, "updateCourseSLook", json["sopen"], json["cid"]);
  806. });
  807. //修改跟随模式阶段-任务
  808. router.route("/updateCourseFollowC").all((req, res, next) => {
  809. postmysql(req, res, "updateCourseFollowC");
  810. });
  811. //修改跟随模式
  812. router.route("/updateCourseFollow").all((req, res, next) => {
  813. postmysql(req, res, "updateCourseFollow");
  814. });
  815. //选人回答
  816. router.route("/updateCoursePick").all((req, res, next) => {
  817. postmysql(req, res, "updateCoursePick");
  818. });
  819. //删除
  820. router.route("/deletePick").all((req, res, next) => {
  821. postmysql(req, res, "deletePick");
  822. });
  823. //修改阶段锁定状态
  824. router.route("/updateCourseLookOpen").all((req, res, next) => {
  825. postmysql(req, res, "updateCourseLookOpen");
  826. });
  827. //查看阶段锁定的状态
  828. router.route("/getCourseState").all((req, res, next) => {
  829. var json = queryString(req.url);
  830. getmysql(req, res, "getCourseState", json["cid"]);
  831. });
  832. //添加锁定状态
  833. router.route("/addCourseState").all((req, res, next) => {
  834. postmysql(req, res, "addCourseState");
  835. });
  836. //修改锁定状态
  837. router.route("/updateCourseSate").all((req, res, next) => {
  838. postmysql(req, res, "updateCourseSate");
  839. });
  840. //修改课程管理模式
  841. router.route("/updateCourseMode").all((req, res, next) => {
  842. postmysql(req, res, "updateCourseMode");
  843. });
  844. //修改课程管理模式
  845. router.route("/updateTrainCourseMode").all((req, res, next) => {
  846. postmysql(req, res, "updateTrainCourseMode");
  847. });
  848. //查询课程权限(学生是否能查看所有作业)
  849. router.route("/selectCourseSLook").all((req, res, next) => {
  850. var json = queryString(req.url);
  851. getmysql(req, res, "selectCourseSLook", json["cid"]);
  852. });
  853. //查询被挑的人
  854. router.route("/getPick").all((req, res, next) => {
  855. var json = queryString(req.url);
  856. getmysql(req, res, "getPick", json["cid"]);
  857. });
  858. //查询作业详情
  859. router.route("/selectWorksDetail2").all((req, res, next) => {
  860. var json = queryString(req.url);
  861. getmysql(
  862. req,
  863. res,
  864. "selectWorksDetail2",
  865. json["uid"],
  866. json["cid"],
  867. json["stage"],
  868. json["task"]
  869. );
  870. });
  871. //查询作业详情
  872. router.route("/selectWorksDetail2u").all((req, res, next) => {
  873. //var json = queryString(req.url);//, json['uid'], json['cid'], json['stage'], json['task'], json['tool'], json['type'], json['atool']
  874. postmysql2(req, res, "selectWorksDetail2u");
  875. });
  876. //查询课程全部作业详情
  877. router.route("/selectWorksDetail3").all((req, res, next) => {
  878. var json = queryString(req.url);
  879. getmysql(req, res, "selectWorksDetail3", json["uid"], json["cid"]);
  880. });
  881. //查询课程所有作业详情
  882. router.route("/selectAllWorksDetail").all((req, res, next) => {
  883. var json = queryString(req.url);
  884. getmysql(req, res, "selectAllWorksDetail", json["uid"], json["cid"]);
  885. });
  886. //查询多个课程全部作业详情
  887. router.route("/selectWorksDetailMore").all((req, res, next) => {
  888. var json = queryString(req.url);
  889. getmysql(req, res, "selectWorksDetailMore", json["uid"], json["cid"]);
  890. });
  891. //查询课程某个阶段某个任务下的评价
  892. router.route("/updateWorksEva").all((req, res, next) => {
  893. var json = queryString(req.url);
  894. getmysql(
  895. req,
  896. res,
  897. "updateWorksEva",
  898. json["cid"],
  899. json["s"],
  900. json["t"],
  901. json["uid"],
  902. json["rate"]
  903. );
  904. });
  905. //学习中心教师查询作业
  906. router.route("/selectSWorks").all((req, res, next) => {
  907. var json = queryString(req.url);
  908. getmysql(req, res, "selectSWorks", json["cid"], json["s"], json["t"]);
  909. });
  910. //学习中心教师查询作业全部展示
  911. router.route("/selectSWorks2").all((req, res, next) => {
  912. var json = queryString(req.url);
  913. getmysql(req, res, "selectSWorks2", json["cid"]);
  914. });
  915. //学习中心学生查询作业
  916. router.route("/selectStudentWorks").all((req, res, next) => {
  917. var json = queryString(req.url);
  918. getmysql(
  919. req,
  920. res,
  921. "selectStudentWorks",
  922. json["uid"],
  923. json["cid"],
  924. json["s"],
  925. json["t"]
  926. );
  927. });
  928. //实时课堂作业评价
  929. router.route("/updateStudentWork").all((req, res, next) => {
  930. postmysql(req, res, "updateStudentWork");
  931. });
  932. //学习中心查询学生
  933. router.route("/selectWorksStudent").all((req, res, next) => {
  934. var json = queryString(req.url);
  935. getmysql(req, res, "selectWorksStudent", json["oid"], json["cid"]);
  936. });
  937. //批量上传查询学生
  938. router.route("/selectSnameByCid").all((req, res, next) => {
  939. var json = queryString(req.url);
  940. getmysql(req, res, "selectSnameByCid", json["cid"]);
  941. });
  942. //批量上传查询学生分页
  943. router.route("/selectSnameByCidPage").all((req, res, next) => {
  944. var json = queryString(req.url);
  945. getmysql(
  946. req,
  947. res,
  948. "selectSnameByCidPage",
  949. json["cid"],
  950. json["cn"],
  951. json["page"],
  952. json["num"]
  953. );
  954. });
  955. //分组查询学生
  956. router.route("/selectSnameByCidGroup").all((req, res, next) => {
  957. var json = queryString(req.url);
  958. getmysql(
  959. req,
  960. res,
  961. "selectSnameByCidGroup",
  962. json["cid"],
  963. json["oid"],
  964. json["cn"]
  965. );
  966. });
  967. /* 查询学生 */
  968. router.route("/selectStudent2").all((req, res, next) => {
  969. var json = queryString(req.url);
  970. getmysql(
  971. req,
  972. res,
  973. "selectStudent2",
  974. json["oid"],
  975. json["cu"],
  976. json["cn"],
  977. json["cid"],
  978. json["page"],
  979. 10
  980. );
  981. });
  982. /* 查询教师 */
  983. router.route("/selectTeacher2").all((req, res, next) => {
  984. var json = queryString(req.url);
  985. getmysql(
  986. req,
  987. res,
  988. "selectTeacher2",
  989. json["oid"],
  990. json["cu"],
  991. json["cn"],
  992. json["cid"],
  993. json["page"],
  994. 10
  995. );
  996. });
  997. /* 查询教师 */
  998. router.route("/selectTeacher").all((req, res, next) => {
  999. var json = queryString(req.url);
  1000. getmysql(
  1001. req,
  1002. res,
  1003. "selectTeacher",
  1004. json["org"],
  1005. json["cu"],
  1006. json["cn"],
  1007. json["page"],
  1008. 10
  1009. );
  1010. });
  1011. /* 添加教师页面查询教师 */
  1012. router.route("/selectTcTeacher").all((req, res, next) => {
  1013. var json = queryString(req.url);
  1014. getmysql(
  1015. req,
  1016. res,
  1017. "selectTcTeacher",
  1018. json["org"],
  1019. json["oid"],
  1020. json["cu"],
  1021. json["cn"],
  1022. json["page"],
  1023. 10
  1024. );
  1025. });
  1026. /* 查询所有评价体系 */
  1027. router.route("/selectAllEvaluation").all((req, res, next) => {
  1028. var json = queryString(req.url);
  1029. getmysql(req, res, "selectAllEvaluation", json["oid"]);
  1030. });
  1031. /* 根据市级用户查询评审员 */
  1032. router.route("/selectReviewer").all((req, res, next) => {
  1033. var json = queryString(req.url);
  1034. getmysql(
  1035. req,
  1036. res,
  1037. "selectReviewer",
  1038. json["uid"],
  1039. json["cn"],
  1040. json["page"],
  1041. 10
  1042. );
  1043. });
  1044. /* 市级区县管理接口 */
  1045. router.route("/selectCReviewer").all((req, res, next) => {
  1046. var json = queryString(req.url);
  1047. getmysql(
  1048. req,
  1049. res,
  1050. "selectCReviewer",
  1051. json["uid"],
  1052. json["cn"],
  1053. json["page"],
  1054. 10
  1055. );
  1056. });
  1057. /* 修改评审员 */
  1058. router.route("/updateReviewer").all((req, res, next) => {
  1059. var json = queryString(req.url);
  1060. getmysql(
  1061. req,
  1062. res,
  1063. "updateReviewer",
  1064. json["n"],
  1065. json["p"],
  1066. json["t"],
  1067. json["s"],
  1068. json["uid"]
  1069. );
  1070. });
  1071. /* 删除评审员 */
  1072. router.route("/deleteReviewer").all((req, res, next) => {
  1073. var json = queryString(req.url);
  1074. getmysql(req, res, "deleteReviewer", json["uid"]);
  1075. });
  1076. /* 查询区县案例 */
  1077. router.route("/selecAnliBox").all((req, res, next) => {
  1078. var json = queryString(req.url);
  1079. getmysql(req, res, "selecAnliBox", json["title"]);
  1080. });
  1081. /* 查询市级案例 */
  1082. router.route("/selecAnliBox1").all((req, res, next) => {
  1083. var json = queryString(req.url);
  1084. getmysql(req, res, "selecAnliBox1", json["title"]);
  1085. });
  1086. /* 查询省级案例 */
  1087. router.route("/selecAnliBox2").all((req, res, next) => {
  1088. var json = queryString(req.url);
  1089. getmysql(req, res, "selecAnliBox2");
  1090. });
  1091. /* 案例征集查询通知公告 */
  1092. router.route("/selectRaceNotice").all((req, res, next) => {
  1093. var json = queryString(req.url);
  1094. getmysql(req, res, "selectRaceNotice", json["page"], 10);
  1095. });
  1096. /* 案例征集查询通知公告详情 */
  1097. router.route("/getRaceNoticeDetail").all((req, res, next) => {
  1098. var json = queryString(req.url);
  1099. getmysql(req, res, "getRaceNoticeDetail", json["nid"]);
  1100. });
  1101. /* 案例征集发送通知 */
  1102. router.route("/insertRaceNote").all((req, res, next) => {
  1103. var json = queryString(req.url);
  1104. getmysql(req, res, "insertRaceNote", json["t"], json["c"], json["uid"]);
  1105. });
  1106. /* 查看随机码是否重复 */
  1107. router.route("/selectInviteCode").all((req, res, next) => {
  1108. var json = queryString(req.url);
  1109. getmysql(req, res, "selectInviteCode", json["code"], json["oid"]);
  1110. });
  1111. /* 查看随机码是否重复 */
  1112. router.route("/selectInviteCode2").all((req, res, next) => {
  1113. var json = queryString(req.url);
  1114. getmysql(req, res, "selectInviteCode2", json["code"], json["oid"]);
  1115. });
  1116. /* 根据随机码获取学校 */
  1117. router.route("/selectCourseByIc").all((req, res, next) => {
  1118. var json = queryString(req.url);
  1119. getmysql(req, res, "selectCourseByIc", json["code"], json["oid"]);
  1120. });
  1121. /* 根据随机码获取学校 */
  1122. router.route("/selectCourseByIc2").all((req, res, next) => {
  1123. var json = queryString(req.url);
  1124. getmysql(req, res, "selectCourseByIc2", json["code"], json["oid"]);
  1125. });
  1126. router.route("/addWorkNew").all((req, res, next) => {
  1127. // postmysql(req, res, "insert_teacher_work_new");
  1128. if (req.body[0]) {
  1129. // p = Object.values(req.body[0]);
  1130. p = [
  1131. req.body[0].uid,
  1132. req.body[0].title,
  1133. req.body[0].brief,
  1134. req.body[0].cover,
  1135. req.body[0].astudent,
  1136. req.body[0].see,
  1137. req.body[0].chapters,
  1138. req.body[0].template,
  1139. ];
  1140. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "insert_teacher_work_new");
  1141. //執行存儲過程
  1142. mysql.usselect(p, function(ret) {
  1143. let course = req.body[0].courseType;
  1144. let courseId = ret[0][0].courseId;
  1145. let userid = req.body[0].uid;
  1146. delCourseType(course, courseId, userid);
  1147. res.end(
  1148. JSON.stringify({
  1149. ordernumber: ret[0][0].ordernumber,
  1150. courseId: ret[0][0].courseId,
  1151. success: 1,
  1152. })
  1153. );
  1154. // res.end(JSON.stringify(ret));
  1155. });
  1156. }
  1157. });
  1158. router.route("/addWorkNew2").all((req, res, next) => {
  1159. if (req.body[0]) {
  1160. p = [
  1161. req.body[0].uid,
  1162. req.body[0].title,
  1163. req.body[0].brief,
  1164. req.body[0].cover,
  1165. req.body[0].evaId,
  1166. req.body[0].astudent,
  1167. req.body[0].see,
  1168. req.body[0].chapters,
  1169. req.body[0].template,
  1170. req.body[0].ateacher,
  1171. ];
  1172. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "insert_teacher_work_new2"); //執行存儲過程
  1173. mysql.usselect(p, function(ret) {
  1174. let course = req.body[0].courseType;
  1175. let courseId = ret[0][0].courseId;
  1176. let userid = req.body[0].uid;
  1177. delCourseType(course, courseId, userid);
  1178. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1179. res.end(
  1180. JSON.stringify({
  1181. ordernumber: ret[0][0].ordernumber,
  1182. courseId: ret[0][0].courseId,
  1183. success: 1,
  1184. })
  1185. );
  1186. });
  1187. }
  1188. });
  1189. router.route("/addTrainCourseNew2").all((req, res, next) => {
  1190. if (req.body[0]) {
  1191. p = [
  1192. req.body[0].uid,
  1193. req.body[0].title,
  1194. req.body[0].brief,
  1195. req.body[0].cover,
  1196. req.body[0].evaId,
  1197. req.body[0].astudent,
  1198. req.body[0].see,
  1199. req.body[0].chapters,
  1200. req.body[0].template,
  1201. req.body[0].ateacher,
  1202. ];
  1203. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addTrainCourseNew2"); //執行存儲過程
  1204. mysql.usselect(p, function(ret) {
  1205. let course = req.body[0].courseType;
  1206. let courseId = ret[0][0].courseId;
  1207. let userid = req.body[0].uid;
  1208. delCourseType(course, courseId, userid);
  1209. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1210. res.end(
  1211. JSON.stringify({
  1212. ordernumber: ret[0][0].ordernumber,
  1213. courseId: ret[0][0].courseId,
  1214. success: 1,
  1215. })
  1216. );
  1217. });
  1218. }
  1219. });
  1220. router.route("/addTestCourse").all((req, res, next) => { //添加评测
  1221. if (req.body[0]) {
  1222. p = [
  1223. req.body[0].uid,
  1224. req.body[0].title,
  1225. req.body[0].brief,
  1226. req.body[0].cover,
  1227. req.body[0].evaId,
  1228. req.body[0].astudent,
  1229. req.body[0].see,
  1230. req.body[0].chapters,
  1231. req.body[0].template,
  1232. req.body[0].ateacher,
  1233. ];
  1234. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addTestCourse"); //執行存儲過程
  1235. mysql.usselect(p, function(ret) {
  1236. let course = req.body[0].courseType;
  1237. let courseId = ret[0][0].courseId;
  1238. let userid = req.body[0].uid;
  1239. delCourseType(course, courseId, userid);
  1240. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1241. res.end(
  1242. JSON.stringify({
  1243. ordernumber: ret[0][0].ordernumber,
  1244. courseId: ret[0][0].courseId,
  1245. success: 1,
  1246. })
  1247. );
  1248. });
  1249. }
  1250. });
  1251. router.route("/addTestCourse2").all((req, res, next) => { //添加评测 类型
  1252. if (req.body[0]) {
  1253. p = [
  1254. req.body[0].uid,
  1255. req.body[0].title,
  1256. req.body[0].brief,
  1257. req.body[0].cover,
  1258. req.body[0].evaId,
  1259. req.body[0].astudent,
  1260. req.body[0].see,
  1261. req.body[0].chapters,
  1262. req.body[0].template,
  1263. req.body[0].ateacher,
  1264. req.body[0].typeid,
  1265. ];
  1266. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addTestCourse2"); //執行存儲過程
  1267. mysql.usselect(p, function(ret) {
  1268. let course = req.body[0].courseType;
  1269. let courseId = ret[0][0].courseId;
  1270. let userid = req.body[0].uid;
  1271. delCourseType(course, courseId, userid);
  1272. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1273. res.end(
  1274. JSON.stringify({
  1275. ordernumber: ret[0][0].ordernumber,
  1276. courseId: ret[0][0].courseId,
  1277. success: 1,
  1278. })
  1279. );
  1280. });
  1281. }
  1282. });
  1283. router.route("/addWorkNew2E").all((req, res, next) => {
  1284. if (req.body[0]) {
  1285. p = [
  1286. req.body[0].uid,
  1287. req.body[0].title,
  1288. req.body[0].brief,
  1289. req.body[0].cover,
  1290. req.body[0].evaId,
  1291. req.body[0].astudent,
  1292. req.body[0].see,
  1293. req.body[0].chapters,
  1294. req.body[0].template,
  1295. req.body[0].ateacher,
  1296. ];
  1297. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "insert_teacher_work_new2E"); //執行存儲過程
  1298. mysql.usselect(p, function(ret) {
  1299. let course = req.body[0].courseType;
  1300. let courseId = ret[0][0].courseId;
  1301. let userid = req.body[0].uid;
  1302. delCourseType(course, courseId, userid);
  1303. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1304. res.end(
  1305. JSON.stringify({
  1306. ordernumber: ret[0][0].ordernumber,
  1307. courseId: ret[0][0].courseId,
  1308. success: 1,
  1309. })
  1310. );
  1311. });
  1312. }
  1313. });
  1314. router.route("/addWorkNew2T").all((req, res, next) => {
  1315. if (req.body[0]) {
  1316. p = [
  1317. req.body[0].uid,
  1318. req.body[0].title,
  1319. req.body[0].brief,
  1320. req.body[0].cover,
  1321. req.body[0].evaId,
  1322. req.body[0].astudent,
  1323. req.body[0].see,
  1324. req.body[0].chapters,
  1325. req.body[0].template,
  1326. req.body[0].ateacher,
  1327. ];
  1328. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "insert_teacher_work_new2T"); //執行存儲過程
  1329. mysql.usselect(p, function(ret) {
  1330. let course = req.body[0].courseType;
  1331. let courseId = ret[0][0].courseId;
  1332. let userid = req.body[0].uid;
  1333. delCourseType(course, courseId, userid);
  1334. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1335. res.end(
  1336. JSON.stringify({
  1337. ordernumber: ret[0][0].ordernumber,
  1338. courseId: ret[0][0].courseId,
  1339. success: 1,
  1340. })
  1341. );
  1342. });
  1343. }
  1344. });
  1345. router.route("/addTrainCourseNew2T").all((req, res, next) => {
  1346. if (req.body[0]) {
  1347. p = [
  1348. req.body[0].uid,
  1349. req.body[0].title,
  1350. req.body[0].brief,
  1351. req.body[0].cover,
  1352. req.body[0].evaId,
  1353. req.body[0].astudent,
  1354. req.body[0].see,
  1355. req.body[0].chapters,
  1356. req.body[0].template,
  1357. req.body[0].ateacher,
  1358. ];
  1359. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addTrainCourseNew2T"); //執行存儲過程
  1360. mysql.usselect(p, function(ret) {
  1361. let course = req.body[0].courseType;
  1362. let courseId = ret[0][0].courseId;
  1363. let userid = req.body[0].uid;
  1364. delCourseType(course, courseId, userid);
  1365. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1366. res.end(
  1367. JSON.stringify({
  1368. ordernumber: ret[0][0].ordernumber,
  1369. courseId: ret[0][0].courseId,
  1370. success: 1,
  1371. })
  1372. );
  1373. });
  1374. }
  1375. });
  1376. router.route("/addSynergyCourse").all((req, res, next) => {
  1377. if (req.body[0]) {
  1378. p = [
  1379. req.body[0].uid,
  1380. req.body[0].title,
  1381. req.body[0].brief,
  1382. req.body[0].cover,
  1383. req.body[0].evaId,
  1384. req.body[0].astudent,
  1385. req.body[0].see,
  1386. req.body[0].chapters,
  1387. req.body[0].template,
  1388. req.body[0].ateacher,
  1389. ];
  1390. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "insert_synergy"); //執行存儲過程
  1391. mysql.usselect(p, function(ret) {
  1392. let course = req.body[0].courseType;
  1393. let courseId = ret[0][0].courseId;
  1394. let userid = req.body[0].uid;
  1395. delCourseType(course, courseId, userid);
  1396. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1397. res.end(
  1398. JSON.stringify({
  1399. ordernumber: ret[0][0].ordernumber,
  1400. courseId: ret[0][0].courseId,
  1401. success: 1,
  1402. })
  1403. );
  1404. });
  1405. }
  1406. });
  1407. router.route("/addWorkNew4").all((req, res, next) => {
  1408. if (req.body[0]) {
  1409. p = [
  1410. req.body[0].uid,
  1411. req.body[0].title,
  1412. req.body[0].brief,
  1413. req.body[0].cover,
  1414. req.body[0].evaId,
  1415. req.body[0].astudent,
  1416. req.body[0].see,
  1417. req.body[0].chapters,
  1418. req.body[0].template,
  1419. req.body[0].ateacher,
  1420. req.body[0].inviteCode,
  1421. ];
  1422. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "insert_teacher_work_new4"); //執行存儲過程
  1423. mysql.usselect(p, function(ret) {
  1424. let course = req.body[0].courseType;
  1425. let courseId = ret[0][0].courseId;
  1426. let userid = req.body[0].uid;
  1427. delCourseType(course, courseId, userid);
  1428. res.end(
  1429. JSON.stringify({
  1430. ordernumber: ret[0][0].ordernumber,
  1431. courseId: ret[0][0].courseId,
  1432. success: 1,
  1433. })
  1434. );
  1435. });
  1436. }
  1437. });
  1438. router.route("/addCourseWorkNew2").all((req, res, next) => {
  1439. //学生
  1440. if (req.body[0]) {
  1441. p = [
  1442. req.body[0].uid,
  1443. req.body[0].title,
  1444. req.body[0].brief,
  1445. req.body[0].cover,
  1446. req.body[0].evaId,
  1447. req.body[0].astudent,
  1448. req.body[0].see,
  1449. req.body[0].chapters,
  1450. req.body[0].template,
  1451. req.body[0].ateacher,
  1452. ];
  1453. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addCourseWorkNew2"); //執行存儲過程
  1454. mysql.usselect(p, function(ret) {
  1455. let course = req.body[0].courseType;
  1456. let courseId = ret[0][0].courseId;
  1457. let userid = req.body[0].uid;
  1458. delCourseType(course, courseId, userid);
  1459. res.end(
  1460. JSON.stringify({
  1461. ordernumber: ret[0][0].ordernumber,
  1462. courseId: ret[0][0].courseId,
  1463. success: 1,
  1464. })
  1465. );
  1466. });
  1467. }
  1468. });
  1469. router.route("/addCourseWorkNew22").all((req, res, next) => {
  1470. //学生
  1471. if (req.body[0]) {
  1472. p = [
  1473. req.body[0].uid,
  1474. req.body[0].title,
  1475. req.body[0].brief,
  1476. req.body[0].cover,
  1477. req.body[0].evaId,
  1478. req.body[0].astudent,
  1479. req.body[0].see,
  1480. req.body[0].chapters,
  1481. req.body[0].template,
  1482. req.body[0].ateacher,
  1483. ];
  1484. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addCourseWorkNew2"); //執行存儲過程
  1485. mysql.usselect(p, function(ret) {
  1486. let course = req.body[0].courseType;
  1487. let courseId = ret[0][0].courseId;
  1488. let userid = req.body[0].uid;
  1489. delCourseTypeS(course, courseId, userid);
  1490. res.end(
  1491. JSON.stringify({
  1492. ordernumber: ret[0][0].ordernumber,
  1493. courseId: ret[0][0].courseId,
  1494. success: 1,
  1495. })
  1496. );
  1497. });
  1498. }
  1499. });
  1500. //新增赛事项目
  1501. router.route("/addRace").all((req, res, next) => {
  1502. if (req.body[0]) {
  1503. p = [
  1504. req.body[0].uid,
  1505. req.body[0].info,
  1506. req.body[0].over,
  1507. req.body[0].pro,
  1508. req.body[0].act,
  1509. req.body[0].exc,
  1510. req.body[0].res,
  1511. ];
  1512. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addRace"); //執行存儲過程
  1513. mysql.usselect(p, function(ret) {
  1514. let course = req.body[0].courseType;
  1515. let courseId = ret[0][0].id;
  1516. let userid = req.body[0].uid;
  1517. delCourseType1(course, courseId, userid);
  1518. res.end(JSON.stringify({ courseId: courseId, success: 1 }));
  1519. });
  1520. }
  1521. });
  1522. //新增赛事账号信息
  1523. router.route("/addRaceUser").all((req, res, next) => {
  1524. if (req.body[0]) {
  1525. p = [
  1526. req.body[0].reg,
  1527. req.body[0].res,
  1528. req.body[0].sch,
  1529. req.body[0].n,
  1530. req.body[0].p,
  1531. req.body[0].t,
  1532. req.body[0].parent,
  1533. ];
  1534. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addRaceUser"); //執行存儲過程
  1535. mysql.usselect(p, function(ret) {
  1536. let num = ret[0][0].num;
  1537. let userid = ret[0][0].userid;
  1538. if (num < 10) {
  1539. num = "SZ" + "00" + num + "@gdae.com";
  1540. } else if (num < 100) {
  1541. num = "SZ" + "0" + num + "@gdae.com";
  1542. } else if (num > 100) {
  1543. num = "SZ" + num + "@gdae.com";
  1544. }
  1545. y = [userid, num, bcrypt.hashSync("123456", bcrypt.genSaltSync(10))];
  1546. //参数拼接,注册
  1547. y.unshift(_mysqlLabor[0], _mysqlLabor[1], "upRaceUserNamePassword");
  1548. mysql.usselect(y, function(ret) {
  1549. res.end(JSON.stringify(ret));
  1550. });
  1551. res.end(JSON.stringify({ num: num, success: 1 }));
  1552. });
  1553. }
  1554. });
  1555. //修改赛事项目
  1556. router.route("/updateRace").all((req, res, next) => {
  1557. if (req.body[0]) {
  1558. p = [
  1559. req.body[0].id,
  1560. req.body[0].info,
  1561. req.body[0].over,
  1562. req.body[0].pro,
  1563. req.body[0].act,
  1564. req.body[0].exc,
  1565. req.body[0].res,
  1566. ];
  1567. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateRace"); //執行存儲過程
  1568. mysql.usselect(p, function(ret) {
  1569. let course = req.body[0].courseType;
  1570. let courseId = req.body[0].id;
  1571. let userid = req.body[0].uid;
  1572. delCourseType1(course, courseId, userid);
  1573. res.end(JSON.stringify({ success: 1 }));
  1574. });
  1575. }
  1576. });
  1577. router.route("/addWorkNew3").all((req, res, next) => {
  1578. if (req.body[0]) {
  1579. p = [
  1580. req.body[0].uid,
  1581. req.body[0].title,
  1582. req.body[0].brief,
  1583. req.body[0].cover,
  1584. req.body[0].astudent,
  1585. req.body[0].see,
  1586. req.body[0].chapters,
  1587. req.body[0].template,
  1588. req.body[0].ateacher,
  1589. ];
  1590. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "insert_teacher_work_new3"); //執行存儲過程
  1591. mysql.usselect(p, function(ret) {
  1592. let course = req.body[0].courseType;
  1593. let courseId = ret[0][0].courseId;
  1594. let userid = req.body[0].uid;
  1595. delCourseType(course, courseId, userid);
  1596. res.end(
  1597. JSON.stringify({
  1598. ordernumber: ret[0][0].ordernumber,
  1599. courseId: ret[0][0].courseId,
  1600. success: 1,
  1601. })
  1602. );
  1603. });
  1604. }
  1605. });
  1606. router.route("/addInviteCode").all((req, res, next) => {
  1607. if (req.body[0]) {
  1608. // delCourseInviteCode(req.body[0].courseId,JSON.parse(req.body[0].inviteCode))
  1609. addCourseInviteCode(
  1610. req.body[0].courseId,
  1611. JSON.parse(req.body[0].inviteCode)
  1612. );
  1613. }
  1614. });
  1615. function delCourseInviteCode(courseId, inviteCode) {
  1616. let _courseId = courseId;
  1617. var _userdata = [_courseId];
  1618. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "delete_courseInviteCode");
  1619. mysql.usselect(_userdata, function(ret) {
  1620. // console.log(ret);
  1621. addCourseInviteCode(_courseId, inviteCode);
  1622. });
  1623. }
  1624. function delCourseType(course, courseId, userid) {
  1625. let _courseId = courseId;
  1626. var _userdata = [_courseId];
  1627. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "delete_courseType");
  1628. mysql.usselect(_userdata, function(ret) {
  1629. // console.log(ret);
  1630. addCourseType(userid, course, _courseId);
  1631. });
  1632. // setTimeout(() => {
  1633. // }, 1000);
  1634. }
  1635. function delCourseType1(course, courseId, userid) {
  1636. let _courseId = courseId;
  1637. var _userdata = [_courseId];
  1638. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "delete_courseType1");
  1639. mysql.usselect(_userdata, function(ret) {
  1640. // console.log(ret);
  1641. });
  1642. setTimeout(() => {
  1643. addCourseType1(userid, course, _courseId);
  1644. }, 1000);
  1645. }
  1646. function delCourseTypeS(course, courseId, userid) {
  1647. let _courseId = courseId;
  1648. var _userdata = [_courseId];
  1649. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "delete_courseTypeS");
  1650. mysql.usselect(_userdata, function(ret) {
  1651. // console.log(ret);
  1652. addCourseTypeS(userid, course, _courseId);
  1653. });
  1654. // setTimeout(() => {
  1655. // }, 1000);
  1656. }
  1657. function addCourseInviteCode(courseId, inviteCode) {
  1658. var _courses = courseId;
  1659. var _tid = inviteCode;
  1660. for (let i = 0; i < _tid.length; i++) {
  1661. let _userdata = [_courses, _tid[i].cid, _tid[i].ic];
  1662. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "add_courseInviteCode");
  1663. setTimeout(() => {
  1664. mysql.usselect(_userdata, function(ret) {
  1665. // console.log(ret);
  1666. });
  1667. }, i * 100);
  1668. }
  1669. }
  1670. function addCourseType(userid, course, _courseId) {
  1671. var _uid = userid;
  1672. var _courses = _courseId;
  1673. var _tid = JSON.parse(course);
  1674. for (let i = 0; i < _tid.length; i++) {
  1675. if (_tid[i] == "") {
  1676. continue;
  1677. }
  1678. var _userdata = [_courses, _tid[i], _uid];
  1679. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "add_courseType");
  1680. mysql.usselect(_userdata, function(ret) {
  1681. // console.log(ret);
  1682. });
  1683. }
  1684. }
  1685. function addCourseType1(userid, course, _courseId) {
  1686. var _uid = userid;
  1687. var _courses = _courseId;
  1688. var _tid = JSON.parse(course);
  1689. for (let i = 0; i < _tid.length; i++) {
  1690. if (_tid[i] == "") {
  1691. continue;
  1692. }
  1693. var _userdata = [_courses, _tid[i], _uid];
  1694. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "add_courseType1");
  1695. mysql.usselect(_userdata, function(ret) {
  1696. // console.log(ret);
  1697. });
  1698. }
  1699. }
  1700. function addCourseTypeS(userid, course, _courseId) {
  1701. var _uid = userid;
  1702. var _courses = _courseId;
  1703. var _tid = JSON.parse(course);
  1704. for (let i = 0; i < _tid.length; i++) {
  1705. if (_tid[i] == "") {
  1706. continue;
  1707. }
  1708. var _userdata = [_courses, _tid[i], _uid];
  1709. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "add_courseTypeS");
  1710. mysql.usselect(_userdata, function(ret) {
  1711. // console.log(ret);
  1712. });
  1713. }
  1714. }
  1715. //修改课程
  1716. // router.route('/updateWork').all((req, res, next) => {
  1717. // postmysql(req, res, "update_teacher_work");
  1718. // });
  1719. router.route("/updateWorkNew").all((req, res, next) => {
  1720. if (req.body[0]) {
  1721. // p = Object.values(req.body[0]);
  1722. p = [
  1723. req.body[0].cid,
  1724. req.body[0].title,
  1725. req.body[0].brief,
  1726. req.body[0].cover,
  1727. req.body[0].astudent,
  1728. req.body[0].see,
  1729. req.body[0].chapters,
  1730. req.body[0].template,
  1731. ];
  1732. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "update_teacher_work_new");
  1733. //執行存儲過程
  1734. mysql.usselect(p, function(ret) {
  1735. let course = req.body[0].courseType;
  1736. let courseId = req.body[0].cid;
  1737. let userid = req.body[0].uid;
  1738. delCourseType(course, courseId, userid);
  1739. res.end(JSON.stringify({ success: 1 }));
  1740. // res.end(JSON.stringify(ret));
  1741. });
  1742. }
  1743. });
  1744. //查询课程
  1745. // router.route('/selectCourse').all((req, res, next) => {
  1746. // var json = queryString(req.url);
  1747. // getmysql(req, res, "select_course", json['type'], json['uid'], json['oid'], json['page'], 10);
  1748. // });
  1749. router.route("/updateWorkNew2").all((req, res, next) => {
  1750. if (req.body[0]) {
  1751. p = [
  1752. req.body[0].cid,
  1753. req.body[0].title,
  1754. req.body[0].brief,
  1755. req.body[0].cover,
  1756. req.body[0].evaId,
  1757. req.body[0].astudent,
  1758. req.body[0].see,
  1759. req.body[0].chapters,
  1760. req.body[0].template,
  1761. req.body[0].ateacher,
  1762. ];
  1763. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "update_teacher_work_new2"); //執行存儲過程
  1764. mysql.usselect(p, function(ret) {
  1765. let course = req.body[0].courseType;
  1766. let courseId = req.body[0].cid;
  1767. let userid = req.body[0].uid;
  1768. delCourseType(course, courseId, userid);
  1769. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1770. res.end(JSON.stringify({ success: 1 }));
  1771. });
  1772. }
  1773. });
  1774. router.route("/updateTrainCourseNew2").all((req, res, next) => {
  1775. if (req.body[0]) {
  1776. p = [
  1777. req.body[0].cid,
  1778. req.body[0].title,
  1779. req.body[0].brief,
  1780. req.body[0].cover,
  1781. req.body[0].evaId,
  1782. req.body[0].astudent,
  1783. req.body[0].see,
  1784. req.body[0].chapters,
  1785. req.body[0].template,
  1786. req.body[0].ateacher,
  1787. ];
  1788. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateTrainCourseNew2"); //執行存儲過程
  1789. mysql.usselect(p, function(ret) {
  1790. let course = req.body[0].courseType;
  1791. let courseId = req.body[0].cid;
  1792. let userid = req.body[0].uid;
  1793. delCourseType(course, courseId, userid);
  1794. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1795. res.end(JSON.stringify({ success: 1 }));
  1796. });
  1797. }
  1798. });
  1799. router.route("/updateTestCourse").all((req, res, next) => { //修改评测
  1800. if (req.body[0]) {
  1801. p = [
  1802. req.body[0].cid,
  1803. req.body[0].title,
  1804. req.body[0].brief,
  1805. req.body[0].cover,
  1806. req.body[0].evaId,
  1807. req.body[0].astudent,
  1808. req.body[0].see,
  1809. req.body[0].chapters,
  1810. req.body[0].template,
  1811. req.body[0].ateacher,
  1812. req.body[0].look,
  1813. ];
  1814. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateTestCourse"); //執行存儲過程
  1815. mysql.usselect(p, function(ret) {
  1816. let course = req.body[0].courseType;
  1817. let courseId = req.body[0].cid;
  1818. let userid = req.body[0].uid;
  1819. delCourseType(course, courseId, userid);
  1820. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1821. res.end(JSON.stringify({ success: 1 }));
  1822. });
  1823. }
  1824. });
  1825. router.route("/updateTestCourse2").all((req, res, next) => { //修改评测
  1826. if (req.body[0]) {
  1827. p = [
  1828. req.body[0].cid,
  1829. req.body[0].title,
  1830. req.body[0].brief,
  1831. req.body[0].cover,
  1832. req.body[0].evaId,
  1833. req.body[0].astudent,
  1834. req.body[0].see,
  1835. req.body[0].chapters,
  1836. req.body[0].template,
  1837. req.body[0].ateacher,
  1838. req.body[0].look,
  1839. req.body[0].typeid,
  1840. ];
  1841. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateTestCourse2"); //執行存儲過程
  1842. mysql.usselect(p, function(ret) {
  1843. let course = req.body[0].courseType;
  1844. let courseId = req.body[0].cid;
  1845. let userid = req.body[0].uid;
  1846. delCourseType(course, courseId, userid);
  1847. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1848. res.end(JSON.stringify({ success: 1 }));
  1849. });
  1850. }
  1851. });
  1852. router.route("/updateSynergy").all((req, res, next) => {
  1853. if (req.body[0]) {
  1854. p = [
  1855. req.body[0].cid,
  1856. req.body[0].title,
  1857. req.body[0].brief,
  1858. req.body[0].cover,
  1859. req.body[0].evaId,
  1860. req.body[0].astudent,
  1861. req.body[0].see,
  1862. req.body[0].chapters,
  1863. req.body[0].template,
  1864. req.body[0].ateacher,
  1865. ];
  1866. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "update_synergy"); //執行存儲過程
  1867. mysql.usselect(p, function(ret) {
  1868. let course = req.body[0].courseType;
  1869. let courseId = req.body[0].cid;
  1870. let userid = req.body[0].uid;
  1871. delCourseType(course, courseId, userid);
  1872. // delCourseInviteCode(courseId, JSON.parse(req.body[0].inviteCode));
  1873. res.end(JSON.stringify({ success: 1 }));
  1874. });
  1875. }
  1876. });
  1877. router.route("/updateWorkNew5").all((req, res, next) => {
  1878. if (req.body[0]) {
  1879. p = [
  1880. req.body[0].cid,
  1881. req.body[0].title,
  1882. req.body[0].brief,
  1883. req.body[0].cover,
  1884. req.body[0].evaId,
  1885. req.body[0].astudent,
  1886. req.body[0].see,
  1887. req.body[0].chapters,
  1888. req.body[0].template,
  1889. req.body[0].ateacher,
  1890. req.body[0].inviteCode,
  1891. ];
  1892. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "update_teacher_work_new5"); //執行存儲過程
  1893. mysql.usselect(p, function(ret) {
  1894. let course = req.body[0].courseType;
  1895. let courseId = req.body[0].cid;
  1896. let userid = req.body[0].uid;
  1897. delCourseType(course, courseId, userid);
  1898. res.end(JSON.stringify({ success: 1 }));
  1899. });
  1900. }
  1901. });
  1902. router.route("/updateStudentWorkNew2").all((req, res, next) => {
  1903. //学生
  1904. if (req.body[0]) {
  1905. p = [
  1906. req.body[0].cid,
  1907. req.body[0].title,
  1908. req.body[0].brief,
  1909. req.body[0].cover,
  1910. req.body[0].evaId,
  1911. req.body[0].astudent,
  1912. req.body[0].see,
  1913. req.body[0].chapters,
  1914. req.body[0].template,
  1915. req.body[0].ateacher,
  1916. ];
  1917. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudentWorkNew2"); //執行存儲過程
  1918. mysql.usselect(p, function(ret) {
  1919. let course = req.body[0].courseType;
  1920. let courseId = req.body[0].cid;
  1921. let userid = req.body[0].uid;
  1922. delCourseType(course, courseId, userid);
  1923. res.end(JSON.stringify({ success: 1 }));
  1924. });
  1925. }
  1926. });
  1927. router.route("/updateStudentWorkNew22").all((req, res, next) => {
  1928. //学生
  1929. if (req.body[0]) {
  1930. p = [
  1931. req.body[0].cid,
  1932. req.body[0].title,
  1933. req.body[0].brief,
  1934. req.body[0].cover,
  1935. req.body[0].evaId,
  1936. req.body[0].astudent,
  1937. req.body[0].see,
  1938. req.body[0].chapters,
  1939. req.body[0].template,
  1940. req.body[0].ateacher,
  1941. ];
  1942. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudentWorkNew2"); //執行存儲過程
  1943. mysql.usselect(p, function(ret) {
  1944. let course = req.body[0].courseType;
  1945. let courseId = req.body[0].cid;
  1946. let userid = req.body[0].uid;
  1947. delCourseTypeS(course, courseId, userid);
  1948. res.end(JSON.stringify({ success: 1 }));
  1949. });
  1950. }
  1951. });
  1952. router.route("/updateWorkNew3").all((req, res, next) => {
  1953. if (req.body[0]) {
  1954. p = [
  1955. req.body[0].cid,
  1956. req.body[0].title,
  1957. req.body[0].brief,
  1958. req.body[0].cover,
  1959. req.body[0].astudent,
  1960. req.body[0].see,
  1961. req.body[0].chapters,
  1962. req.body[0].template,
  1963. req.body[0].ateacher,
  1964. ];
  1965. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "update_teacher_work_new3"); //執行存儲過程
  1966. mysql.usselect(p, function(ret) {
  1967. let course = req.body[0].courseType;
  1968. let courseId = req.body[0].cid;
  1969. let userid = req.body[0].uid;
  1970. delCourseType(course, courseId, userid);
  1971. res.end(JSON.stringify({ success: 1 }));
  1972. });
  1973. }
  1974. });
  1975. function guid() {
  1976. var _num,
  1977. i,
  1978. _guid = "";
  1979. for (i = 0; i < 32; i++) {
  1980. _guid += Math.floor(Math.random() * 16).toString(16); //随机0 - 16 的数字 转变为16进制的字符串
  1981. _num = Math.floor((i - 7) / 4); //计算 (i-7)除4
  1982. if (_num > -1 && _num < 4 && i == 7 + 4 * _num) {
  1983. //会使guid中间加 "-" 形式为xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
  1984. _guid += "-";
  1985. }
  1986. }
  1987. return _guid;
  1988. }
  1989. router.route("/updateWorkNew4").all((req, res, next) => {
  1990. if (req.body[0]) {
  1991. let p = [req.body[0].cid];
  1992. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_course_detail"); //執行存儲過程
  1993. mysql.usselect(p, function(ret) {
  1994. let _unitIndex = parseInt(req.body[0].unitIndex);
  1995. let _chapters = JSON.parse(req.body[0].chapters);
  1996. let _unitJson = JSON.parse(ret[0][0].chapters);
  1997. if (_unitJson.length - 1 < _unitIndex) {
  1998. let _i = _unitIndex - (_unitJson.length - 1);
  1999. for (let i = 0; i < _i; i++) {
  2000. _unitJson.push({
  2001. dyName: "", //单元标题
  2002. chapterInfo: [{
  2003. isread: false,
  2004. chapterid: guid(),
  2005. title: "",
  2006. courseName: "",
  2007. taskJson: [{
  2008. task: "",
  2009. taskDetail: "",
  2010. chapterData: [],
  2011. toolText: "",
  2012. toolChoose: [{
  2013. tool: [],
  2014. toolDetail: "",
  2015. toolType: 0,
  2016. askCount: 1,
  2017. askTitle: "",
  2018. askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
  2019. }, ],
  2020. isShowTools: false,
  2021. askCount: 1,
  2022. isFold: 0,
  2023. askTitle: "",
  2024. askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
  2025. checkJson: [{ checkCount: [], checkPerent: [] }],
  2026. homeworkList: [],
  2027. }, ],
  2028. itemCount: 1,
  2029. fileList1: [],
  2030. video: [],
  2031. testData: [],
  2032. pData: [],
  2033. templateArray: [],
  2034. }, ],
  2035. });
  2036. }
  2037. _unitJson[_unitIndex] = _chapters[_unitIndex];
  2038. } else {
  2039. _unitJson[_unitIndex] = _chapters[_unitIndex];
  2040. }
  2041. // console.log(_unitJson);
  2042. let p2 = [
  2043. req.body[0].cid,
  2044. JSON.stringify(_unitJson).replaceAll(/%/g, "%25"),
  2045. ];
  2046. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "update_teacher_work_new4"); //執行存儲過程
  2047. mysql.usselect(p2, function(ret) {
  2048. res.end(JSON.stringify({ success: 1 }));
  2049. });
  2050. // res.end(JSON.stringify({ success: 1 }));
  2051. });
  2052. }
  2053. });
  2054. router.route("/updateTrainCourseNew4").all((req, res, next) => {
  2055. if (req.body[0]) {
  2056. let p = [req.body[0].cid];
  2057. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_trainCourse_detail"); //執行存儲過程
  2058. mysql.usselect(p, function(ret) {
  2059. let _unitIndex = parseInt(req.body[0].unitIndex);
  2060. let _chapters = JSON.parse(req.body[0].chapters);
  2061. let _unitJson = JSON.parse(ret[0][0].chapters);
  2062. if (_unitJson.length - 1 < _unitIndex) {
  2063. let _i = _unitIndex - (_unitJson.length - 1);
  2064. for (let i = 0; i < _i; i++) {
  2065. _unitJson.push({
  2066. dyName: "", //单元标题
  2067. chapterInfo: [{
  2068. isread: false,
  2069. chapterid: guid(),
  2070. title: "",
  2071. courseName: "",
  2072. taskJson: [{
  2073. task: "",
  2074. taskDetail: "",
  2075. chapterData: [],
  2076. toolText: "",
  2077. toolChoose: [{
  2078. tool: [],
  2079. toolDetail: "",
  2080. toolType: 0,
  2081. askCount: 1,
  2082. askTitle: "",
  2083. askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
  2084. }, ],
  2085. isShowTools: false,
  2086. askCount: 1,
  2087. isFold: 0,
  2088. askTitle: "",
  2089. askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
  2090. checkJson: [{ checkCount: [], checkPerent: [] }],
  2091. homeworkList: [],
  2092. }, ],
  2093. itemCount: 1,
  2094. fileList1: [],
  2095. video: [],
  2096. testData: [],
  2097. pData: [],
  2098. templateArray: [],
  2099. }, ],
  2100. });
  2101. }
  2102. _unitJson[_unitIndex] = _chapters[_unitIndex];
  2103. } else {
  2104. _unitJson[_unitIndex] = _chapters[_unitIndex];
  2105. }
  2106. // console.log(_unitJson);
  2107. let p2 = [
  2108. req.body[0].cid,
  2109. JSON.stringify(_unitJson).replaceAll(/%/g, "%25"),
  2110. ];
  2111. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateTrainCourseNew4"); //執行存儲過程
  2112. mysql.usselect(p2, function(ret) {
  2113. res.end(JSON.stringify({ success: 1 }));
  2114. });
  2115. // res.end(JSON.stringify({ success: 1 }));
  2116. });
  2117. }
  2118. });
  2119. router.route("/updateStudentWorkNew4").all((req, res, next) => {
  2120. //学生
  2121. if (req.body[0]) {
  2122. let p = [req.body[0].cid];
  2123. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_student_course_detail2"); //執行存儲過程
  2124. mysql.usselect(p, function(ret) {
  2125. let _unitIndex = parseInt(req.body[0].unitIndex);
  2126. let _chapters = JSON.parse(req.body[0].chapters);
  2127. let _unitJson = JSON.parse(ret[0][0].chapters);
  2128. if (_unitJson.length - 1 < _unitIndex) {
  2129. let _i = _unitIndex - (_unitJson.length - 1);
  2130. for (let i = 0; i < _i; i++) {
  2131. _unitJson.push({
  2132. dyName: "", //单元标题
  2133. chapterInfo: [{
  2134. isread: false,
  2135. chapterid: guid(),
  2136. title: "",
  2137. courseName: "",
  2138. taskJson: [{
  2139. task: "",
  2140. taskDetail: "",
  2141. chapterData: [],
  2142. toolText: "",
  2143. toolChoose: [{
  2144. tool: [],
  2145. toolDetail: "",
  2146. toolType: 0,
  2147. askCount: 1,
  2148. askTitle: "",
  2149. askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
  2150. }, ],
  2151. isShowTools: false,
  2152. askCount: 1,
  2153. isFold: 0,
  2154. askTitle: "",
  2155. askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
  2156. checkJson: [{ checkCount: [], checkPerent: [] }],
  2157. homeworkList: [],
  2158. }, ],
  2159. itemCount: 1,
  2160. fileList1: [],
  2161. video: [],
  2162. testData: [],
  2163. pData: [],
  2164. templateArray: [],
  2165. }, ],
  2166. });
  2167. }
  2168. _unitJson[_unitIndex] = _chapters[_unitIndex];
  2169. } else {
  2170. _unitJson[_unitIndex] = _chapters[_unitIndex];
  2171. }
  2172. // console.log(_unitJson);
  2173. let p2 = [
  2174. req.body[0].cid,
  2175. JSON.stringify(_unitJson).replaceAll(/%/g, "%25"),
  2176. ];
  2177. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudentWorkNew4"); //執行存儲過程
  2178. mysql.usselect(p2, function(ret) {
  2179. res.end(JSON.stringify({ success: 1 }));
  2180. });
  2181. // res.end(JSON.stringify({ success: 1 }));
  2182. });
  2183. }
  2184. });
  2185. //协同删除阶段
  2186. router.route("/deleteWork").all((req, res, next) => {
  2187. if (req.body[0]) {
  2188. let p = [req.body[0].cid];
  2189. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_course_detail"); //執行存儲過程
  2190. mysql.usselect(p, function(ret) {
  2191. let _chapid = req.body[0].chapid;
  2192. // console.log(_chapid);
  2193. let _chapters = JSON.parse(req.body[0].chapters);
  2194. let _unitJson = JSON.parse(ret[0][0].chapters);
  2195. let _unitJson2 = [];
  2196. for (var i = 0; i < _unitJson.length; i++) {
  2197. if (_unitJson[i].chapterInfo[0].chapterid != _chapid) {
  2198. // console.log(1);
  2199. // _unitJson.splice(i, -1)
  2200. _unitJson2.push(_unitJson[i]);
  2201. // break;
  2202. }
  2203. }
  2204. // console.log(_unitJson2);
  2205. let p2 = [
  2206. req.body[0].cid,
  2207. JSON.stringify(_unitJson2).replaceAll(/%/g, "%25"),
  2208. ];
  2209. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "update_teacher_work_new4"); //執行存儲過程
  2210. mysql.usselect(p2, function(ret) {
  2211. res.end(JSON.stringify({ success: 1 }));
  2212. });
  2213. // res.end(JSON.stringify({ success: 1 }));
  2214. });
  2215. }
  2216. });
  2217. router.route("/deletetrainCourseWork").all((req, res, next) => {
  2218. if (req.body[0]) {
  2219. let p = [req.body[0].cid];
  2220. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_trainCourse_detail"); //執行存儲過程
  2221. mysql.usselect(p, function(ret) {
  2222. let _chapid = req.body[0].chapid;
  2223. // console.log(_chapid);
  2224. let _chapters = JSON.parse(req.body[0].chapters);
  2225. let _unitJson = JSON.parse(ret[0][0].chapters);
  2226. let _unitJson2 = [];
  2227. for (var i = 0; i < _unitJson.length; i++) {
  2228. if (_unitJson[i].chapterInfo[0].chapterid != _chapid) {
  2229. // console.log(1);
  2230. // _unitJson.splice(i, -1)
  2231. _unitJson2.push(_unitJson[i]);
  2232. // break;
  2233. }
  2234. }
  2235. // console.log(_unitJson2);
  2236. let p2 = [
  2237. req.body[0].cid,
  2238. JSON.stringify(_unitJson2).replaceAll(/%/g, "%25"),
  2239. ];
  2240. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateTrainCourseNew4"); //執行存儲過程
  2241. mysql.usselect(p2, function(ret) {
  2242. res.end(JSON.stringify({ success: 1 }));
  2243. });
  2244. // res.end(JSON.stringify({ success: 1 }));
  2245. });
  2246. }
  2247. });
  2248. //协同删除阶段
  2249. router.route("/deleteStudentWork").all((req, res, next) => {
  2250. //学生
  2251. if (req.body[0]) {
  2252. let p = [req.body[0].cid];
  2253. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_student_course_detail2"); //執行存儲過程
  2254. mysql.usselect(p, function(ret) {
  2255. let _chapid = req.body[0].chapid;
  2256. // console.log(_chapid);
  2257. let _chapters = JSON.parse(req.body[0].chapters);
  2258. let _unitJson = JSON.parse(ret[0][0].chapters);
  2259. let _unitJson2 = [];
  2260. for (var i = 0; i < _unitJson.length; i++) {
  2261. if (_unitJson[i].chapterInfo[0].chapterid != _chapid) {
  2262. // console.log(1);
  2263. // _unitJson.splice(i, -1)
  2264. _unitJson2.push(_unitJson[i]);
  2265. // break;
  2266. }
  2267. }
  2268. // console.log(_unitJson2);
  2269. let p2 = [
  2270. req.body[0].cid,
  2271. JSON.stringify(_unitJson2).replaceAll(/%/g, "%25"),
  2272. ];
  2273. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudentWorkNew4"); //執行存儲過程
  2274. mysql.usselect(p2, function(ret) {
  2275. res.end(JSON.stringify({ success: 1 }));
  2276. });
  2277. // res.end(JSON.stringify({ success: 1 }));
  2278. });
  2279. }
  2280. });
  2281. //协同恢复删除的阶段
  2282. router.route("/restoreWork").all((req, res, next) => {
  2283. if (req.body[0]) {
  2284. let p = [req.body[0].cid];
  2285. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_course_detail"); //執行存儲過程
  2286. mysql.usselect(p, function(ret) {
  2287. let _chapid = req.body[0].chapid;
  2288. // console.log(_chapid);
  2289. let _chapters = JSON.parse(req.body[0].chapters);
  2290. let _unitJson = JSON.parse(ret[0][0].chapters);
  2291. let _unitJson2 = [];
  2292. let chpaindex;
  2293. for (var i = 0; i < _chapters.length; i++) {
  2294. if (_chapters[i].chapterInfo[0].chapterid == _chapid) {
  2295. chpaindex = i;
  2296. }
  2297. }
  2298. for (var i = 0; i < _unitJson.length; i++) {
  2299. if (_unitJson[i].chapterInfo[0].chapterid != _chapid) {
  2300. // console.log(1);
  2301. // _unitJson.splice(i, -1)
  2302. _unitJson2.push(_unitJson[i]);
  2303. // break;
  2304. }
  2305. }
  2306. _unitJson2.splice(chpaindex, 0, _chapters[chpaindex]);
  2307. // console.log(_unitJson2);
  2308. let p2 = [
  2309. req.body[0].cid,
  2310. JSON.stringify(_unitJson2).replaceAll(/%/g, "%25"),
  2311. ];
  2312. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "update_teacher_work_new4"); //執行存儲過程
  2313. mysql.usselect(p2, function(ret) {
  2314. res.end(JSON.stringify({ success: 1 }));
  2315. });
  2316. // res.end(JSON.stringify({ success: 1 }));
  2317. });
  2318. }
  2319. });
  2320. //协同恢复删除的阶段
  2321. router.route("/restoreTrainCourse").all((req, res, next) => {
  2322. if (req.body[0]) {
  2323. let p = [req.body[0].cid];
  2324. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_trainCourse_detail"); //執行存儲過程
  2325. mysql.usselect(p, function(ret) {
  2326. let _chapid = req.body[0].chapid;
  2327. // console.log(_chapid);
  2328. let _chapters = JSON.parse(req.body[0].chapters);
  2329. let _unitJson = JSON.parse(ret[0][0].chapters);
  2330. let _unitJson2 = [];
  2331. let chpaindex;
  2332. for (var i = 0; i < _chapters.length; i++) {
  2333. if (_chapters[i].chapterInfo[0].chapterid == _chapid) {
  2334. chpaindex = i;
  2335. }
  2336. }
  2337. for (var i = 0; i < _unitJson.length; i++) {
  2338. if (_unitJson[i].chapterInfo[0].chapterid != _chapid) {
  2339. // console.log(1);
  2340. // _unitJson.splice(i, -1)
  2341. _unitJson2.push(_unitJson[i]);
  2342. // break;
  2343. }
  2344. }
  2345. _unitJson2.splice(chpaindex, 0, _chapters[chpaindex]);
  2346. // console.log(_unitJson2);
  2347. let p2 = [
  2348. req.body[0].cid,
  2349. JSON.stringify(_unitJson2).replaceAll(/%/g, "%25"),
  2350. ];
  2351. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateTrainCourseNew4"); //執行存儲過程
  2352. mysql.usselect(p2, function(ret) {
  2353. res.end(JSON.stringify({ success: 1 }));
  2354. });
  2355. // res.end(JSON.stringify({ success: 1 }));
  2356. });
  2357. }
  2358. });
  2359. //协同恢复删除的阶段
  2360. router.route("/restoreStudentWork").all((req, res, next) => {
  2361. //学生
  2362. if (req.body[0]) {
  2363. let p = [req.body[0].cid];
  2364. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_student_course_detail2"); //執行存儲過程
  2365. mysql.usselect(p, function(ret) {
  2366. let _chapid = req.body[0].chapid;
  2367. // console.log(_chapid);
  2368. let _chapters = JSON.parse(req.body[0].chapters);
  2369. let _unitJson = JSON.parse(ret[0][0].chapters);
  2370. let _unitJson2 = [];
  2371. let chpaindex;
  2372. for (var i = 0; i < _chapters.length; i++) {
  2373. if (_chapters[i].chapterInfo[0].chapterid == _chapid) {
  2374. chpaindex = i;
  2375. }
  2376. }
  2377. for (var i = 0; i < _unitJson.length; i++) {
  2378. if (_unitJson[i].chapterInfo[0].chapterid != _chapid) {
  2379. // console.log(1);
  2380. // _unitJson.splice(i, -1)
  2381. _unitJson2.push(_unitJson[i]);
  2382. // break;
  2383. }
  2384. }
  2385. _unitJson2.splice(chpaindex, 0, _chapters[chpaindex]);
  2386. // console.log(_unitJson2);
  2387. let p2 = [
  2388. req.body[0].cid,
  2389. JSON.stringify(_unitJson2).replaceAll(/%/g, "%25"),
  2390. ];
  2391. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudentWorkNew4"); //執行存儲過程
  2392. mysql.usselect(p2, function(ret) {
  2393. res.end(JSON.stringify({ success: 1 }));
  2394. });
  2395. // res.end(JSON.stringify({ success: 1 }));
  2396. });
  2397. }
  2398. });
  2399. router.route("/selectCourseNew").all((req, res, next) => {
  2400. var json = queryString(req.url);
  2401. getmysql(
  2402. req,
  2403. res,
  2404. "select_course_new",
  2405. json["type"],
  2406. json["uid"],
  2407. json["oid"],
  2408. json["typea"],
  2409. json["typeb"],
  2410. json["typec"],
  2411. json["typed"],
  2412. json["typeE"],
  2413. json["cu"],
  2414. json["cn"],
  2415. json["page"],
  2416. 10
  2417. );
  2418. });
  2419. router.route("/selectCourseNew2").all((req, res, next) => {
  2420. var json = queryString(req.url);
  2421. getmysql(
  2422. req,
  2423. res,
  2424. "select_course_new2",
  2425. json["type"],
  2426. json["uid"],
  2427. json["oid"],
  2428. json["org"],
  2429. json["typea"],
  2430. json["typeb"],
  2431. json["typec"],
  2432. json["typed"],
  2433. json["typeE"],
  2434. json["cu"],
  2435. json["cn"],
  2436. json["page"],
  2437. json["pageSize"]
  2438. );
  2439. });
  2440. router.route("/selectTrainCourseNew2").all((req, res, next) => {
  2441. var json = queryString(req.url);
  2442. getmysql(
  2443. req,
  2444. res,
  2445. "selectTrainCourseNew2",
  2446. json["type"],
  2447. json["uid"],
  2448. json["oid"],
  2449. json["org"],
  2450. json["typea"],
  2451. json["typeb"],
  2452. json["typec"],
  2453. json["typed"],
  2454. json["typeE"],
  2455. json["cu"],
  2456. json["cn"],
  2457. json["page"],
  2458. json["pageSize"]
  2459. );
  2460. });
  2461. router.route("/selectSynergyCourse").all((req, res, next) => {
  2462. var json = queryString(req.url);
  2463. getmysql(
  2464. req,
  2465. res,
  2466. "selectSynergyCourse",
  2467. json["type"],
  2468. json["uid"],
  2469. json["oid"],
  2470. json["org"],
  2471. json["typea"],
  2472. json["typeb"],
  2473. json["typec"],
  2474. json["typed"],
  2475. json["typeE"],
  2476. json["cu"],
  2477. json["cn"],
  2478. json["page"],
  2479. json["pageSize"]
  2480. );
  2481. });
  2482. router.route("/selectStudentCourseNew2").all((req, res, next) => {
  2483. var json = queryString(req.url);
  2484. getmysql(
  2485. req,
  2486. res,
  2487. "selectStudentCourseNew2",
  2488. json["type"],
  2489. json["uid"],
  2490. json["oid"],
  2491. json["org"],
  2492. json["typea"],
  2493. json["typeb"],
  2494. json["typec"],
  2495. json["typed"],
  2496. json["typeE"],
  2497. json["cu"],
  2498. json["cn"],
  2499. json["page"],
  2500. 10
  2501. );
  2502. });
  2503. router.route("/selectStudentCourseNew22").all((req, res, next) => {
  2504. var json = queryString(req.url);
  2505. getmysql(
  2506. req,
  2507. res,
  2508. "selectStudentCourseNew22",
  2509. json["type"],
  2510. json["uid"],
  2511. json["oid"],
  2512. json["org"],
  2513. json["typea"],
  2514. json["typeb"],
  2515. json["typec"],
  2516. json["typed"],
  2517. json["typef"],
  2518. json["typeE"],
  2519. json["cu"],
  2520. json["cn"],
  2521. json["page"],
  2522. json["pageSize"]
  2523. );
  2524. });
  2525. router.route("/selectStudentCourseNew222").all((req, res, next) => {
  2526. var json = queryString(req.url);
  2527. getmysql(
  2528. req,
  2529. res,
  2530. "selectStudentCourseNew222",
  2531. json["type"],
  2532. json["uid"],
  2533. json["oid"],
  2534. json["org"],
  2535. json["typea"],
  2536. json["typeb"],
  2537. json["typec"],
  2538. json["typed"],
  2539. json["typef"],
  2540. json["typeE"],
  2541. json["cu"],
  2542. json["cn"],
  2543. json["page"],
  2544. json["pageSize"]
  2545. );
  2546. });
  2547. //查询评测
  2548. router.route("/selectTesttCourse").all((req, res, next) => {
  2549. var json = queryString(req.url);
  2550. getmysql(
  2551. req,
  2552. res,
  2553. "selectTesttCourse",
  2554. json["type"],
  2555. json["uid"],
  2556. json["oid"],
  2557. json["org"],
  2558. json["typea"],
  2559. json["typeb"],
  2560. json["typec"],
  2561. json["typed"],
  2562. json["typef"],
  2563. json["typeE"],
  2564. json["cu"],
  2565. json["cn"],
  2566. json["page"],
  2567. json["pageSize"]
  2568. );
  2569. });
  2570. //查询评测 评测中心
  2571. router.route("/selectTesttCourseCenter").all((req, res, next) => {
  2572. var json = queryString(req.url);
  2573. getmysql(
  2574. req,
  2575. res,
  2576. "selectTesttCourseCenter",
  2577. json["type"],
  2578. json["uid"],
  2579. json["oid"],
  2580. json["org"],
  2581. json["classid"],
  2582. json["typea"],
  2583. json["typeb"],
  2584. json["typec"],
  2585. json["typed"],
  2586. json["typef"],
  2587. json["typeE"],
  2588. json["cu"],
  2589. json["cn"],
  2590. json["page"],
  2591. json["pageSize"]
  2592. );
  2593. });
  2594. router.route("/selectStudentCourseNew22Mode").all((req, res, next) => {
  2595. var json = queryString(req.url);
  2596. getmysql(
  2597. req,
  2598. res,
  2599. "selectStudentCourseNew22Mode",
  2600. json["type"],
  2601. json["uid"],
  2602. json["oid"],
  2603. json["org"],
  2604. json["typea"],
  2605. json["typeb"],
  2606. json["typec"],
  2607. json["typed"],
  2608. json["typef"],
  2609. json["typeE"],
  2610. json["cu"],
  2611. json["cn"]
  2612. );
  2613. });
  2614. //查询协同编辑课程
  2615. router.route("/selectCourseTeam").all((req, res, next) => {
  2616. var json = queryString(req.url);
  2617. getmysql(req, res, "selectCourseTeam", json["uid"], json["oid"]);
  2618. });
  2619. //查询学校
  2620. router.route("/selectSchoolName").all((req, res, next) => {
  2621. var json = queryString(req.url);
  2622. getmysql(req, res, "selectOidName", json["cu"], json["cn"], json["page"], 10);
  2623. });
  2624. //查询组织
  2625. router.route("/selectOrgName").all((req, res, next) => {
  2626. var json = queryString(req.url);
  2627. getmysql(req, res, "selectOrgName", json["page"], 10);
  2628. });
  2629. //查询学校
  2630. router.route("/selectSchoolName2").all((req, res, next) => {
  2631. var json = queryString(req.url);
  2632. getmysql(req, res, "selectOidName2", json["oid"]);
  2633. });
  2634. //查询学校
  2635. router.route("/selectSchoolNameOrg").all((req, res, next) => {
  2636. var json = queryString(req.url);
  2637. getmysql(req, res, "selectSchoolNameOrg", json["org"], json["page"], 10);
  2638. });
  2639. //查询协同学校和被协同学校
  2640. router.route("/selectOrgType").all((req, res, next) => {
  2641. var json = queryString(req.url);
  2642. getmysql(req, res, "selectOrgType", json["t"], json["org"], json["page"], 10);
  2643. });
  2644. //新增批注
  2645. router.route("/addPz").all((req, res, next) => {
  2646. postmysql(req, res, "addPz");
  2647. });
  2648. //新增批注
  2649. router.route("/addPz2").all((req, res, next) => {
  2650. postmysql(req, res, "addPz2");
  2651. });
  2652. //新增回复
  2653. router.route("/addHf").all((req, res, next) => {
  2654. postmysql(req, res, "addHf");
  2655. });
  2656. //删除批注
  2657. router.route("/deletePz").all((req, res, next) => {
  2658. postmysql(req, res, "deletePz");
  2659. });
  2660. //删除回复
  2661. router.route("/deleteReply").all((req, res, next) => {
  2662. postmysql(req, res, "deleteReply");
  2663. });
  2664. //查询批注列表
  2665. router.route("/selectPzList").all((req, res, next) => {
  2666. var json = queryString(req.url);
  2667. getmysql(req, res, "selectPzList", json["cid"], json["s"], json["t"]);
  2668. });
  2669. //查询批注列表
  2670. router.route("/selectPzListType").all((req, res, next) => {
  2671. var json = queryString(req.url);
  2672. getmysql(req, res, "selectPzListType", json["cid"], json["s"], json["t"], json["type"], json["uid"]);
  2673. });
  2674. //评分
  2675. router.route("/scoreWork").all((req, res, next) => {
  2676. postmysql(req, res, "scoreWork");
  2677. });
  2678. //删除学生
  2679. router.route("/deleteStudent").all((req, res, next) => {
  2680. postmysql(req, res, "delete_student");
  2681. });
  2682. //查询学校底下的班级
  2683. router.route("/selectClassBySchool").all((req, res, next) => {
  2684. var json = queryString(req.url);
  2685. getmysql(req, res, "selectClassBySchool", json["oid"]);
  2686. });
  2687. //查询学校底下的教研室
  2688. router.route("/selectTeacherOfficeBySchool").all((req, res, next) => {
  2689. var json = queryString(req.url);
  2690. getmysql(req, res, "selectTeacherOfficeBySchool", json["oid"]);
  2691. });
  2692. //查询学校底下的年级
  2693. router.route("/selectGrageBySchool").all((req, res, next) => {
  2694. var json = queryString(req.url);
  2695. getmysql(req, res, "selectGrageBySchool", json["oid"]);
  2696. });
  2697. //查询学校底下的班级
  2698. router.route("/selectClassBySchoolSearch").all((req, res, next) => {
  2699. var json = queryString(req.url);
  2700. getmysql(req, res, "selectClassBySchoolSearch", json["oid"], json["cn"]);
  2701. });
  2702. //查询学校底下的班级
  2703. router.route("/selectClassBySchoolSearch2").all((req, res, next) => {
  2704. var json = queryString(req.url);
  2705. getmysql(req, res, "selectClassBySchoolSearch2", json["oid"], json["gid"], json["cn"]);
  2706. });
  2707. //查询组织底下的学校
  2708. router.route("/selectSchoolByOrg").all((req, res, next) => {
  2709. var json = queryString(req.url);
  2710. getmysql(req, res, "selectSchoolByOrg", json["org"]);
  2711. });
  2712. //学生注册接口
  2713. router.route("/register_student").post(function(req, res, next) {
  2714. //mode的处理
  2715. if (req.body[0]) {
  2716. // 0 用户名 1 用户密码 2用户身份 3 第三方id(可有可无)
  2717. p = Object.values(req.body[0]); //获取用户密码
  2718. //没有第三方id的处理
  2719. // if (p.length < 4) {
  2720. // p.push("")
  2721. // }
  2722. p[1] = bcrypt.hashSync(p[1], bcrypt.genSaltSync(10));
  2723. //密码加密
  2724. // bcrypt.hash(p[1], 10, function (err, hash) {
  2725. // if (err) {
  2726. // return next(err);
  2727. // }
  2728. // p[1] = hash;
  2729. // });
  2730. //参数拼接,注册
  2731. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "register_student");
  2732. //返回注册用户数据
  2733. // mysql.usselect(p, function (ret) {
  2734. // res.end(ret);
  2735. // });
  2736. mysql.usselect(p, function(ret) {
  2737. res.end(JSON.stringify(ret));
  2738. });
  2739. }
  2740. });
  2741. //查询课程详情
  2742. router.route("/selectCourseDetail").all((req, res, next) => {
  2743. var json = queryString(req.url);
  2744. getmysql(req, res, "selectCourseDetail", json["courseId"]);
  2745. });
  2746. //查询课程详情
  2747. router.route("/selectCourseDetail2").all((req, res, next) => {
  2748. var json = queryString(req.url);
  2749. getmysql(req, res, "selectCourseDetail2", json["courseId"]);
  2750. });
  2751. //查询课程详情
  2752. router.route("/selectCourseDetail3").all((req, res, next) => {
  2753. var json = queryString(req.url);
  2754. getmysql(req, res, "selectCourseDetail3", json["courseId"]);
  2755. });
  2756. //查询学校底下的所有赛事
  2757. router.route("/selectRaceByOid").all((req, res, next) => {
  2758. var json = queryString(req.url);
  2759. getmysql(req, res, "selectRaceByOid", json["sid"]);
  2760. });
  2761. //修改作业学生名称
  2762. router.route("/updateCourseWorksName").all((req, res, next) => {
  2763. var json = queryString(req.url);
  2764. getmysql(req, res, "updateCourseWorksName", json["n"], json["cid"]);
  2765. });
  2766. //查询课程详情
  2767. router.route("/selectStudentCourseDetail").all((req, res, next) => {
  2768. //学生
  2769. var json = queryString(req.url);
  2770. getmysql(req, res, "selectStudentCourseDetail", json["courseId"]);
  2771. });
  2772. //查询课程详情
  2773. router.route("/selectStudentCourseDetail3").all((req, res, next) => {
  2774. //学生
  2775. var json = queryString(req.url);
  2776. getmysql(req, res, "selectStudentCourseDetail3", json["courseId"]);
  2777. });
  2778. //查询课程详情
  2779. router.route("/selectStudentCourseDetail2").all((req, res, next) => {
  2780. //学生
  2781. var json = queryString(req.url);
  2782. getmysql(req, res, "selectStudentCourseDetail2", json["courseId"]);
  2783. });
  2784. //跳转阶段时,如果有课程就查询1返回,如果没有就插入
  2785. router.route("/addUserR").all((req, res, next) => {
  2786. var json = queryString(req.url);
  2787. getmysql(req, res, "insertUserR", json["uid"], json["cid"]);
  2788. });
  2789. //新增学生端作业
  2790. router.route("/addWorks").all((req, res, next) => {
  2791. postmysql(req, res, "add_works");
  2792. });
  2793. //查询已提交作业
  2794. router.route("/selectWork").all((req, res, next) => {
  2795. var json = queryString(req.url);
  2796. getmysql(
  2797. req,
  2798. res,
  2799. "selectWork",
  2800. json["cid"],
  2801. json["stage"],
  2802. json["task"],
  2803. json["uid"]
  2804. );
  2805. });
  2806. //查询作业详情
  2807. router.route("/selectWorksDetail").all((req, res, next) => {
  2808. var json = queryString(req.url);
  2809. getmysql(req, res, "selectWorksDetail", json["uid"], json["cid"]);
  2810. });
  2811. //新增作业评分
  2812. router.route("/updateWorks").all((req, res, next) => {
  2813. var json = queryString(req.url);
  2814. getmysql(req, res, "updateWorks", json["rate"], json["tuid"], json["id"]);
  2815. });
  2816. //新增素材信息
  2817. router.route("/addMtl").all((req, res, next) => {
  2818. var json = queryString(req.url);
  2819. getmysql(req, res, "add_mtl", json["cInfo"], json["t"], json["cBy"]);
  2820. });
  2821. //根据类型查询素材信息
  2822. router.route("/selectMtl").all((req, res, next) => {
  2823. var json = queryString(req.url);
  2824. getmysql(req, res, "selectMtl", json["t"], json["page"], 10);
  2825. });
  2826. //根据类型查询素材信息
  2827. router.route("/selectMtl2").all((req, res, next) => {
  2828. var json = queryString(req.url);
  2829. getmysql(req, res, "selectMtl2", json["t"], json["uid"], json["page"], 10);
  2830. });
  2831. //学习中心
  2832. //新增学习资源信息
  2833. router.route("/addStuMtl").all((req, res, next) => {
  2834. var json = queryString(req.url);
  2835. getmysql(req, res, "addStuMtl", json["cInfo"], json["t"], json["cBy"]);
  2836. });
  2837. //根据类型查询学习资料信息
  2838. router.route("/selectStuMtl").all((req, res, next) => {
  2839. var json = queryString(req.url);
  2840. getmysql(req, res, "selectStuMtl", json["t"], json["page"], 10);
  2841. });
  2842. //删除素材
  2843. router.route("/deleteStuM").all((req, res, next) => {
  2844. var json = queryString(req.url);
  2845. getmysql(req, res, "deleteStuM", json["id"]);
  2846. });
  2847. //查询学生信息
  2848. router.route("/selectSDetail").all((req, res, next) => {
  2849. var json = queryString(req.url);
  2850. getmysql(req, res, "selectStudentDetail", json["uid"]);
  2851. });
  2852. //查询个人课程
  2853. router.route("/selectMyCourse").all((req, res, next) => {
  2854. var json = queryString(req.url);
  2855. getmysql(req, res, "selectMyCourse", json["uid"]);
  2856. });
  2857. //查询个人课程groupby课程id
  2858. router.route("/selectMyCourseBycid").all((req, res, next) => {
  2859. var json = queryString(req.url);
  2860. getmysql(req, res, "selectMyCourseBycid", json["uid"]);
  2861. });
  2862. //查询所有课程
  2863. router.route("/selectAllCourse").all((req, res, next) => {
  2864. var json = queryString(req.url);
  2865. getmysql(req, res, "selectAllCourse", json["oid"], json["page"], 10);
  2866. });
  2867. //根据班级查询所有课程
  2868. router.route("/selectAllCourseByCid").all((req, res, next) => {
  2869. var json = queryString(req.url);
  2870. getmysql(
  2871. req,
  2872. res,
  2873. "selectAllCourseByCid",
  2874. json["oid"],
  2875. json["cid"],
  2876. json["page"],
  2877. 10
  2878. );
  2879. });
  2880. //根据分类查询所有课程
  2881. router.route("/selectTypeCourse").all((req, res, next) => {
  2882. var json = queryString(req.url);
  2883. getmysql(
  2884. req,
  2885. res,
  2886. "selectTypeCourse",
  2887. json["uid"],
  2888. json["oid"],
  2889. json["typea"],
  2890. json["typeb"],
  2891. json["typec"],
  2892. json["typed"],
  2893. json["typeE"],
  2894. json["cu"],
  2895. json["cn"],
  2896. json["classid"],
  2897. json["page"],
  2898. 10
  2899. );
  2900. });
  2901. //根据分类查询所有课程
  2902. router.route("/selectTypeCourse2").all((req, res, next) => {
  2903. var json = queryString(req.url);
  2904. getmysql(
  2905. req,
  2906. res,
  2907. "selectTypeCourse2",
  2908. json["uid"],
  2909. json["oid"],
  2910. json["typea"],
  2911. json["typeb"],
  2912. json["typec"],
  2913. json["typed"],
  2914. json["typeE"],
  2915. json["cu"],
  2916. json["cn"],
  2917. json["classid"],
  2918. json["org"],
  2919. json["page"],
  2920. json["pageSize"]
  2921. );
  2922. });
  2923. //根据分类查询所有课程
  2924. router.route("/selectTypeTrainCourse2").all((req, res, next) => {
  2925. var json = queryString(req.url);
  2926. getmysql(
  2927. req,
  2928. res,
  2929. "selectTypeTrainCourse2",
  2930. json["uid"],
  2931. json["oid"],
  2932. json["typea"],
  2933. json["typeb"],
  2934. json["typec"],
  2935. json["typed"],
  2936. json["typeE"],
  2937. json["cu"],
  2938. json["cn"],
  2939. json["classid"],
  2940. json["org"],
  2941. json["page"],
  2942. json["pageSize"]
  2943. );
  2944. });
  2945. //根据分类查询所有课程
  2946. router.route("/selectTypeCourse2Mode").all((req, res, next) => {
  2947. var json = queryString(req.url);
  2948. getmysql(
  2949. req,
  2950. res,
  2951. "selectTypeCourse2Mode",
  2952. json["uid"],
  2953. json["oid"],
  2954. json["typea"],
  2955. json["typeb"],
  2956. json["typec"],
  2957. json["typed"],
  2958. json["typeE"],
  2959. json["cu"],
  2960. json["cn"],
  2961. json["classid"],
  2962. json["org"]
  2963. );
  2964. });
  2965. //根据分类查询所有课程
  2966. router.route("/selectTypeTrainCourse2Mode").all((req, res, next) => {
  2967. var json = queryString(req.url);
  2968. getmysql(
  2969. req,
  2970. res,
  2971. "selectTypeTrainCourse2Mode",
  2972. json["uid"],
  2973. json["oid"],
  2974. json["typea"],
  2975. json["typeb"],
  2976. json["typec"],
  2977. json["typed"],
  2978. json["typeE"],
  2979. json["cu"],
  2980. json["cn"],
  2981. json["classid"],
  2982. json["org"]
  2983. );
  2984. });
  2985. //根据分类查询所有课程
  2986. router.route("/selectTypeCourse2GM").all((req, res, next) => {
  2987. var json = queryString(req.url);
  2988. getmysql(
  2989. req,
  2990. res,
  2991. "selectTypeCourse2GM",
  2992. json["uid"],
  2993. json["oid"],
  2994. json["typea"],
  2995. json["typeb"],
  2996. json["typec"],
  2997. json["typed"],
  2998. json["typeE"],
  2999. json["cu"],
  3000. json["cn"],
  3001. json["classid"],
  3002. json["org"],
  3003. json["page"],
  3004. 10
  3005. );
  3006. });
  3007. //根据分类查询所有课程
  3008. router.route("/selectCourseExamine").all((req, res, next) => {
  3009. var json = queryString(req.url);
  3010. getmysql(
  3011. req,
  3012. res,
  3013. "selectCourseExamine",
  3014. json["oid"],
  3015. json["org"],
  3016. json["cn"],
  3017. json["page"],
  3018. 10
  3019. );
  3020. });
  3021. //根据分类查询所有课程
  3022. router.route("/selectTypeCourse3").all((req, res, next) => {
  3023. var json = queryString(req.url);
  3024. getmysql(
  3025. req,
  3026. res,
  3027. "selectTypeCourse3",
  3028. json["uid"],
  3029. json["oid"],
  3030. json["typea"],
  3031. json["typeb"],
  3032. json["typec"],
  3033. json["typed"],
  3034. json["typeE"],
  3035. json["cu"],
  3036. json["cn"],
  3037. json["classid"],
  3038. json["org"],
  3039. json["page"],
  3040. 10
  3041. );
  3042. });
  3043. //审核课程
  3044. router.route("/examineCourse").all((req, res, next) => {
  3045. postmysql(req, res, "examineCourse");
  3046. });
  3047. //删除素材
  3048. router.route("/deleteM").all((req, res, next) => {
  3049. var json = queryString(req.url);
  3050. getmysql(req, res, "deleteM", json["id"]);
  3051. });
  3052. //点击阶段时添加观看人数
  3053. router.route("/updateVc").all((req, res, next) => {
  3054. var json = queryString(req.url);
  3055. getmysql(req, res, "updateVc", json["cid"]);
  3056. });
  3057. //删除课程
  3058. router.route("/deleteCourse").all((req, res, next) => {
  3059. var json = queryString(req.url);
  3060. getmysql(req, res, "deleteCourse", json["cid"]);
  3061. });
  3062. //删除课程
  3063. router.route("/deleteTrainCourse").all((req, res, next) => {
  3064. var json = queryString(req.url);
  3065. getmysql(req, res, "deleteTrainCourse", json["cid"]);
  3066. });
  3067. //删除课程
  3068. router.route("/deleteSynergyCourse").all((req, res, next) => {
  3069. var json = queryString(req.url);
  3070. getmysql(req, res, "deleteSynergyCourse", json["cid"]);
  3071. });
  3072. //删除课程
  3073. router.route("/deleteStudentCourse").all((req, res, next) => {
  3074. var json = queryString(req.url);
  3075. getmysql(req, res, "deleteStudentCourse", json["cid"]);
  3076. });
  3077. //复制课程
  3078. router.route("/copyCourse").all((req, res, next) => {
  3079. postmysql(req, res, "copyCourse");
  3080. });
  3081. //复制课程
  3082. router.route("/copyTrainCourse").all((req, res, next) => {
  3083. postmysql(req, res, "copyTrainCourse");
  3084. });
  3085. //复制课程
  3086. router.route("/copySynergyCourse").all((req, res, next) => {
  3087. postmysql(req, res, "copySynergyCourse");
  3088. });
  3089. //复制评价体系
  3090. router.route("/copyEva").all((req, res, next) => {
  3091. postmysql(req, res, "copyEva");
  3092. });
  3093. //复制课程
  3094. router.route("/copySCourse").all((req, res, next) => {
  3095. postmysql(req, res, "copySCourse");
  3096. });
  3097. //查看课程
  3098. router.route("/select_course_detail").all((req, res, next) => {
  3099. var json = queryString(req.url);
  3100. getmysql(req, res, "select_course_detail", json["cid"]);
  3101. });
  3102. //查看课程
  3103. router.route("/select_trainCourse_detail").all((req, res, next) => {
  3104. var json = queryString(req.url);
  3105. getmysql(req, res, "select_trainCourse_detail", json["cid"]);
  3106. });
  3107. //删除评测
  3108. router.route("/deleteTestCourseWorks").all((req, res, next) => {
  3109. postmysql(req, res, "deleteTestCourseWorks");
  3110. });
  3111. //查看评测
  3112. router.route("/selectTestType").all((req, res, next) => {
  3113. var json = queryString(req.url);
  3114. getmysql(req, res, "selectTestType", json["oid"]);
  3115. });
  3116. //查看评测
  3117. router.route("/getTestCourseDetail").all((req, res, next) => {
  3118. var json = queryString(req.url);
  3119. getmysql(req, res, "getTestCourseDetail", json["cid"]);
  3120. });
  3121. //查看课程
  3122. router.route("/select_synergy").all((req, res, next) => {
  3123. var json = queryString(req.url);
  3124. getmysql(req, res, "select_synergy", json["cid"]);
  3125. });
  3126. //查看课程
  3127. router.route("/select_student_course_detail").all((req, res, next) => {
  3128. //学生
  3129. var json = queryString(req.url);
  3130. getmysql(req, res, "select_student_course_detail", json["cid"]);
  3131. });
  3132. //查看课程
  3133. router.route("/select_student_course_detail2").all((req, res, next) => {
  3134. //学生
  3135. var json = queryString(req.url);
  3136. getmysql(req, res, "select_student_course_detail2", json["cid"]);
  3137. });
  3138. //查看课程
  3139. router.route("/getExportScourse").all((req, res, next) => {
  3140. //学生
  3141. var json = queryString(req.url);
  3142. getmysql(req, res, "getExportScourse", json["cid"]);
  3143. });
  3144. //模糊查找课程
  3145. // router.route('/searchCourse').all((req, res, next) => {
  3146. // var json = queryString(req.url);
  3147. // getmysql(req, res, "searchCourse", json['cu'], json['cn'], json['page'], 10);
  3148. // });
  3149. //创建调查问卷
  3150. router.route("/addAsk").all((req, res, next) => {
  3151. postmysql(req, res, "insert_ask");
  3152. });
  3153. //学生提交问卷
  3154. router.route("/addAskList").all((req, res, next) => {
  3155. postmysql(req, res, "insert_askList");
  3156. });
  3157. //根据课程id阶段id获取已提交的问卷
  3158. router.route("/getAskListByCidStage").all((req, res, next) => {
  3159. var json = queryString(req.url);
  3160. getmysql(
  3161. req,
  3162. res,
  3163. "getAskListByCidStage",
  3164. json["cid"],
  3165. json["stage"],
  3166. json["task"]
  3167. );
  3168. });
  3169. //获取调查问卷
  3170. router.route("/getAsk").all((req, res, next) => {
  3171. var json = queryString(req.url);
  3172. getmysql(req, res, "select_ask", json["uid"], json["page"], 10);
  3173. });
  3174. //删除问卷
  3175. router.route("/deleteAsk").all((req, res, next) => {
  3176. postmysql(req, res, "deleteAsk");
  3177. });
  3178. //问卷调查数据统计
  3179. router.route("/getAskListByAskid").all((req, res, next) => {
  3180. var json = queryString(req.url);
  3181. getmysql(req, res, "select_askListByAskid", json["aid"]);
  3182. });
  3183. //删除学生提交问卷
  3184. router.route("/deleteAskList").all((req, res, next) => {
  3185. postmysql(req, res, "update_askList_delete");
  3186. });
  3187. //根据id获取调查问卷
  3188. router.route("/getAskList").all((req, res, next) => {
  3189. var json = queryString(req.url);
  3190. getmysql(req, res, "select_askList", json["uid"], json["page"], 10);
  3191. });
  3192. //查看便签列表
  3193. router.route("/selectNote").all((req, res, next) => {
  3194. var json = queryString(req.url);
  3195. getmysql(req, res, "selectNote", json["uid"]);
  3196. });
  3197. //新增便签列表
  3198. router.route("/insertNote").all((req, res, next) => {
  3199. var json = queryString(req.url);
  3200. getmysql(req, res, "insertNote", json["uid"], json["c"]);
  3201. });
  3202. //根据便签id修改便签内容
  3203. router.route("/updateNote").all((req, res, next) => {
  3204. var json = queryString(req.url);
  3205. getmysql(req, res, "updateNote", json["nid"], json["c"]);
  3206. });
  3207. //删除便签
  3208. router.route("/deleteNote").all((req, res, next) => {
  3209. var json = queryString(req.url);
  3210. getmysql(req, res, "deleteNote", json["nid"]);
  3211. });
  3212. //查询便签
  3213. router.route("/selectNoteContent").all((req, res, next) => {
  3214. var json = queryString(req.url);
  3215. getmysql(req, res, "selectNoteContent", json["cn"]);
  3216. });
  3217. //修改用户信息
  3218. router.route("/updateUserByEdu").all((req, res, next) => {
  3219. postmysql(req, res, "updateUserByEdu");
  3220. });
  3221. //修改用户信息
  3222. router.route("/updateUserByEdu1").all((req, res, next) => {
  3223. postmysql(req, res, "updateUserByEdu1");
  3224. });
  3225. //修改用户信息
  3226. router.route("/updateUserByEduOid").all((req, res, next) => {
  3227. postmysql(req, res, "updateUserByEduOid");
  3228. });
  3229. //修改学生信息
  3230. router.route("/updateStudentInfo").all((req, res, next) => {
  3231. postmysql(req, res, "updateStudentInfo");
  3232. });
  3233. //教师端data修改pbl用户信息
  3234. router.route("/updatePblMessage").all((req, res, next) => {
  3235. postmysql2(req, res, "updatePblMessage");
  3236. });
  3237. //登录次数
  3238. router.route("/addLoginOperation").all((req, res, next) => {
  3239. postmysql2(req, res, "addLoginOperation");
  3240. });
  3241. //当日登录时间
  3242. router.route("/addOperationTime").all((req, res, next) => {
  3243. postmysql2(req, res, "addOperationTime");
  3244. });
  3245. //课程学习时间
  3246. router.route("/addOperationTime2").all((req, res, next) => {
  3247. postmysql(req, res, "addOperationTime");
  3248. });
  3249. //当日登录时间
  3250. router.route("/addOperationTimeT").all((req, res, next) => {
  3251. postmysql2(req, res, "addOperationTime2");
  3252. });
  3253. //课程学习时间
  3254. router.route("/addOperationTimeT2").all((req, res, next) => {
  3255. postmysql(req, res, "addOperationTime2");
  3256. });
  3257. //记录用户协同建构操作
  3258. router.route("/add_OperationCSCL").all((req, res, next) => {
  3259. postmysql2(req, res, "add_OperationCSCL");
  3260. });
  3261. //获取所有分组协同数据
  3262. router.route("/select_CSCLDataByID").all((req, res, next) => {
  3263. postmysql2(req, res, "select_CSCLDataByID");
  3264. });
  3265. //获取项目所有的分组所有的人操作数据的总数和时间
  3266. router.route("/select_CSCLDataCount").all((req, res, next) => {
  3267. postmysql2(req, res, "select_CSCLDataCount");
  3268. });
  3269. //获取用户在某个分组的操作日志
  3270. router.route("/select_CSCLDataByUserIdID").all((req, res, next) => {
  3271. postmysql2(req, res, "select_CSCLDataByUserIdID");
  3272. });
  3273. router.route("/updatePblMessage2").all((req, res, next) => {
  3274. postmysql(req, res, "updatePblMessage");
  3275. });
  3276. router.route("/updateUserInfoText").all((req, res, next) => {
  3277. postmysql(req, res, "updateUserInfoText");
  3278. });
  3279. router.route("/updateRaceUser").all((req, res, next) => {
  3280. postmysql(req, res, "updateRaceUser");
  3281. });
  3282. //查询用户信息
  3283. router.route("/selectUser").all((req, res, next) => {
  3284. var json = queryString(req.url);
  3285. getmysql(req, res, "selectUser", json["userid"]);
  3286. });
  3287. //新增英语写作批改
  3288. router.route("/addEngC").all((req, res, next) => {
  3289. var json = queryString(req.url);
  3290. getmysql(req, res, "insertEngCorrect", json["cid"], json["s"], json["t"], json["tool"], json["wid"], json["c"], json["w"]);
  3291. });
  3292. //查询英语写作批改
  3293. router.route("/selectEngC").all((req, res, next) => {
  3294. var json = queryString(req.url);
  3295. getmysql(req, res, "selectEngCorrect", json["workid"]);
  3296. });
  3297. //查询英语写作作业
  3298. router.route("/selectEngWork").all((req, res, next) => {
  3299. var json = queryString(req.url);
  3300. getmysql(req, res, "selectEngWork", json["wid"]);
  3301. });
  3302. //新增或修改英语写作评价
  3303. router.route("/addEngEva").all((req, res, next) => {
  3304. var json = queryString(req.url);
  3305. getmysql(req, res, "addEngEva", json["id"], json["aic"], json["tc"]);
  3306. });
  3307. //查询分类及所有子分类
  3308. router.route("/selectAllType").all((req, res, next) => {
  3309. var json = queryString(req.url);
  3310. getmysql(req, res, "selectAllType", json["org"], json["oid"]);
  3311. });
  3312. //查询分类及所有子分类
  3313. router.route("/selectAllTrainType").all((req, res, next) => {
  3314. var json = queryString(req.url);
  3315. getmysql(req, res, "selectAllTrainType", json["org"], json["oid"]);
  3316. });
  3317. //查询分类及所有子分类
  3318. router.route("/selectAllTypeS").all((req, res, next) => {
  3319. var json = queryString(req.url);
  3320. getmysql(req, res, "selectAllTypeS", json["org"], json["oid"]);
  3321. });
  3322. //查询分类及所有子分类
  3323. router.route("/selectAllTypeT").all((req, res, next) => {
  3324. var json = queryString(req.url);
  3325. getmysql(req, res, "selectAllTypeT", json["org"], json["oid"]);
  3326. });
  3327. //查询分类及子分类
  3328. router.route("/selectType").all((req, res, next) => {
  3329. var json = queryString(req.url);
  3330. getmysql(req, res, "selectType");
  3331. });
  3332. //查询分类及子分类
  3333. router.route("/selectStudentType").all((req, res, next) => {
  3334. var json = queryString(req.url);
  3335. getmysql(req, res, "selectStudentType");
  3336. });
  3337. //查询赛事分类及子分类
  3338. router.route("/selectMatType").all((req, res, next) => {
  3339. var json = queryString(req.url);
  3340. getmysql(req, res, "selectMatType");
  3341. });
  3342. //根据学校查询分类
  3343. router.route("/selectPtype").all((req, res, next) => {
  3344. var json = queryString(req.url);
  3345. getmysql(req, res, "selectPtype", json["page"], 10);
  3346. });
  3347. //根据学校查询学生项目分类
  3348. router.route("/selectSPtype").all((req, res, next) => {
  3349. var json = queryString(req.url);
  3350. getmysql(req, res, "selectSPtype", json["page"], 10);
  3351. });
  3352. //根据学校查询分类1
  3353. router.route("/selectPtype1").all((req, res, next) => {
  3354. var json = queryString(req.url);
  3355. getmysql(req, res, "selectPtype1", json["oid"], json["page"], 10);
  3356. });
  3357. //添加分类
  3358. router.route("/addPtype").all((req, res, next) => {
  3359. var json = queryString(req.url);
  3360. getmysql(req, res, "addPtype", json["n"], json["uid"], json["oid"]);
  3361. });
  3362. //修改分类
  3363. router.route("/updatePtype").all((req, res, next) => {
  3364. var json = queryString(req.url);
  3365. getmysql(req, res, "updatePtype", json["n"], json["tid"]);
  3366. });
  3367. //修改学生项目分类
  3368. router.route("/updateSPtype").all((req, res, next) => {
  3369. var json = queryString(req.url);
  3370. getmysql(req, res, "updateSPtype", json["n"], json["tid"]);
  3371. });
  3372. //删除分类
  3373. router.route("/deletePtype").all((req, res, next) => {
  3374. var json = queryString(req.url);
  3375. getmysql(req, res, "deletePtype", json["tid"]);
  3376. });
  3377. //删除学生项目分类
  3378. router.route("/deleteSPtype").all((req, res, next) => {
  3379. var json = queryString(req.url);
  3380. getmysql(req, res, "deleteSPtype", json["tid"]);
  3381. });
  3382. //查询子分类列表
  3383. router.route("/selectStype").all((req, res, next) => {
  3384. var json = queryString(req.url);
  3385. getmysql(req, res, "selectStype", json["pid"], json["oid"], json["page"], 10);
  3386. });
  3387. //查询学生项目子分类列表
  3388. router.route("/selectSStype").all((req, res, next) => {
  3389. var json = queryString(req.url);
  3390. getmysql(
  3391. req,
  3392. res,
  3393. "selectSStype",
  3394. json["pid"],
  3395. json["oid"],
  3396. json["page"],
  3397. 10
  3398. );
  3399. });
  3400. //添加子分类
  3401. router.route("/addStype").all((req, res, next) => {
  3402. var json = queryString(req.url);
  3403. getmysql(
  3404. req,
  3405. res,
  3406. "addStype",
  3407. json["pid"],
  3408. json["n"],
  3409. json["uid"],
  3410. json["oid"]
  3411. );
  3412. });
  3413. //添加学生项目子分类
  3414. router.route("/addSStype").all((req, res, next) => {
  3415. var json = queryString(req.url);
  3416. getmysql(
  3417. req,
  3418. res,
  3419. "addSStype",
  3420. json["pid"],
  3421. json["n"],
  3422. json["uid"],
  3423. json["oid"]
  3424. );
  3425. });
  3426. //根据学校查询工作分类
  3427. router.route("/selectStudioPtype").all((req, res, next) => {
  3428. var json = queryString(req.url);
  3429. getmysql(req, res, "selectStudioPtype", json["page"], 10);
  3430. });
  3431. //查询工作室项目子分类列表
  3432. router.route("/selectStudioStype").all((req, res, next) => {
  3433. var json = queryString(req.url);
  3434. getmysql(
  3435. req,
  3436. res,
  3437. "selectStudioStype",
  3438. json["pid"],
  3439. json["oid"],
  3440. json["page"],
  3441. 10
  3442. );
  3443. });
  3444. //添加工作室项目子分类
  3445. router.route("/addStudioStype").all((req, res, next) => {
  3446. var json = queryString(req.url);
  3447. getmysql(
  3448. req,
  3449. res,
  3450. "addStudioStype",
  3451. json["pid"],
  3452. json["n"],
  3453. json["uid"],
  3454. json["oid"]
  3455. );
  3456. });
  3457. //修改工作项目分类
  3458. router.route("/updateStudioPtype").all((req, res, next) => {
  3459. var json = queryString(req.url);
  3460. getmysql(req, res, "updateStudioPtype", json["n"], json["tid"]);
  3461. });
  3462. //删除工作项目分类
  3463. router.route("/deleteStudioPtype").all((req, res, next) => {
  3464. var json = queryString(req.url);
  3465. getmysql(req, res, "deleteStudioPtype", json["tid"]);
  3466. });
  3467. //查看本校所有学生(分页)
  3468. router.route("/selectAllStudent").all((req, res, next) => {
  3469. var json = queryString(req.url);
  3470. getmysql(
  3471. req,
  3472. res,
  3473. "selectAllStudent",
  3474. json["oid"],
  3475. json["cn"],
  3476. json["cid"],
  3477. json["page"],
  3478. 10
  3479. );
  3480. });
  3481. //根据学校id查询子分类
  3482. router.route("/selectTypeByOid").all((req, res, next) => {
  3483. var json = queryString(req.url);
  3484. getmysql(req, res, "selectTypeByOid", json["oid"]);
  3485. });
  3486. //根据学校id查询子分类
  3487. router.route("/selectTypeByOrg").all((req, res, next) => {
  3488. var json = queryString(req.url);
  3489. getmysql(req, res, "selectTypeByOid", json["oid"]);
  3490. });
  3491. //根据组织id查询子分类
  3492. router.route("/selectStudentTypeByOid").all((req, res, next) => {
  3493. var json = queryString(req.url);
  3494. getmysql(req, res, "selectStudentTypeByOid", json["oid"]);
  3495. });
  3496. //更加父id查询分类
  3497. router.route("/selectTypeByPid").all((req, res, next) => {
  3498. var json = queryString(req.url);
  3499. getmysql(req, res, "selectTypeByPid", json["pid"]);
  3500. });
  3501. //点击工具计数
  3502. router.route("/insertToolsCount").all((req, res, next) => {
  3503. var json = queryString(req.url);
  3504. getmysql(
  3505. req,
  3506. res,
  3507. "insertToolsCount",
  3508. json["cid"],
  3509. json["chid"],
  3510. json["uid"],
  3511. json["tid"],
  3512. json["count"]
  3513. );
  3514. });
  3515. //修改工具次数
  3516. router.route("/updateToolsCount").all((req, res, next) => {
  3517. var json = queryString(req.url);
  3518. getmysql(
  3519. req,
  3520. res,
  3521. "updateToolsCount",
  3522. json["cid"],
  3523. json["chid"],
  3524. json["uid"],
  3525. json["tid"],
  3526. json["count"]
  3527. );
  3528. });
  3529. //查询工具次数
  3530. router.route("/selectToolsCount").all((req, res, next) => {
  3531. var json = queryString(req.url);
  3532. getmysql(
  3533. req,
  3534. res,
  3535. "selectToolsCount",
  3536. json["cid"],
  3537. json["chid"],
  3538. json["uid"]
  3539. );
  3540. });
  3541. //导出学生
  3542. router.route("/selectUserBySchool").all((req, res, next) => {
  3543. var json = queryString(req.url);
  3544. getmysql(req, res, "selectUserBySchool", json["oid"]);
  3545. });
  3546. //上传学生作业
  3547. router.route("/insertSWork").all((req, res, next) => {
  3548. var json = queryString(req.url);
  3549. getmysql(
  3550. req,
  3551. res,
  3552. "insertSWork",
  3553. json["uid"],
  3554. json["cid"],
  3555. json["p"],
  3556. json["t"],
  3557. json["upload"]
  3558. );
  3559. });
  3560. //查询学生作业
  3561. router.route("/selectSWork").all((req, res, next) => {
  3562. var json = queryString(req.url);
  3563. getmysql(
  3564. req,
  3565. res,
  3566. "selectSWork",
  3567. json["uid"],
  3568. json["cid"],
  3569. json["p"],
  3570. json["type"]
  3571. );
  3572. });
  3573. //课程进展数据
  3574. router.route("/selectCase").all((req, res, next) => {
  3575. var json = queryString(req.url);
  3576. getmysql(req, res, "selectCase", json["org"]);
  3577. });
  3578. //课程进展数据
  3579. router.route("/selectCase2").all((req, res, next) => {
  3580. var json = queryString(req.url);
  3581. getmysql(req, res, "selectCase2", json["org"]);
  3582. });
  3583. //课程进展数据
  3584. router.route("/selectCase3").all((req, res, next) => {
  3585. var json = queryString(req.url);
  3586. getmysql(
  3587. req,
  3588. res,
  3589. "selectCase3",
  3590. json["org"],
  3591. json["oid"],
  3592. json["page"],
  3593. json["pageSize"]
  3594. );
  3595. });
  3596. //项目进展数据
  3597. router.route("/selectCaseS").all((req, res, next) => {
  3598. var json = queryString(req.url);
  3599. getmysql(req, res, "selectCaseS", json["org"], json["oid"]);
  3600. });
  3601. //项目进展数据
  3602. router.route("/selectCaseS2").all((req, res, next) => {
  3603. var json = queryString(req.url);
  3604. getmysql(
  3605. req,
  3606. res,
  3607. "selectCaseS2",
  3608. json["org"],
  3609. json["oid"],
  3610. json["type"],
  3611. json["page"],
  3612. json["pageSize"]
  3613. );
  3614. });
  3615. //查询赛事项目列表
  3616. router.route("/selectRaceList").all((req, res, next) => {
  3617. var json = queryString(req.url);
  3618. getmysql(req, res, "selectRaceList", json["uid"], json["t"]);
  3619. });
  3620. //修改赛事状态
  3621. router.route("/updateRaceState").all((req, res, next) => {
  3622. var json = queryString(req.url);
  3623. getmysql(req, res, "updateRaceState", json["id"], json["s"]);
  3624. });
  3625. //查询赛事项目详情
  3626. router.route("/selectRaceDetail").all((req, res, next) => {
  3627. var json = queryString(req.url);
  3628. getmysql(req, res, "selectRaceDetail", json["id"]);
  3629. });
  3630. //race 查询学校
  3631. router.route("/getSchool").all((req, res, next) => {
  3632. var json = queryString(req.url);
  3633. getmysql(req, res, "getSchool", json["n"]);
  3634. });
  3635. //查询我的学习报告
  3636. router.route("/selectMrEva").all((req, res, next) => {
  3637. var json = queryString(req.url);
  3638. getmysql(req, res, "selectMrEva", json["uid"], json["oid"], json["cid"]);
  3639. });
  3640. //查询行为数据库
  3641. router.route("/selectModelList").all((req, res, next) => {
  3642. var json = queryString(req.url);
  3643. getmysql(req, res, "selectModelList", json["cn"], json["oid"]);
  3644. });
  3645. //lsc
  3646. //admin 查询学校
  3647. router.route("/getSchoolAdmin").all((req, res, next) => {
  3648. var json = queryString(req.url);
  3649. getmysql(req, res, "select_school", json["page"], 10);
  3650. });
  3651. //admin 添加学校
  3652. router.route("/addSchoolAdmin").all((req, res, next) => {
  3653. postmysql(req, res, "add_school");
  3654. });
  3655. //组织添加学校
  3656. router.route("/addSchoolOrg").all((req, res, next) => {
  3657. postmysql(req, res, "addSchoolOrg");
  3658. });
  3659. //教师端组织添加学校
  3660. router.route("/insertSchoolByOrg").all((req, res, next) => {
  3661. postmysql(req, res, "insertSchoolByOrg");
  3662. });
  3663. //admin 删除学校
  3664. router.route("/deleteSchoolAdmin").all((req, res, next) => {
  3665. postmysql(req, res, "delete_school");
  3666. });
  3667. //admin 查询班级
  3668. router.route("/getClassAdmin").all((req, res, next) => {
  3669. var json = queryString(req.url);
  3670. getmysql(req, res, "select_classAdmin", json["cn"], json["page"], 10);
  3671. });
  3672. //admin 添加班级
  3673. router.route("/addClassAdmin").all((req, res, next) => {
  3674. postmysql(req, res, "add_classAdmin");
  3675. });
  3676. //admin 查询班级是否重复
  3677. router.route("/getClassRepeat").all((req, res, next) => {
  3678. var json = queryString(req.url);
  3679. getmysql(req, res, "select_classRepeatAdmin", json["n"], json["oid"]);
  3680. });
  3681. //查询未在此班级的学生
  3682. router.route("/getClassStudent").all((req, res, next) => {
  3683. var json = queryString(req.url);
  3684. getmysql(
  3685. req,
  3686. res,
  3687. "getClassStudent",
  3688. json["cid"],
  3689. json["oid"],
  3690. json["cn"],
  3691. json["page"],
  3692. json["num"]
  3693. );
  3694. });
  3695. //查询未在此教研室的老师
  3696. router.route("/getClassTeacher").all((req, res, next) => {
  3697. var json = queryString(req.url);
  3698. getmysql(
  3699. req,
  3700. res,
  3701. "getClassTeacher",
  3702. json["cid"],
  3703. json["oid"],
  3704. json["cn"],
  3705. json["page"],
  3706. json["num"]
  3707. );
  3708. });
  3709. //查询未在此年级的班级
  3710. router.route("/getGradeClass").all((req, res, next) => {
  3711. var json = queryString(req.url);
  3712. getmysql(
  3713. req,
  3714. res,
  3715. "getGradeClass",
  3716. json["cid"],
  3717. json["oid"],
  3718. json["cn"],
  3719. json["page"],
  3720. json["num"]
  3721. );
  3722. });
  3723. //添加学生到班级
  3724. router.route("/addClassStudent").all((req, res, next) => {
  3725. let cid = req.body[0].cid;
  3726. let student = JSON.parse(req.body[0].student);
  3727. for (let i = 0; i < student.length; i++) {
  3728. let _userdata = [student[i]];
  3729. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectUser");
  3730. mysql.usselect(_userdata, function(ret) {
  3731. let classid = ret[0][0].classid;
  3732. if (!classid || classid.indexOf(cid) == -1) {
  3733. classid = classid ? classid.split(",") : [];
  3734. classid.push(cid);
  3735. let _userdata2 = [student[i], classid.join(",")];
  3736. _userdata2.unshift(
  3737. _mysqlLabor[0],
  3738. _mysqlLabor[1],
  3739. "updateStudentClass"
  3740. );
  3741. mysql.usselect(_userdata2, function(ret) {
  3742. if (i == student.length - 1) {
  3743. res.end(JSON.stringify({ success: 1 }));
  3744. }
  3745. });
  3746. }
  3747. });
  3748. }
  3749. });
  3750. //添加老师到教研室
  3751. router.route("/addClassTeacher").all((req, res, next) => {
  3752. let cid = req.body[0].cid;
  3753. let student = JSON.parse(req.body[0].student);
  3754. for (let i = 0; i < student.length; i++) {
  3755. let _userdata = [student[i]];
  3756. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectUser");
  3757. mysql.usselect(_userdata, function(ret) {
  3758. let classid = ret[0][0].cclassid;
  3759. if (!classid || classid.indexOf(cid) == -1) {
  3760. classid = classid ? classid.split(",") : [];
  3761. classid.push(cid);
  3762. let _userdata2 = [student[i], classid.join(",")];
  3763. _userdata2.unshift(
  3764. _mysqlLabor[0],
  3765. _mysqlLabor[1],
  3766. "updateTeacherClass"
  3767. );
  3768. mysql.usselect(_userdata2, function(ret) {
  3769. if (i == student.length - 1) {
  3770. res.end(JSON.stringify({ success: 1 }));
  3771. }
  3772. });
  3773. }
  3774. });
  3775. }
  3776. });
  3777. //添加班级到年级
  3778. router.route("/addGradeClass").all((req, res, next) => {
  3779. let cid = req.body[0].cid;
  3780. let student = JSON.parse(req.body[0].student);
  3781. for (let i = 0; i < student.length; i++) {
  3782. let _userdata = [cid, student[i]];
  3783. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "addGradeClass");
  3784. mysql.usselect(_userdata, function(ret) {
  3785. if (i == student.length - 1) {
  3786. res.end(JSON.stringify({ success: 1 }));
  3787. }
  3788. });
  3789. }
  3790. });
  3791. //移除学生此班级
  3792. router.route("/deleteClassStudent").all((req, res, next) => {
  3793. let cid = req.body[0].cid;
  3794. let student = req.body[0].uid;
  3795. let _userdata = [student];
  3796. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectUser");
  3797. mysql.usselect(_userdata, function(ret) {
  3798. let classid = ret[0][0].classid;
  3799. if (classid.indexOf(cid) != -1) {
  3800. classid = classid.split(",");
  3801. classid.splice(classid.indexOf(cid), 1);
  3802. let _userdata2 = [student, classid.join(",")];
  3803. _userdata2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudentClass");
  3804. mysql.usselect(_userdata2, function(ret) {
  3805. res.end(JSON.stringify({ success: 1 }));
  3806. });
  3807. }
  3808. });
  3809. });
  3810. //移除学生此班级
  3811. router.route("/deleteClassTeacher").all((req, res, next) => {
  3812. let cid = req.body[0].cid;
  3813. let student = req.body[0].uid;
  3814. let _userdata = [student];
  3815. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "selectUser");
  3816. mysql.usselect(_userdata, function(ret) {
  3817. let classid = ret[0][0].cclassid;
  3818. if (classid.indexOf(cid) != -1) {
  3819. classid = classid.split(",");
  3820. classid.splice(classid.indexOf(cid), 1);
  3821. let _userdata2 = [student, classid.join(",")];
  3822. _userdata2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateTeacherClass");
  3823. mysql.usselect(_userdata2, function(ret) {
  3824. res.end(JSON.stringify({ success: 1 }));
  3825. });
  3826. }
  3827. });
  3828. });
  3829. //移除班级
  3830. router.route("/deleteGradeClass").all((req, res, next) => {
  3831. let cid = req.body[0].cid;
  3832. let student = req.body[0].uid;
  3833. let _userdata = ['', student];
  3834. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "addGradeClass");
  3835. mysql.usselect(_userdata, function(ret) {
  3836. res.end(JSON.stringify({ success: 1 }));
  3837. });
  3838. });
  3839. //admin 发布通知
  3840. router.route("/addNews").all((req, res, next) => {
  3841. postmysql(req, res, "add_news");
  3842. });
  3843. //admin 删除通知
  3844. router.route("/deleteNews").all((req, res, next) => {
  3845. postmysql(req, res, "delete_news");
  3846. });
  3847. //admin 添加banner
  3848. router.route("/addBanner").all((req, res, next) => {
  3849. postmysql(req, res, "add_banner");
  3850. });
  3851. //admin 添加banner
  3852. router.route("/deleteBanner").all((req, res, next) => {
  3853. postmysql(req, res, "delete_banner");
  3854. });
  3855. //admin 查询banner
  3856. router.route("/getBanner").all((req, res, next) => {
  3857. var json = queryString(req.url);
  3858. getmysql(req, res, "select_banner");
  3859. });
  3860. //根据学校查询banner
  3861. router.route("/selectBannerByOid").all((req, res, next) => {
  3862. var json = queryString(req.url);
  3863. getmysql(req, res, "selectBannerByOid", json["oid"]);
  3864. });
  3865. //admin 查询banner
  3866. router.route("/getBannerS").all((req, res, next) => {
  3867. var json = queryString(req.url);
  3868. getmysql(req, res, "getBannerS");
  3869. });
  3870. //根据学校查询banner
  3871. router.route("/selectBannerByOidS").all((req, res, next) => {
  3872. var json = queryString(req.url);
  3873. getmysql(req, res, "selectBannerByOidS", json["oid"]);
  3874. });
  3875. //admin 查询课程getSearchCourse
  3876. router.route("/getSearchCourse").all((req, res, next) => {
  3877. var json = queryString(req.url);
  3878. getmysql(req, res, "selectAll_courseSearch", json["t"]);
  3879. });
  3880. //根据学校查询课程
  3881. router.route("/getSearchCourseByoid").all((req, res, next) => {
  3882. var json = queryString(req.url);
  3883. getmysql(req, res, "selectAll_courseByOid", json["t"], json["oid"]);
  3884. });
  3885. //admin 查询所有课程专区
  3886. router.route("/getZone").all((req, res, next) => {
  3887. getmysql(req, res, "select_zone");
  3888. });
  3889. //admin 添加课程专区
  3890. router.route("/addZone").all((req, res, next) => {
  3891. postmysql(req, res, "insert_classZone");
  3892. });
  3893. //评审
  3894. router.route("/reviewCourse").all((req, res, next) => {
  3895. postmysql(req, res, "reviewCourse");
  3896. });
  3897. //查询评审
  3898. router.route("/getReview").all((req, res, next) => {
  3899. var json = queryString(req.url);
  3900. getmysql(req, res, "getReview", json["cid"]);
  3901. });
  3902. //查询所有课程专区下的课程
  3903. router.route("/getZoneClass").all((req, res, next) => {
  3904. var json = queryString(req.url);
  3905. getmysql(
  3906. req,
  3907. res,
  3908. "select_zoneClass",
  3909. json["bid"],
  3910. json["oid"],
  3911. json["page"],
  3912. 10
  3913. );
  3914. });
  3915. //查询所有课程专区下的课程
  3916. router.route("/getZoneClass").all((req, res, next) => {
  3917. var json = queryString(req.url);
  3918. getmysql(
  3919. req,
  3920. res,
  3921. "select_zoneClass",
  3922. json["bid"],
  3923. json["oid"],
  3924. json["page"],
  3925. 10
  3926. );
  3927. });
  3928. //查询所有课程专区下的课程
  3929. router.route("/getZoneClassStudent").all((req, res, next) => {
  3930. var json = queryString(req.url);
  3931. getmysql(
  3932. req,
  3933. res,
  3934. "select_zoneClass",
  3935. json["bid"],
  3936. json["oid"],
  3937. json["page"],
  3938. 20
  3939. );
  3940. });
  3941. //admin 后台查看专区下课程的数量
  3942. router.route("/getZoneClassNum").all((req, res, next) => {
  3943. var json = queryString(req.url);
  3944. getmysql(req, res, "select_zoneClassNum", json["bid"]);
  3945. });
  3946. //admin 后台添加课程专区时查看课程是否在此专区重复
  3947. router.route("/getZoneClassRepeat").all((req, res, next) => {
  3948. var json = queryString(req.url);
  3949. getmysql(req, res, "select_zoneClassRepeat", json["pid"], json["cid"]);
  3950. });
  3951. //把课程添加进专区
  3952. router.route("/addZoneCourse").all((req, res, next) => {
  3953. postmysql(req, res, "insert_app");
  3954. });
  3955. //admin 删除课程专区底下的课程
  3956. router.route("/deleteZoneCourse").all((req, res, next) => {
  3957. postmysql(req, res, "delete_app");
  3958. });
  3959. //admin 删除班级
  3960. router.route("/deleteZone").all((req, res, next) => {
  3961. postmysql(req, res, "delete_zone");
  3962. });
  3963. //admin 后台专区上移下移
  3964. router.route("/zoneRank").all((req, res, next) => {
  3965. postmysql(req, res, "update_classRank");
  3966. });
  3967. //admin 添加模板文档
  3968. router.route("/addTemplateAdmin").all((req, res, next) => {
  3969. postmysql(req, res, "add_template");
  3970. });
  3971. //admin 添加模板文档
  3972. router.route("/deleteTemplateAdmin").all((req, res, next) => {
  3973. postmysql(req, res, "delete_template");
  3974. });
  3975. //admin 查询模板文档
  3976. router.route("/getTemplateAdmin").all((req, res, next) => {
  3977. var json = queryString(req.url);
  3978. getmysql(req, res, "select_template", json["page"], 10);
  3979. });
  3980. //查询上传作业
  3981. router.route("/getCourseWorks").all((req, res, next) => {
  3982. var json = queryString(req.url); //cid 课程id,page 页数
  3983. getmysql(
  3984. req,
  3985. res,
  3986. "select_courseWorks",
  3987. json["cid"],
  3988. json["stage"],
  3989. json["task"],
  3990. json["page"],
  3991. 10
  3992. );
  3993. });
  3994. //查询上传作业
  3995. router.route("/getCourseWorks2").all((req, res, next) => {
  3996. var json = queryString(req.url); //cid 课程id,page 页数
  3997. getmysql(
  3998. req,
  3999. res,
  4000. "select_courseWorks2",
  4001. json["cid"],
  4002. json["uname"],
  4003. json["stage"],
  4004. json["task"],
  4005. json["page"],
  4006. 10
  4007. );
  4008. });
  4009. //查询上传作业
  4010. router.route("/getCourseWorks3").all((req, res, next) => {
  4011. var json = queryString(req.url); //cid 课程id,page 页数
  4012. getmysql(
  4013. req,
  4014. res,
  4015. "select_courseWorks3",
  4016. json["cid"],
  4017. json["uname"],
  4018. json["stage"],
  4019. json["task"],
  4020. json["page"],
  4021. 10
  4022. );
  4023. });
  4024. //查询所有学生上传作业
  4025. router.route("/getCourseWorks4").all((req, res, next) => {
  4026. var json = queryString(req.url); //cid 课程id,page 页数
  4027. getmysql(
  4028. req,
  4029. res,
  4030. "select_courseWorks4",
  4031. json["cid"],
  4032. json["uname"],
  4033. json["stage"],
  4034. json["task"]
  4035. );
  4036. });
  4037. //查询学生课程作业
  4038. router.route("/selectStudentCourseWorks").all((req, res, next) => {
  4039. var json = queryString(req.url); //cid 课程id,page 页数
  4040. getmysql(
  4041. req,
  4042. res,
  4043. "selectStudentCourseWorks",
  4044. json["uid"],
  4045. json["cid"],
  4046. json["stage"],
  4047. json["task"],
  4048. json["page"],
  4049. 10
  4050. );
  4051. });
  4052. //查询报告数据
  4053. router.route("/getCourseWorksReport").all((req, res, next) => {
  4054. var json = queryString(req.url); //cid 课程id,page 页数
  4055. getmysql(req, res, "getCourseWorksReport", json["cid"]);
  4056. });
  4057. //查询多个课程报告数据
  4058. router.route("/getCourseWorksReportMore").all((req, res, next) => {
  4059. var json = queryString(req.url); //cid 课程id,page 页数
  4060. getmysql(req, res, "getCourseWorksReportMore", json["cid"]);
  4061. });
  4062. //查询学生课程报告数据
  4063. router.route("/getStudentCourseWorksReport").all((req, res, next) => {
  4064. var json = queryString(req.url); //cid 课程id,page 页数
  4065. getmysql(req, res, "getStudentCourseWorksReport", json["uid"]);
  4066. });
  4067. //admin 添加项目模板文档
  4068. router.route("/addCourseTemplateAdmin").all((req, res, next) => {
  4069. postmysql(req, res, "add_courseTemplate");
  4070. });
  4071. //admin 添加项目模板文档
  4072. router.route("/deleteCourseTemplateAdmin").all((req, res, next) => {
  4073. postmysql(req, res, "delete_courseTemplate");
  4074. });
  4075. //admin 查询项目模板文档
  4076. router.route("/getCourseTemplateAdmin").all((req, res, next) => {
  4077. var json = queryString(req.url);
  4078. getmysql(req, res, "select_courseTemplate", json["page"], 10);
  4079. });
  4080. //teacher 查询项目模板
  4081. router.route("/getCourseTemplateT").all((req, res, next) => {
  4082. var json = queryString(req.url);
  4083. getmysql(req, res, "select_courseTemplateT");
  4084. });
  4085. //teacher 查询项目模板
  4086. router.route("/getTrainCourseTemplateT").all((req, res, next) => {
  4087. var json = queryString(req.url);
  4088. getmysql(req, res, "getTrainCourseTemplateT");
  4089. });
  4090. //teacher 查询项目模板
  4091. router.route("/getCourseTemplateTByOid").all((req, res, next) => {
  4092. var json = queryString(req.url);
  4093. getmysql(req, res, "getCourseTemplateTByOid", json["oid"]);
  4094. });
  4095. //teacher 查询项目模板
  4096. router.route("/getTrainCourseTemplateTByOid").all((req, res, next) => {
  4097. var json = queryString(req.url);
  4098. getmysql(req, res, "getTrainCourseTemplateTByOid", json["oid"]);
  4099. });
  4100. //目标管理查询目标模板
  4101. router.route("/selectEvaTemplate").all((req, res, next) => {
  4102. var json = queryString(req.url);
  4103. getmysql(req, res, "select_evaTemplate", json["oid"]);
  4104. });
  4105. //目标管理新增目标模板
  4106. router.route("/addEvaTemplate").all((req, res, next) => {
  4107. var json = queryString(req.url);
  4108. getmysql(req, res, "add_evaTemplate", json["t"], json["c"], json["uid"], json["oid"]);
  4109. });
  4110. //teacher 查询项目模板
  4111. router.route("/getCourseTemplateTs").all((req, res, next) => {
  4112. var json = queryString(req.url);
  4113. getmysql(req, res, "getCourseTemplateTs", json["oid"]);
  4114. });
  4115. //teacher 查询项目模板
  4116. router.route("/getCourseTemplateTStudio").all((req, res, next) => {
  4117. var json = queryString(req.url);
  4118. getmysql(req, res, "getCourseTemplateTStudio", json["oid"]);
  4119. });
  4120. //admin 查询课程
  4121. router.route("/getCourseAdmin").all((req, res, next) => {
  4122. var json = queryString(req.url);
  4123. getmysql(req, res, "select_courseAdmin", json["cn"], json["page"], 10);
  4124. });
  4125. //admin 查询模板文档
  4126. router.route("/deleteCourseAdmin").all((req, res, next) => {
  4127. postmysql(req, res, "delete_courseAdmin");
  4128. });
  4129. //设置分组
  4130. router.route("/setCourseGroup").all((req, res, next) => {
  4131. postmysql(req, res, "setCourseGroup");
  4132. });
  4133. //删除分组
  4134. router.route("/deleteCourseGroup").all((req, res, next) => {
  4135. postmysql(req, res, "deleteCourseGroup");
  4136. });
  4137. //获取分组
  4138. router.route("/getCourseGroup").all((req, res, next) => {
  4139. var json = queryString(req.url);
  4140. getmysql(req, res, "getCourseGroup", json["cid"], json["classid"]);
  4141. });
  4142. //获取分组
  4143. router.route("/getCourseGroup2").all((req, res, next) => {
  4144. var json = queryString(req.url);
  4145. getmysql(req, res, "getCourseGroup2", json["cid"], json["classid"]);
  4146. });
  4147. //加入分组
  4148. router.route("/joinCourseGroup").all((req, res, next) => {
  4149. postmysql(req, res, "joinCourseGroup");
  4150. });
  4151. //退出分组
  4152. router.route("/exitCourseGroup").all((req, res, next) => {
  4153. postmysql(req, res, "exitCourseGroup");
  4154. });
  4155. //加入分组
  4156. router.route("/joinGroup").all((req, res, next) => {
  4157. postmysql(req, res, "joinGroup");
  4158. });
  4159. //退出分组
  4160. router.route("/exitGroup").all((req, res, next) => {
  4161. postmysql(req, res, "exitGroup");
  4162. });
  4163. //查看分组
  4164. router.route("/selectGroup").all((req, res, next) => {
  4165. postmysql(req, res, "selectGroup");
  4166. });
  4167. //查询ppt在哪页
  4168. router.route("/selectPptPage").all((req, res, next) => {
  4169. var json = queryString(req.url);
  4170. getmysql(req, res, "selectPptPage", json["id"]);
  4171. });
  4172. //修改ppt页码
  4173. router.route("/updatePptPage").all((req, res, next) => {
  4174. postmysql(req, res, "updatePptPage");
  4175. });
  4176. //修改ppt操作
  4177. router.route("/updatePPTHandle").all((req, res, next) => {
  4178. postmysql(req, res, "updatePPTHandle");
  4179. });
  4180. //查询实时课堂
  4181. router.route("/getRealTimeClass").all((req, res, next) => {
  4182. var json = queryString(req.url);
  4183. getmysql(
  4184. req,
  4185. res,
  4186. "getRealTimeClass",
  4187. json["cn"],
  4188. json["uid"],
  4189. json["page"],
  4190. 10
  4191. );
  4192. });
  4193. //查询实时课堂学生
  4194. router.route("/getRealTimeClassStu").all((req, res, next) => {
  4195. var json = queryString(req.url);
  4196. getmysql(
  4197. req,
  4198. res,
  4199. "getRealTimeClassStu",
  4200. json["oid"],
  4201. json["cid"],
  4202. json["page"],
  4203. 10
  4204. );
  4205. });
  4206. //查询实时课堂学生
  4207. router.route("/getRealTimeClassById").all((req, res, next) => {
  4208. var json = queryString(req.url);
  4209. getmysql(req, res, "getRealTimeClassById", json["id"]);
  4210. });
  4211. //根据区级管理者查询案例
  4212. router.route("/selectAnliList").all((req, res, next) => {
  4213. var json = queryString(req.url);
  4214. getmysql(
  4215. req,
  4216. res,
  4217. "selectAnliList",
  4218. json["typea"],
  4219. json["typeb"],
  4220. json["typec"],
  4221. json["typed"],
  4222. json["typeE"],
  4223. json["cn"],
  4224. json["cid"],
  4225. json["title"],
  4226. json["page"],
  4227. 10
  4228. );
  4229. });
  4230. //根据市级管理者查询案例
  4231. router.route("/selectAnliList1").all((req, res, next) => {
  4232. var json = queryString(req.url);
  4233. getmysql(
  4234. req,
  4235. res,
  4236. "selectAnliList1",
  4237. json["typea"],
  4238. json["typeb"],
  4239. json["typec"],
  4240. json["typed"],
  4241. json["typeE"],
  4242. json["cn"],
  4243. json["cid"],
  4244. json["title"],
  4245. json["page"],
  4246. 10
  4247. );
  4248. });
  4249. //根据省级级管理者查询案例
  4250. router.route("/selectAnliList2").all((req, res, next) => {
  4251. var json = queryString(req.url);
  4252. getmysql(
  4253. req,
  4254. res,
  4255. "selectAnliList2",
  4256. json["typea"],
  4257. json["typeb"],
  4258. json["typec"],
  4259. json["typed"],
  4260. json["typeE"],
  4261. json["cn"],
  4262. json["cid"],
  4263. json["title"],
  4264. json["page"],
  4265. 10
  4266. );
  4267. });
  4268. //删除案例
  4269. router.route("/deleteAnli").all((req, res, next) => {
  4270. var json = queryString(req.url);
  4271. getmysql(req, res, "deleteAnli", json["id"]);
  4272. });
  4273. //根据区县管理者查询评分
  4274. router.route("/selectPoint").all((req, res, next) => {
  4275. var json = queryString(req.url);
  4276. getmysql(
  4277. req,
  4278. res,
  4279. "selectPoint",
  4280. json["typea"],
  4281. json["typeb"],
  4282. json["typec"],
  4283. json["typed"],
  4284. json["typeE"],
  4285. json["cn"],
  4286. json["cid"],
  4287. json["title"],
  4288. json["page"],
  4289. 10
  4290. );
  4291. });
  4292. //根据市级管理者查询评分
  4293. router.route("/selectPoint1").all((req, res, next) => {
  4294. var json = queryString(req.url);
  4295. getmysql(
  4296. req,
  4297. res,
  4298. "selectPoint1",
  4299. json["typea"],
  4300. json["typeb"],
  4301. json["typec"],
  4302. json["typed"],
  4303. json["typeE"],
  4304. json["cn"],
  4305. json["cid"],
  4306. json["title"],
  4307. json["page"],
  4308. 10
  4309. );
  4310. });
  4311. //根据市级管理者查询全部评分
  4312. router.route("/selectPointAll").all((req, res, next) => {
  4313. var json = queryString(req.url);
  4314. getmysql(
  4315. req,
  4316. res,
  4317. "selectPointAll",
  4318. json["typea"],
  4319. json["typeb"],
  4320. json["typec"],
  4321. json["typed"],
  4322. json["typeE"],
  4323. json["cn"],
  4324. json["cid"],
  4325. json["title"]
  4326. );
  4327. });
  4328. //查询分配案例
  4329. router.route("/selectCaseUser").all((req, res, next) => {
  4330. var json = queryString(req.url);
  4331. getmysql(req, res, "select_case", json["uid"]);
  4332. });
  4333. //根据用户id,课程id,阶段,任务,工具去查询协同
  4334. router.route("/selectWord").all((req, res, next) => {
  4335. var json = queryString(req.url);
  4336. getmysql(
  4337. req,
  4338. res,
  4339. "selectWord",
  4340. json["uid"],
  4341. json["cid"],
  4342. json["s"],
  4343. json["task"],
  4344. json["t"]
  4345. );
  4346. });
  4347. //根据用户id,课程id,阶段,任务,工具去查询协同
  4348. router.route("/selectWord2").all((req, res, next) => {
  4349. var json = queryString(req.url);
  4350. getmysql(
  4351. req,
  4352. res,
  4353. "selectWord2",
  4354. json["uid"],
  4355. json["cid"],
  4356. json["s"],
  4357. json["task"],
  4358. json["t"],
  4359. json["type"]
  4360. );
  4361. });
  4362. //根据用户id,课程id,阶段,任务,工具去查询协同
  4363. router.route("/selectWords").all((req, res, next) => {
  4364. var json = queryString(req.url);
  4365. getmysql(
  4366. req,
  4367. res,
  4368. "selectWords",
  4369. json["uid"],
  4370. json["cid"],
  4371. json["s"],
  4372. json["task"],
  4373. json["t"],
  4374. json["type"]
  4375. );
  4376. });
  4377. //根据用户id,课程id,阶段,任务,工具去查询协同
  4378. router.route("/selectWordsY").all((req, res, next) => {
  4379. var json = queryString(req.url);
  4380. getmysql(
  4381. req,
  4382. res,
  4383. "selectWordsY",
  4384. json["uid"],
  4385. json["cid"],
  4386. json["s"],
  4387. json["task"],
  4388. json["t"],
  4389. json["type"]
  4390. );
  4391. });
  4392. //新增协同内容
  4393. router.route("/insertWord2y").all((req, res, next) => {
  4394. var json = queryString(req.url);
  4395. // getmysql(req, res, "insertWord2y", json["uid"], json["cid"], json["s"], json["task"], json["t"], json["text"], json["type"]);
  4396. postmysql3(req, res, "insertWord2y");
  4397. });
  4398. //新增协同内容
  4399. router.route("/insertWord").all((req, res, next) => {
  4400. var json = queryString(req.url);
  4401. getmysql(
  4402. req,
  4403. res,
  4404. "insertWord",
  4405. json["uid"],
  4406. json["cid"],
  4407. json["s"],
  4408. json["task"],
  4409. json["t"],
  4410. json["text"]
  4411. );
  4412. });
  4413. //分配案例
  4414. router.route("/insertCase").all((req, res, next) => {
  4415. if (req.body[0]) {
  4416. p = [req.body[0].uid, req.body[0].box];
  4417. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "insertCase"); //執行存儲過程
  4418. mysql.usselect(p, function(ret) {
  4419. res.end(JSON.stringify({ success: 1 }));
  4420. });
  4421. }
  4422. });
  4423. //新增评分
  4424. router.route("/addScore").all((req, res, next) => {
  4425. postmysql(req, res, "addScore");
  4426. });
  4427. //添加用户标签
  4428. router.route("/add_userlabel").all((req, res, next) => {
  4429. postmysql2(req, res, "add_userlabel");
  4430. });
  4431. //查询评分
  4432. router.route("/selectScore").all((req, res, next) => {
  4433. var json = queryString(req.url);
  4434. getmysql(req, res, "selectScore", json["rid"], json["suser"]);
  4435. });
  4436. //查询所有评分
  4437. router.route("/selectAllScore").all((req, res, next) => {
  4438. var json = queryString(req.url);
  4439. getmysql(req, res, "selectAllScore");
  4440. });
  4441. //根据用户id查询评分
  4442. router.route("/selectScoreByUid").all((req, res, next) => {
  4443. var json = queryString(req.url);
  4444. getmysql(req, res, "selectScoreByUid", json["uid"]);
  4445. });
  4446. //查询单个案例所有评分
  4447. router.route("/selectAnliScore").all((req, res, next) => {
  4448. var json = queryString(req.url);
  4449. getmysql(req, res, "selectAnliScore", json["rid"]);
  4450. });
  4451. //赛事推荐
  4452. router.route("/updateRaceRec").all((req, res, next) => {
  4453. var json = queryString(req.url);
  4454. getmysql(req, res, "updateRaceRec", json["id"], json["rec"]);
  4455. });
  4456. //查询数据报告学生报告列表
  4457. router.route("/selectSr").all((req, res, next) => {
  4458. var json = queryString(req.url);
  4459. getmysql(
  4460. req,
  4461. res,
  4462. "selectSr",
  4463. json["cu"],
  4464. json["cn"],
  4465. json["oid"],
  4466. json["page"],
  4467. 10
  4468. );
  4469. });
  4470. //查询数据报告班级报告列表
  4471. router.route("/selectCr").all((req, res, next) => {
  4472. var json = queryString(req.url);
  4473. getmysql(
  4474. req,
  4475. res,
  4476. "selectCr",
  4477. json["cu"],
  4478. json["cn"],
  4479. json["oid"],
  4480. json["page"],
  4481. 10
  4482. );
  4483. });
  4484. //查询数据报告查看班级报告底下学生列表
  4485. router.route("/selectCStudent").all((req, res, next) => {
  4486. var json = queryString(req.url);
  4487. getmysql(req, res, "selectCStudent", json["cid"], json["courseid"]);
  4488. });
  4489. //查询数据报告课程报告列表
  4490. router.route("/selectCourseR").all((req, res, next) => {
  4491. var json = queryString(req.url);
  4492. getmysql(
  4493. req,
  4494. res,
  4495. "selectCourseR",
  4496. json["cu"],
  4497. json["cn"],
  4498. json["cl"],
  4499. json["oid"],
  4500. json["page"],
  4501. 10
  4502. );
  4503. });
  4504. //根据学校id查询学校底下有评价的课程
  4505. router.route("/selectCourseByOid").all((req, res, next) => {
  4506. var json = queryString(req.url);
  4507. getmysql(req, res, "selectCourseByOid", json["oid"]);
  4508. });
  4509. //根据目标id和班级id查询底下有作业的课程
  4510. router.route("/selectEvaCourse").all((req, res, next) => {
  4511. var json = queryString(req.url);
  4512. getmysql(req, res, "selectEvaCourse", json["eid"], json["cid"]);
  4513. });
  4514. //teacher 查询模板
  4515. router.route("/getTemplateT").all((req, res, next) => {
  4516. var json = queryString(req.url);
  4517. getmysql(req, res, "select_templateT");
  4518. });
  4519. //思维网格 创建房间
  4520. router.route("/insertRoom").all((req, res, next) => {
  4521. postmysql(req, res, "insertRoom");
  4522. });
  4523. //删除作业阶段任务工具
  4524. router.route("/deleteStudentToolSTT").all((req, res, next) => {
  4525. postmysql(req, res, "deleteStudentToolSTT");
  4526. });
  4527. //删除作业阶段任务
  4528. router.route("/deleteStudentToolST").all((req, res, next) => {
  4529. postmysql(req, res, "deleteStudentToolST");
  4530. });
  4531. //删除作业阶段
  4532. router.route("/deleteStudentToolS").all((req, res, next) => {
  4533. postmysql(req, res, "deleteStudentToolST");
  4534. });
  4535. //协同编辑 创建房间
  4536. router.route("/insertRoomByFile").all((req, res, next) => {
  4537. //var json = queryString(req.url);
  4538. postmysql2(req, res, "insertRoomByFile");
  4539. //getmysql(req, res, "insertRoomByFile", json["uid"], json["n"], json["d"]);
  4540. });
  4541. //思维网格 查询是否是重复房间号
  4542. router.route("/checkRoomNum").all((req, res, next) => {
  4543. var json = queryString(req.url);
  4544. getmysql(req, res, "checkRoomNum", json["num"]);
  4545. });
  4546. //思维网格 查询房间列表
  4547. router.route("/selectRoomList").all((req, res, next) => {
  4548. var json = queryString(req.url);
  4549. getmysql(
  4550. req,
  4551. res,
  4552. "selectRoomList",
  4553. json["uid"],
  4554. json["oid"],
  4555. json["cid"],
  4556. json["cu"],
  4557. json["cn"]
  4558. );
  4559. });
  4560. //查询pdf列表
  4561. router.route("/selectRTC").all((req, res, next) => {
  4562. var json = queryString(req.url);
  4563. getmysql(req, res, "selectRTC", json["uid"], json["cu"], json["cn"]);
  4564. });
  4565. //协同文档 查询房间列表
  4566. router.route("/selectFileList").all((req, res, next) => {
  4567. var json = queryString(req.url);
  4568. getmysql(
  4569. req,
  4570. res,
  4571. "selectFileList",
  4572. json["uid"],
  4573. json["oid"],
  4574. json["cid"],
  4575. json["cu"],
  4576. json["cn"]
  4577. );
  4578. });
  4579. //协同编辑 查询是否是重复房间号
  4580. router.route("/checkRoomNumByFile").all((req, res, next) => {
  4581. var json = queryString(req.url);
  4582. getmysql(req, res, "checkRoomNumByFile", json["num"]);
  4583. });
  4584. //思维网格 根据房间号或者用户id查询房间信息
  4585. router.route("/selectRoom").all((req, res, next) => {
  4586. var json = queryString(req.url);
  4587. getmysql(req, res, "selectRoom", json["uid"]);
  4588. });
  4589. //思维网格 根据房间号或者用户id查询房间信息
  4590. router.route("/getRoom").all((req, res, next) => {
  4591. var json = queryString(req.url);
  4592. getmysql(req, res, "select_room", json["fid"]);
  4593. });
  4594. //协同编辑 根据房间号或者用户id查询房间信息
  4595. router.route("/selectRoomByFile").all((req, res, next) => {
  4596. var json = queryString(req.url);
  4597. getmysql(req, res, "selectRoomByFile", json["uid"]);
  4598. });
  4599. //思维网格 修改房间数据
  4600. router.route("/updateRoomData").all((req, res, next) => {
  4601. postmysql(req, res, "updateRoomData");
  4602. });
  4603. router.route("/updateFileData").all((req, res, next) => {
  4604. var json = queryString(req.url);
  4605. var json2 = json["mode"].split(",");
  4606. getmysql(req, res, "updateFileData", json2[0], json2[1]);
  4607. });
  4608. router.route("/select_file").all((req, res, next) => {
  4609. var json = queryString(req.url);
  4610. getmysql(req, res, "select_file", json["fid"]);
  4611. });
  4612. //思维网格 解散房间
  4613. router.route("/dismiss").all((req, res, next) => {
  4614. postmysql(req, res, "update_room");
  4615. });
  4616. //提交提问
  4617. router.route("/addProblem").all((req, res, next) => {
  4618. postmysql(req, res, "add_problem");
  4619. //cid 课程id,chid 章节id,t 提问内容,uid 用户id
  4620. });
  4621. //查询提交的提问
  4622. router.route("/getProblem").all((req, res, next) => {
  4623. var json = queryString(req.url); //cid 课程id,page 页数
  4624. getmysql(req, res, "select_problem", json["cid"], json["page"], 10);
  4625. });
  4626. //获取用户基本信息
  4627. router.route("/getUserInfo").all((req, res, next) => {
  4628. var json = queryString(req.url);
  4629. getmysql(req, res, "getUserInfo", json["uid"], json["cid"]);
  4630. });
  4631. //获取用户多个课程基本信息
  4632. router.route("/getUserInfoMore").all((req, res, next) => {
  4633. var json = queryString(req.url);
  4634. getmysql(req, res, "getUserInfoMore", json["uid"], json["cid"]);
  4635. });
  4636. //获取多个用户单个课程基本信息
  4637. router.route("/getClassUserInfoMore").all((req, res, next) => {
  4638. var json = queryString(req.url);
  4639. getmysql(req, res, "getClassUserInfoMore", json["uid"], json["cid"]);
  4640. });
  4641. //获取课程下所有有作业的学生id
  4642. router.route("/selectCourseSuid").all((req, res, next) => {
  4643. var json = queryString(req.url);
  4644. getmysql(req, res, "selectCourseSuid", json["cid"], json["courseid"]);
  4645. });
  4646. //获取项目基本信息
  4647. router.route("/getCourseInfo").all((req, res, next) => {
  4648. var json = queryString(req.url);
  4649. getmysql(req, res, "getCourseInfo", json["cid"]);
  4650. });
  4651. //获取多个项目基本信息
  4652. router.route("/getCourseInfoMore").all((req, res, next) => {
  4653. var json = queryString(req.url);
  4654. getmysql(req, res, "getCourseInfoMore", json["cid"]);
  4655. });
  4656. //获取用户基本信息
  4657. router.route("/getAllUserById").all((req, res, next) => {
  4658. var json = queryString(req.url);
  4659. getmysql(req, res, "getAllUserById", json["uid"]);
  4660. });
  4661. //作业生成报告
  4662. router.route("/getWorkData").all((req, res, next) => {
  4663. var json = queryString(req.url); //cid 课程id,page 页数
  4664. getmysql(req, res, "select_work_data", json["cid"]);
  4665. });
  4666. //查询评价体系
  4667. router.route("/getEvaluation").all((req, res, next) => {
  4668. var json = queryString(req.url); //cid 课程id,page 页数
  4669. getmysql(
  4670. req,
  4671. res,
  4672. "select_evaluation",
  4673. json["oid"],
  4674. json["n"],
  4675. json["page"],
  4676. 10
  4677. );
  4678. });
  4679. //添加评价体系
  4680. router.route("/addEvaluation").all((req, res, next) => {
  4681. postmysql(req, res, "add_evaluation");
  4682. //uid 用户id t标题 c内容
  4683. });
  4684. //修改评价体系
  4685. router.route("/updateEvaluation").all((req, res, next) => {
  4686. postmysql(req, res, "update_evaluation");
  4687. //c内容 t标题 id评价id
  4688. });
  4689. //删除评价体系
  4690. router.route("/deleteEvaluation").all((req, res, next) => {
  4691. postmysql(req, res, "delete_evaluation");
  4692. // id评价id
  4693. });
  4694. //删除评价体系前查询课程是否有该评价
  4695. router.route("/selectCourseEva").all((req, res, next) => {
  4696. var json = queryString(req.url); //cid 课程id,page 页数
  4697. getmysql(
  4698. req,
  4699. res,
  4700. "select_course_eva",
  4701. json["eid"],
  4702. );
  4703. });
  4704. //批量添加学校
  4705. router.route("/batchRegistrationSchool").post(function(req, res, next) {
  4706. let users = req.body[0];
  4707. let arr = JSON.parse(req.body[0].arr);
  4708. for (let i = 0; i < arr.length; i++) {
  4709. let _school = arr[i].school;
  4710. let _org = users.org;
  4711. //用戶數據
  4712. let _data = [_school, _org, "", "1", ""];
  4713. //參數拼接,註冊
  4714. _data.unshift(_mysqlLabor[0], _mysqlLabor[1], "insertSchoolByOrg");
  4715. //用戶註冊處理
  4716. mysql.usselect(_data, function(ret) {
  4717. res.end(JSON.stringify({ success: 1 }));
  4718. });
  4719. }
  4720. });
  4721. //批量添加学生
  4722. router.route("/batchRegistrationMore").post(function(req, res, next) {
  4723. let users = req.body[0];
  4724. let arr = JSON.parse(req.body[0].arr);
  4725. for (let i = 0; i < arr.length; i++) {
  4726. let _username = arr[i].name;
  4727. let _mail = arr[i].mail;
  4728. let _password = users.password || "123456";
  4729. let _alias = arr[i].name;
  4730. let _oid = users.oid;
  4731. let _ph = arr[i].phone ? arr[i].phone : "";
  4732. let _class = arr[i].class;
  4733. let _sId = arr[i].sId;
  4734. //加密密碼
  4735. _password = bcrypt.hashSync(_password, bcrypt.genSaltSync(10));
  4736. //生成激活碼
  4737. let _hashstr = new Date().getTime() + "";
  4738. let _digest = crypto
  4739. .createHash("sha256")
  4740. .update(_hashstr, "utf8")
  4741. .digest("hex");
  4742. //用戶數據
  4743. let _userdata = [
  4744. _mail,
  4745. _password,
  4746. _alias,
  4747. "",
  4748. 1, //0老师 1学生
  4749. _username,
  4750. "",
  4751. generateAPIKey(_username),
  4752. _digest,
  4753. "",
  4754. _username,
  4755. _sId,
  4756. 2, //1老师 2学生
  4757. _oid,
  4758. _ph,
  4759. _class,
  4760. "",
  4761. "0",
  4762. ];
  4763. //參數拼接,註冊
  4764. _userdata.unshift(_mysqluser[0], _mysqluser[1], "pbl_add_batchregister");
  4765. //用戶註冊處理
  4766. mysql.usselect(_userdata, function(ret) {
  4767. // let _pbluserdata = [
  4768. // ret[1][0].uid,
  4769. // _username,
  4770. // _sId,
  4771. // 2,
  4772. // _oid,
  4773. // _ph,
  4774. // _class,
  4775. // '',
  4776. // "0",
  4777. // ];
  4778. // _pbluserdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateUserByEdu");
  4779. // mysql.usselect(_pbluserdata, function(ret) {
  4780. res.end(JSON.stringify({ success: 1 }));
  4781. // });
  4782. });
  4783. }
  4784. });
  4785. //初始化密码
  4786. router.route("/iniPassword").post(function(req, res, next) {
  4787. let users = req.body[0];
  4788. _password = users.pa;
  4789. //加密密碼
  4790. _password = bcrypt.hashSync(_password, bcrypt.genSaltSync(10));
  4791. //用戶數據
  4792. let _userList = [users.uid, _password];
  4793. _userList.unshift(_mysqlLabor[0], _mysqlLabor[1], "iniPassword");
  4794. mysql.usselect(_userList, function(ret) {
  4795. res.end(JSON.stringify({ success: 1 }));
  4796. });
  4797. });
  4798. //批量添加教师
  4799. router.route("/batchRegistrationMore1").post(function(req, res, next) {
  4800. let users = req.body[0];
  4801. let arr = JSON.parse(req.body[0].arr);
  4802. for (let i = 0; i < arr.length; i++) {
  4803. let _username = arr[i].name;
  4804. let _mail = arr[i].mail;
  4805. let _password = users.password || "123456";
  4806. let _alias = arr[i].name;
  4807. let _org = users.org;
  4808. let _oid = arr[i].school;
  4809. let _ph = arr[i].phone ? arr[i].phone : "";
  4810. let _class = arr[i].class;
  4811. let _sId = arr[i].sId;
  4812. //加密密碼
  4813. _password = bcrypt.hashSync(_password, bcrypt.genSaltSync(10));
  4814. //生成激活碼
  4815. let _hashstr = new Date().getTime() + "";
  4816. let _digest = crypto
  4817. .createHash("sha256")
  4818. .update(_hashstr, "utf8")
  4819. .digest("hex");
  4820. //用戶數據
  4821. let _userdata = [
  4822. _mail,
  4823. _password,
  4824. _alias,
  4825. "",
  4826. 0, //0老师 1学生
  4827. _username,
  4828. "",
  4829. generateAPIKey(_username),
  4830. _digest,
  4831. "",
  4832. _username,
  4833. _sId,
  4834. 1, //1老师 2学生
  4835. _org,
  4836. _oid,
  4837. "",
  4838. "",
  4839. "",
  4840. "0",
  4841. ];
  4842. //參數拼接,註冊
  4843. _userdata.unshift(
  4844. _mysqluser[0],
  4845. _mysqluser[1],
  4846. "pbl_add_batchregister_oid"
  4847. );
  4848. //用戶註冊處理
  4849. mysql.usselect(_userdata, function(ret) {
  4850. res.end(JSON.stringify({ success: 1 }));
  4851. });
  4852. }
  4853. });
  4854. //赛事批量注册老师
  4855. router.route("/pbl_add_raceuser_oid").post(function(req, res, next) {
  4856. let users = req.body[0];
  4857. let arr = JSON.parse(req.body[0].arr);
  4858. for (let i = 0; i < arr.length; i++) {
  4859. let _username = arr[i].name;
  4860. let _mail = arr[i].mail;
  4861. let _password = users.password || "123456";
  4862. let _oid = arr[i].school;
  4863. //加密密碼
  4864. _password = bcrypt.hashSync(_password, bcrypt.genSaltSync(10));
  4865. //生成激活碼
  4866. let _hashstr = new Date().getTime() + "";
  4867. let _digest = crypto
  4868. .createHash("sha256")
  4869. .update(_hashstr, "utf8")
  4870. .digest("hex");
  4871. //用戶數據
  4872. let _userdata = [
  4873. _mail,
  4874. _oid,
  4875. _password,
  4876. _username,
  4877. 1, //1普通教师 2市级 3省级 4市级子级评委 5县区评委 6县区子级
  4878. ];
  4879. //參數拼接,註冊
  4880. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "pbl_add_raceuser_oid");
  4881. //用戶註冊處理
  4882. mysql.usselect(_userdata, function(ret) {
  4883. res.end(JSON.stringify({ success: 1 }));
  4884. });
  4885. }
  4886. });
  4887. //新增学生
  4888. router.route("/batchRegistration").post(function(req, res, next) {
  4889. var users = req.body[0];
  4890. //循环注册
  4891. var _username = users.alias;
  4892. var _mail = users.username;
  4893. var _password = users.password || "123456";
  4894. var _alias = users.alias;
  4895. var _oid = users.oid;
  4896. var _ph = users.ph;
  4897. var _class = users.cid;
  4898. var _sId = users.sid;
  4899. //加密密碼
  4900. _password = bcrypt.hashSync(_password, bcrypt.genSaltSync(10));
  4901. //生成激活碼
  4902. let _hashstr = new Date().getTime() + "";
  4903. let _digest = crypto
  4904. .createHash("sha256")
  4905. .update(_hashstr, "utf8")
  4906. .digest("hex");
  4907. //用戶數據
  4908. var _userdata = [
  4909. _mail,
  4910. _password,
  4911. _alias,
  4912. "",
  4913. 1,
  4914. _username,
  4915. "",
  4916. generateAPIKey(_username),
  4917. _digest,
  4918. "",
  4919. _username,
  4920. _sId,
  4921. 2,
  4922. _oid,
  4923. _ph,
  4924. _class,
  4925. "",
  4926. "0",
  4927. ];
  4928. //參數拼接,註冊
  4929. _userdata.unshift(_mysqluser[0], _mysqluser[1], "pbl_add_batchregister");
  4930. //用戶註冊處理
  4931. mysql.usselect(_userdata, function(ret) {
  4932. res.end(
  4933. JSON.stringify({
  4934. uid: ret[1][0].uid,
  4935. ph: _ph,
  4936. oid: _oid,
  4937. cid: _class,
  4938. success: 1,
  4939. })
  4940. );
  4941. });
  4942. });
  4943. //新增教师
  4944. router.route("/batchRegistration1").post(function(req, res, next) {
  4945. var users = req.body[0];
  4946. //循环注册
  4947. var _username = users.alias;
  4948. var _mail = users.username;
  4949. var _password = users.password || "123456";
  4950. var _alias = users.alias;
  4951. var _org = users.org;
  4952. var _oid = users.oid;
  4953. var _ph = users.ph;
  4954. var _class = users.cid;
  4955. var _sId = users.sid;
  4956. //加密密碼
  4957. _password = bcrypt.hashSync(_password, bcrypt.genSaltSync(10));
  4958. //生成激活碼
  4959. let _hashstr = new Date().getTime() + "";
  4960. let _digest = crypto
  4961. .createHash("sha256")
  4962. .update(_hashstr, "utf8")
  4963. .digest("hex");
  4964. //用戶數據
  4965. var _userdata = [
  4966. _mail,
  4967. _password,
  4968. _alias,
  4969. "",
  4970. 0,
  4971. _username,
  4972. "",
  4973. generateAPIKey(_username),
  4974. _digest,
  4975. "",
  4976. _username,
  4977. _sId,
  4978. 1,
  4979. _org,
  4980. _oid,
  4981. _ph,
  4982. _class,
  4983. "",
  4984. "0",
  4985. ];
  4986. //參數拼接,註冊
  4987. _userdata.unshift(_mysqluser[0], _mysqluser[1], "pbl_add_batchregister1");
  4988. //用戶註冊處理
  4989. mysql.usselect(_userdata, function(ret) {
  4990. res.end(
  4991. JSON.stringify({
  4992. uid: ret[1][0].uid,
  4993. ph: _ph,
  4994. oid: _oid,
  4995. cid: _class,
  4996. success: 1,
  4997. })
  4998. );
  4999. });
  5000. });
  5001. router.route("/batchRegistrationOrg").post(function(req, res, next) {
  5002. var users = req.body[0];
  5003. //循环注册
  5004. var _username = users.alias;
  5005. var _mail = users.username;
  5006. var _password = users.password || "123456";
  5007. var _alias = users.alias;
  5008. var _oid = users.oid;
  5009. var _ph = users.ph;
  5010. var _class = users.cid;
  5011. var _sId = users.sid;
  5012. var _org = users.org;
  5013. //加密密碼
  5014. _password = bcrypt.hashSync(_password, bcrypt.genSaltSync(10));
  5015. //生成激活碼
  5016. let _hashstr = new Date().getTime() + "";
  5017. let _digest = crypto
  5018. .createHash("sha256")
  5019. .update(_hashstr, "utf8")
  5020. .digest("hex");
  5021. //用戶數據
  5022. var _userdata = [
  5023. _mail,
  5024. _password,
  5025. _alias,
  5026. "",
  5027. 1,
  5028. _username,
  5029. "",
  5030. generateAPIKey(_username),
  5031. _digest,
  5032. "",
  5033. _username,
  5034. _sId,
  5035. 2,
  5036. _oid,
  5037. _ph,
  5038. _class,
  5039. "",
  5040. "0",
  5041. _org,
  5042. ];
  5043. //參數拼接,註冊
  5044. _userdata.unshift(_mysqluser[0], _mysqluser[1], "pbl_add_batchregister_org");
  5045. //用戶註冊處理
  5046. mysql.usselect(_userdata, function(ret) {
  5047. res.end(
  5048. JSON.stringify({
  5049. uid: ret[1][0].uid,
  5050. ph: _ph,
  5051. oid: _oid,
  5052. cid: _class,
  5053. success: 1,
  5054. })
  5055. );
  5056. });
  5057. });
  5058. router.route("/batchRegistrationMoreOrg").post(function(req, res, next) {
  5059. let users = req.body[0];
  5060. let arr = JSON.parse(req.body[0].arr);
  5061. for (let i = 0; i < arr.length; i++) {
  5062. let _username = arr[i].name;
  5063. let _mail = arr[i].mail;
  5064. let _password = users.password || "123456";
  5065. let _alias = arr[i].name;
  5066. let _oid = users.oid;
  5067. let _ph = arr[i].phone ? arr[i].phone : "";
  5068. let _class = arr[i].class;
  5069. let _sId = arr[i].sId;
  5070. let _org = users.org;
  5071. //加密密碼
  5072. _password = bcrypt.hashSync(_password, bcrypt.genSaltSync(10));
  5073. //生成激活碼
  5074. let _hashstr = new Date().getTime() + "";
  5075. let _digest = crypto
  5076. .createHash("sha256")
  5077. .update(_hashstr, "utf8")
  5078. .digest("hex");
  5079. //用戶數據
  5080. let _userdata = [
  5081. _mail,
  5082. _password,
  5083. _alias,
  5084. "",
  5085. 1, //0老师 1学生
  5086. _username,
  5087. "",
  5088. generateAPIKey(_username),
  5089. _digest,
  5090. "",
  5091. _username,
  5092. _sId,
  5093. 2, //1老师 2学生
  5094. _oid,
  5095. _ph,
  5096. _class,
  5097. "",
  5098. "0",
  5099. _org,
  5100. ];
  5101. //參數拼接,註冊
  5102. _userdata.unshift(
  5103. _mysqluser[0],
  5104. _mysqluser[1],
  5105. "pbl_add_batchregister_org2"
  5106. );
  5107. //用戶註冊處理
  5108. mysql.usselect(_userdata, function(ret) {
  5109. res.end(JSON.stringify({ success: 1 }));
  5110. });
  5111. }
  5112. });
  5113. //工作室管理
  5114. router.route("/updateStudioWorkNew4").all((req, res, next) => {
  5115. //学生
  5116. if (req.body[0]) {
  5117. let p = [req.body[0].cid];
  5118. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_studio_course_detail2"); //執行存儲過程
  5119. mysql.usselect(p, function(ret) {
  5120. let _unitIndex = parseInt(req.body[0].unitIndex);
  5121. let _chapters = JSON.parse(req.body[0].chapters);
  5122. let _unitJson = JSON.parse(ret[0][0].chapters);
  5123. if (_unitJson.length - 1 < _unitIndex) {
  5124. let _i = _unitIndex - (_unitJson.length - 1);
  5125. for (let i = 0; i < _i; i++) {
  5126. _unitJson.push({
  5127. dyName: "", //单元标题
  5128. chapterInfo: [{
  5129. isread: false,
  5130. chapterid: guid(),
  5131. title: "",
  5132. courseName: "",
  5133. taskJson: [{
  5134. task: "",
  5135. taskDetail: "",
  5136. chapterData: [],
  5137. toolText: "",
  5138. toolChoose: [{
  5139. tool: [],
  5140. toolDetail: "",
  5141. toolType: 0,
  5142. askCount: 1,
  5143. askTitle: "",
  5144. askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
  5145. }, ],
  5146. isShowTools: false,
  5147. askCount: 1,
  5148. isFold: 0,
  5149. askTitle: "",
  5150. askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
  5151. checkJson: [{ checkCount: [], checkPerent: [] }],
  5152. homeworkList: [],
  5153. }, ],
  5154. itemCount: 1,
  5155. fileList1: [],
  5156. video: [],
  5157. testData: [],
  5158. pData: [],
  5159. templateArray: [],
  5160. }, ],
  5161. });
  5162. }
  5163. _unitJson[_unitIndex] = _chapters[_unitIndex];
  5164. } else {
  5165. _unitJson[_unitIndex] = _chapters[_unitIndex];
  5166. }
  5167. // console.log(_unitJson);
  5168. let p2 = [
  5169. req.body[0].cid,
  5170. JSON.stringify(_unitJson).replaceAll(/%/g, "%25"),
  5171. ];
  5172. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudioWorkNew4"); //執行存儲過程
  5173. mysql.usselect(p2, function(ret) {
  5174. res.end(JSON.stringify({ success: 1 }));
  5175. });
  5176. // res.end(JSON.stringify({ success: 1 }));
  5177. });
  5178. }
  5179. });
  5180. router.route("/updateStudioWorkNew2").all((req, res, next) => {
  5181. //学生
  5182. if (req.body[0]) {
  5183. p = [
  5184. req.body[0].cid,
  5185. req.body[0].title,
  5186. req.body[0].brief,
  5187. req.body[0].cover,
  5188. req.body[0].evaId,
  5189. req.body[0].astudent,
  5190. req.body[0].see,
  5191. req.body[0].chapters,
  5192. req.body[0].template,
  5193. req.body[0].ateacher,
  5194. ];
  5195. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudioWorkNew2"); //執行存儲過程
  5196. mysql.usselect(p, function(ret) {
  5197. let course = req.body[0].courseType;
  5198. let courseId = req.body[0].cid;
  5199. let userid = req.body[0].uid;
  5200. delStudioCourseTypeS(course, courseId, userid);
  5201. res.end(JSON.stringify({ success: 1 }));
  5202. });
  5203. }
  5204. });
  5205. router.route("/addStudioCourseWorkNew2").all((req, res, next) => {
  5206. //学生
  5207. if (req.body[0]) {
  5208. p = [
  5209. req.body[0].uid,
  5210. req.body[0].title,
  5211. req.body[0].brief,
  5212. req.body[0].cover,
  5213. req.body[0].evaId,
  5214. req.body[0].astudent,
  5215. req.body[0].see,
  5216. req.body[0].chapters,
  5217. req.body[0].template,
  5218. req.body[0].ateacher,
  5219. ];
  5220. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addStudioCourseWorkNew2"); //執行存儲過程
  5221. mysql.usselect(p, function(ret) {
  5222. let course = req.body[0].courseType;
  5223. let courseId = ret[0][0].courseId;
  5224. let userid = req.body[0].uid;
  5225. delStudioCourseTypeS(course, courseId, userid);
  5226. res.end(
  5227. JSON.stringify({
  5228. ordernumber: ret[0][0].ordernumber,
  5229. courseId: ret[0][0].courseId,
  5230. success: 1,
  5231. })
  5232. );
  5233. });
  5234. }
  5235. });
  5236. //teacher 查询项目模板
  5237. router.route("/getStudioTemplateTs").all((req, res, next) => {
  5238. var json = queryString(req.url);
  5239. getmysql(req, res, "getStudioTemplateTs", json["oid"]);
  5240. });
  5241. //查看课程
  5242. router.route("/select_studio_course_detail").all((req, res, next) => {
  5243. //学生
  5244. var json = queryString(req.url);
  5245. getmysql(req, res, "select_studio_course_detail", json["cid"]);
  5246. });
  5247. //查看课程
  5248. router.route("/select_studio_course_detail2").all((req, res, next) => {
  5249. //学生
  5250. var json = queryString(req.url);
  5251. getmysql(req, res, "select_studio_course_detail2", json["cid"]);
  5252. });
  5253. //协同恢复删除的阶段
  5254. router.route("/restoreStudioWork").all((req, res, next) => {
  5255. //学生
  5256. if (req.body[0]) {
  5257. let p = [req.body[0].cid];
  5258. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "select_studio_course_detail2"); //執行存儲過程
  5259. mysql.usselect(p, function(ret) {
  5260. let _chapid = req.body[0].chapid;
  5261. // console.log(_chapid);
  5262. let _chapters = JSON.parse(req.body[0].chapters);
  5263. let _unitJson = JSON.parse(ret[0][0].chapters);
  5264. let _unitJson2 = [];
  5265. let chpaindex;
  5266. for (var i = 0; i < _chapters.length; i++) {
  5267. if (_chapters[i].chapterInfo[0].chapterid == _chapid) {
  5268. chpaindex = i;
  5269. }
  5270. }
  5271. for (var i = 0; i < _unitJson.length; i++) {
  5272. if (_unitJson[i].chapterInfo[0].chapterid != _chapid) {
  5273. // console.log(1);
  5274. // _unitJson.splice(i, -1)
  5275. _unitJson2.push(_unitJson[i]);
  5276. // break;
  5277. }
  5278. }
  5279. _unitJson2.splice(chpaindex, 0, _chapters[chpaindex]);
  5280. // console.log(_unitJson2);
  5281. let p2 = [
  5282. req.body[0].cid,
  5283. JSON.stringify(_unitJson2).replaceAll(/%/g, "%25"),
  5284. ];
  5285. p2.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateStudioWorkNew4"); //執行存儲過程
  5286. mysql.usselect(p2, function(ret) {
  5287. res.end(JSON.stringify({ success: 1 }));
  5288. });
  5289. // res.end(JSON.stringify({ success: 1 }));
  5290. });
  5291. }
  5292. });
  5293. //查询分类及所有子分类
  5294. router.route("/selectAllTypeStudio").all((req, res, next) => {
  5295. var json = queryString(req.url);
  5296. getmysql(req, res, "selectAllTypeStudio", json["org"], json["oid"]);
  5297. });
  5298. //上传文件
  5299. router.route("/addStudioCourseWorksS").all((req, res, next) => {
  5300. postmysql(req, res, "addStudioCourseWorksS");
  5301. });
  5302. //删除提交的作业
  5303. router.route("/deleteStudioCourseWorkS").all((req, res, next) => {
  5304. postmysql(req, res, "deleteStudioCourseWorkS");
  5305. });
  5306. router.route("/selectStudioCourseNew222").all((req, res, next) => {
  5307. var json = queryString(req.url);
  5308. getmysql(
  5309. req,
  5310. res,
  5311. "selectStudioCourseNew222",
  5312. json["type"],
  5313. json["uid"],
  5314. json["oid"],
  5315. json["org"],
  5316. json["typea"],
  5317. json["typeb"],
  5318. json["typec"],
  5319. json["typed"],
  5320. json["typef"],
  5321. json["typeE"],
  5322. json["cu"],
  5323. json["cn"],
  5324. json["page"],
  5325. json["pageSize"]
  5326. );
  5327. });
  5328. //删除课程
  5329. router.route("/deleteStudioCourse").all((req, res, next) => {
  5330. var json = queryString(req.url);
  5331. getmysql(req, res, "deleteStudioCourse", json["cid"]);
  5332. });
  5333. function delStudioCourseTypeS(course, courseId, userid) {
  5334. let _courseId = courseId;
  5335. var _userdata = [_courseId];
  5336. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "delete_studioCourseTypeS");
  5337. mysql.usselect(_userdata, function(ret) {
  5338. // console.log(ret);
  5339. addStudioCourseTypeS(userid, course, _courseId);
  5340. });
  5341. // setTimeout(() => {
  5342. // }, 1000);
  5343. }
  5344. function addStudioCourseTypeS(userid, course, _courseId) {
  5345. var _uid = userid;
  5346. var _courses = _courseId;
  5347. var _tid = JSON.parse(course);
  5348. for (let i = 0; i < _tid.length; i++) {
  5349. if (_tid[i] == "") {
  5350. continue;
  5351. }
  5352. var _userdata = [_courses, _tid[i], _uid];
  5353. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "add_studioCourseTypeS");
  5354. mysql.usselect(_userdata, function(ret) {
  5355. // console.log(ret);
  5356. });
  5357. }
  5358. }
  5359. //删除作业阶段任务工具
  5360. router.route("/deleteStudioToolSTT").all((req, res, next) => {
  5361. postmysql(req, res, "deleteStudioToolSTT");
  5362. });
  5363. //删除作业阶段任务
  5364. router.route("/deleteStudioToolST").all((req, res, next) => {
  5365. postmysql(req, res, "deleteStudioToolST");
  5366. });
  5367. //删除作业阶段
  5368. router.route("/deleteStudioToolS").all((req, res, next) => {
  5369. postmysql(req, res, "deleteStudioToolST");
  5370. });
  5371. //工作管理首页查询分类
  5372. router.route("/selectStudioCourseNew22Mode").all((req, res, next) => {
  5373. var json = queryString(req.url);
  5374. getmysql(
  5375. req,
  5376. res,
  5377. "selectStudioCourseNew22Mode",
  5378. json["type"],
  5379. json["uid"],
  5380. json["oid"],
  5381. json["org"],
  5382. json["typea"],
  5383. json["typeb"],
  5384. json["typec"],
  5385. json["typed"],
  5386. json["typef"],
  5387. json["typeE"],
  5388. json["cu"],
  5389. json["cn"]
  5390. );
  5391. });
  5392. //工作管理首页查询
  5393. router.route("/selectStudioCourseNew22").all((req, res, next) => {
  5394. var json = queryString(req.url);
  5395. getmysql(
  5396. req,
  5397. res,
  5398. "selectStudioCourseNew22",
  5399. json["type"],
  5400. json["uid"],
  5401. json["oid"],
  5402. json["org"],
  5403. json["typea"],
  5404. json["typeb"],
  5405. json["typec"],
  5406. json["typed"],
  5407. json["typef"],
  5408. json["typeE"],
  5409. json["cu"],
  5410. json["cn"],
  5411. json["page"],
  5412. json["pageSize"]
  5413. );
  5414. });
  5415. //根据学校查询banner
  5416. router.route("/selectBannerByOidStudio").all((req, res, next) => {
  5417. var json = queryString(req.url);
  5418. getmysql(req, res, "selectBannerByOidStudio", json["oid"]);
  5419. });
  5420. //admin 查询banner
  5421. router.route("/getBannerStudio").all((req, res, next) => {
  5422. var json = queryString(req.url);
  5423. getmysql(req, res, "getBannerStudio");
  5424. });
  5425. //查询工作课程详情
  5426. router.route("/selectStudioCourseDetail2").all((req, res, next) => {
  5427. //学生
  5428. var json = queryString(req.url);
  5429. getmysql(req, res, "selectStudioCourseDetail2", json["courseId"]);
  5430. });
  5431. //查询工作课程详情
  5432. router.route("/selectStudioCourseDetail3").all((req, res, next) => {
  5433. //学生
  5434. var json = queryString(req.url);
  5435. getmysql(req, res, "selectStudioCourseDetail3", json["courseId"]);
  5436. });
  5437. //上传文件
  5438. router.route("/addCourseWorks4studio").all((req, res, next) => {
  5439. postmysql3(req, res, "addCourseWorks4studio");
  5440. });
  5441. //查询教师资源分类
  5442. router.route("/selectAllSourceType").all((req, res, next) => {
  5443. //学生
  5444. var json = queryString(req.url);
  5445. getmysql(req, res, "selectAllSourceType", json["oid"], json["org"]);
  5446. });
  5447. router.route("/addSource").all((req, res, next) => {
  5448. //添加资源
  5449. if (req.body[0]) {
  5450. p = [
  5451. req.body[0].name,
  5452. req.body[0].url,
  5453. req.body[0].detail,
  5454. req.body[0].label,
  5455. req.body[0].userid,
  5456. ];
  5457. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addSource");
  5458. //執行存儲過程
  5459. mysql.usselect(p, function(ret) {
  5460. let course = req.body[0].courseType;
  5461. let courseId = ret[0][0].id;
  5462. let userid = req.body[0].userid;
  5463. delSourceType(course, courseId, userid);
  5464. res.end(JSON.stringify({ id: ret[0][0].id, success: 1 }));
  5465. // res.end(JSON.stringify(ret));
  5466. });
  5467. }
  5468. });
  5469. router.route("/updateSource").all((req, res, next) => {
  5470. //修改资源
  5471. if (req.body[0]) {
  5472. p = [
  5473. req.body[0].id,
  5474. req.body[0].name,
  5475. req.body[0].url,
  5476. req.body[0].detail,
  5477. req.body[0].label,
  5478. req.body[0].userid,
  5479. ];
  5480. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateSource");
  5481. //執行存儲過程
  5482. mysql.usselect(p, function(ret) {
  5483. let course = req.body[0].courseType;
  5484. let courseId = req.body[0].id;
  5485. let userid = req.body[0].userid;
  5486. delSourceType(course, courseId, userid);
  5487. res.end(JSON.stringify({ id: req.body[0].id, success: 1 }));
  5488. // res.end(JSON.stringify(ret));
  5489. });
  5490. }
  5491. });
  5492. function delSourceType(course, courseId, userid) {
  5493. let _courseId = courseId;
  5494. var _userdata = [_courseId];
  5495. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "delete_sourceType");
  5496. mysql.usselect(_userdata, function(ret) {
  5497. addSourceType(userid, course, _courseId);
  5498. });
  5499. }
  5500. function addSourceType(userid, course, _courseId) {
  5501. var _uid = userid;
  5502. var _courses = _courseId;
  5503. var _tid = JSON.parse(course);
  5504. for (let i = 0; i < _tid.length; i++) {
  5505. if (_tid[i] == "") {
  5506. continue;
  5507. }
  5508. var _userdata = [_courses, _tid[i], _uid];
  5509. _userdata.unshift(_mysqlLabor[0], _mysqlLabor[1], "add_sourceType");
  5510. mysql.usselect(_userdata, function(ret) {
  5511. // console.log(ret);
  5512. });
  5513. }
  5514. }
  5515. //资源查询
  5516. router.route("/selectSource").all((req, res, next) => {
  5517. var json = queryString(req.url);
  5518. getmysql(
  5519. req,
  5520. res,
  5521. "selectSource",
  5522. json["uid"],
  5523. json["oid"],
  5524. json["org"],
  5525. json["typea"],
  5526. json["typeb"],
  5527. json["typeE"],
  5528. json["cn"],
  5529. json["page"],
  5530. json["pageSize"]
  5531. );
  5532. });
  5533. //数据看板-综合数据
  5534. router.route("/selectDataBoardSchool").all((req, res, next) => {
  5535. postmysql(req, res, "selectDataBoardSchool");
  5536. });
  5537. //数据看板-教师数据
  5538. router.route("/selectDataBoardTeacher").all((req, res, next) => {
  5539. postmysql(req, res, "selectDataBoardTeacher");
  5540. });
  5541. //数据看板-学生数据
  5542. router.route("/selectDataBoardStudent").all((req, res, next) => {
  5543. postmysql(req, res, "selectDataBoardStudent");
  5544. });
  5545. //数据看板-课程数据
  5546. router.route("/selectDataBoardCourse").all((req, res, next) => {
  5547. postmysql(req, res, "selectDataBoardCourse");
  5548. });
  5549. //数据看板-综合数据
  5550. router.route("/selectDataBoardSchoolNew").all((req, res, next) => {
  5551. postmysql(req, res, "selectDataBoardSchoolNew");
  5552. });
  5553. //数据看板-教师数据
  5554. router.route("/selectDataBoardTeacherNew").all((req, res, next) => {
  5555. postmysql(req, res, "selectDataBoardTeacherNew");
  5556. });
  5557. //数据看板-学生数据
  5558. router.route("/selectDataBoardStudentNew").all((req, res, next) => {
  5559. postmysql(req, res, "selectDataBoardStudentNew");
  5560. });
  5561. //数据看板-课程数据
  5562. router.route("/selectDataBoardCourseNew").all((req, res, next) => {
  5563. postmysql(req, res, "selectDataBoardCourseNew");
  5564. });
  5565. //数据看板-课程数据
  5566. router.route("/selectDataBoardStudentCourseNew").all((req, res, next) => {
  5567. postmysql(req, res, "selectDataBoardStudentCourseNew");
  5568. });
  5569. //数据看板-学生排行榜
  5570. router.route("/selectDataboardStudentRank").all((req, res, next) => {
  5571. postmysql(req, res, "selectDataboardStudentRank");
  5572. });
  5573. //数据看板-查询项目数据长度
  5574. router.route("/getCourseLength").all((req, res, next) => {
  5575. postmysql(req, res, "getCourseLength");
  5576. });
  5577. //评测中心-上传评测
  5578. router.route("/addTestWorks").all((req, res, next) => {
  5579. postmysql(req, res, "addTestWorks");
  5580. });
  5581. //评测中心-上传评测
  5582. router.route("/addTestWorks2").all((req, res, next) => {
  5583. postmysql(req, res, "addTestWorks2");
  5584. });
  5585. //评测中心-上传评测
  5586. router.route("/addTestWorks2").all((req, res, next) => {
  5587. postmysql(req, res, "addTestWorks2");
  5588. });
  5589. //评测中心-删除评测
  5590. router.route("/deleteTestCourse").all((req, res, next) => {
  5591. postmysql(req, res, "deleteTestCourse");
  5592. });
  5593. //评测中心-批改
  5594. router.route("/addTestWorksTeacher").all((req, res, next) => {
  5595. postmysql(req, res, "addTestWorksTeacher");
  5596. });
  5597. //评测中心-复制评测
  5598. router.route("/copyTestWorks").all((req, res, next) => {
  5599. postmysql(req, res, "copyTestWorks");
  5600. });
  5601. //评测中心-查询用户测评总览
  5602. router.route("/selectTestUserY").all((req, res, next) => {
  5603. var json = queryString(req.url);
  5604. getmysql(req, res, "selectTestUserY", json["uid"], json["oid"], json["org"]);
  5605. });
  5606. //评测中心-查询用户数据
  5607. router.route("/selectTestUser").all((req, res, next) => {
  5608. var json = queryString(req.url);
  5609. getmysql(req, res, "selectTestUser", json["uid"]);
  5610. });
  5611. //评测中心-获取评测提交详情
  5612. router.route("/getTestWorks").all((req, res, next) => {
  5613. var json = queryString(req.url);
  5614. getmysql(req, res, "getTestWorks", json["cid"], json["uid"]);
  5615. });
  5616. //评测中心-获取评测提交详情
  5617. router.route("/getTestWorks2").all((req, res, next) => {
  5618. var json = queryString(req.url);
  5619. getmysql(req, res, "getTestWorks2", json["cid"], json["tid"]);
  5620. });
  5621. //评测中心-获取评测提交详情
  5622. router.route("/getTestWorksPage").all((req, res, next) => {
  5623. var json = queryString(req.url);
  5624. getmysql(req, res, "getTestWorksPage", json["cid"], json["page"], json["pageSize"]);
  5625. });
  5626. //评测中心-个人中心
  5627. router.route("/getTestWorksPerson").all((req, res, next) => {
  5628. var json = queryString(req.url);
  5629. getmysql(req, res, "getTestWorksPerson", json["uid"], json["typeid"]);
  5630. });
  5631. //查询英语写作评价模板
  5632. router.route("/selectEnglishEva").all((req, res, next) => {
  5633. var json = queryString(req.url);
  5634. getmysql(req, res, "selectEnglishEva", json["oid"]);
  5635. });
  5636. //新增英语写作评价模板
  5637. router.route("/insertEnglishEva").all((req, res, next) => {
  5638. postmysql(req, res, "insertEnglishEva");
  5639. });
  5640. //获取作业数量
  5641. router.route("/getCourseWorkCount").all((req, res, next) => {
  5642. postmysql(req, res, "getCourseWorkCount");
  5643. });
  5644. //根据id查询英语写作评价模板
  5645. router.route("/selectEnglishEvaById").all((req, res, next) => {
  5646. var json = queryString(req.url);
  5647. getmysql(req, res, "selectEnglishEvaById", json["id"], json["oid"]);
  5648. });
  5649. //根据id删除英语写作评价模板
  5650. router.route("/deleteEnglishEvaById").all((req, res, next) => {
  5651. var json = queryString(req.url);
  5652. getmysql(req, res, "deleteEnglishEvaById", json["id"]);
  5653. });
  5654. //案例新项目登录接口
  5655. router.route("/loginNewEvenManage").all((req, res, next) => {
  5656. postmysql(req, res, "loginNewEvenManage");
  5657. });
  5658. //案例新项目创建用户接口
  5659. router.route("/addNewRaceUser").all((req, res, next) => {
  5660. postmysql(req, res, "addNewRaceUser");
  5661. });
  5662. //查询老师的信息
  5663. router.route("/getRaceUser1").all((req, res, next) => {
  5664. var json = queryString(req.url);
  5665. getmysql(req, res, "getRaceUser1", json["uid"]);
  5666. });
  5667. //修改用户信息
  5668. router.route("/updateRaceUser1").all((req, res, next) => {
  5669. postmysql(req, res, "updateRaceUser1");
  5670. });
  5671. /* 修改评审员 */
  5672. router.route("/updateReviewer").all((req, res, next) => {
  5673. var json = queryString(req.url);
  5674. getmysql(
  5675. req,
  5676. res,
  5677. "updateReviewer",
  5678. json["n"],
  5679. json["p"],
  5680. json["t"],
  5681. json["s"],
  5682. json["uid"]
  5683. );
  5684. });
  5685. //race 查询学校
  5686. router.route("/getSchool1").all((req, res, next) => {
  5687. var json = queryString(req.url);
  5688. getmysql(req, res, "getSchool1", json["n"]);
  5689. });
  5690. //查询赛事项目列表
  5691. router.route("/selectRaceList1").all((req, res, next) => {
  5692. var json = queryString(req.url);
  5693. getmysql(req, res, "selectRaceList1", json["uid"], json["t"], json["oid"], json["org"]);
  5694. });
  5695. //修改赛事状态
  5696. router.route("/updateRaceStateGM").all((req, res, next) => {
  5697. var json = queryString(req.url);
  5698. getmysql(req, res, "updateRaceStateGM", json["id"], json["s"]);
  5699. });
  5700. //删除案例
  5701. router.route("/deleteAnliGM").all((req, res, next) => {
  5702. var json = queryString(req.url);
  5703. getmysql(req, res, "deleteAnliGM", json["id"]);
  5704. });
  5705. //新增赛事项目
  5706. router.route("/addRaceGM").all((req, res, next) => {
  5707. if (req.body[0]) {
  5708. p = [
  5709. req.body[0].uid,
  5710. req.body[0].info,
  5711. req.body[0].over,
  5712. req.body[0].pro,
  5713. req.body[0].act,
  5714. req.body[0].exc,
  5715. req.body[0].res,
  5716. ];
  5717. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "addRaceGM"); //執行存儲過程
  5718. mysql.usselect(p, function(ret) {
  5719. let course = req.body[0].courseType;
  5720. let courseId = ret[0][0].id;
  5721. let userid = req.body[0].uid;
  5722. delCourseType1(course, courseId, userid);
  5723. res.end(JSON.stringify({ courseId: courseId, success: 1 }));
  5724. });
  5725. }
  5726. });
  5727. //修改赛事项目
  5728. router.route("/updateRaceGM").all((req, res, next) => {
  5729. if (req.body[0]) {
  5730. p = [
  5731. req.body[0].id,
  5732. req.body[0].info,
  5733. req.body[0].over,
  5734. req.body[0].pro,
  5735. req.body[0].act,
  5736. req.body[0].exc,
  5737. req.body[0].res,
  5738. ];
  5739. p.unshift(_mysqlLabor[0], _mysqlLabor[1], "updateRaceGM"); //執行存儲過程
  5740. mysql.usselect(p, function(ret) {
  5741. let course = req.body[0].courseType;
  5742. let courseId = req.body[0].id;
  5743. let userid = req.body[0].uid;
  5744. delCourseType1(course, courseId, userid);
  5745. res.end(JSON.stringify({ success: 1 }));
  5746. });
  5747. }
  5748. });
  5749. //查询赛事项目详情
  5750. router.route("/selectRaceDetailGM").all((req, res, next) => {
  5751. var json = queryString(req.url);
  5752. getmysql(req, res, "selectRaceDetailGM", json["id"]);
  5753. });
  5754. //查询赛事分类及子分类
  5755. router.route("/selectMatTypeGM").all((req, res, next) => {
  5756. var json = queryString(req.url);
  5757. getmysql(req, res, "selectMatTypeGM");
  5758. });
  5759. function generateAPIKey(username) {
  5760. let timeStamp = new Date().getTime();
  5761. let hashStr = timeStamp + username;
  5762. let digest = crypto
  5763. .createHash("sha256")
  5764. .update(hashStr, "utf8")
  5765. .digest("hex");
  5766. return digest;
  5767. }
  5768. queryString = function(url) {
  5769. var a = url.split("?");
  5770. var json = querystring.parse(a[1]);
  5771. return json;
  5772. };
  5773. //post存儲過程處理
  5774. postmysql = function(req, res, functionname) {
  5775. //mode的處理
  5776. if (req.body[0]) {
  5777. p = Object.values(req.body[0]);
  5778. p.unshift(_mysqlLabor[0], _mysqlLabor[1], functionname);
  5779. //執行存儲過程
  5780. mysql.usselect(p, function(ret) {
  5781. res.end(JSON.stringify(ret));
  5782. });
  5783. }
  5784. };
  5785. //post存儲過程處理
  5786. postmysql2 = function(req, res, functionname) {
  5787. //mode的處理
  5788. if (req.body) {
  5789. p = Object.values(req.body)[0].split(",");
  5790. p.unshift(_mysqlLabor[0], _mysqlLabor[1], functionname);
  5791. //執行存儲過程
  5792. mysql.usselect(p, function(ret) {
  5793. res.end(JSON.stringify(ret));
  5794. });
  5795. }
  5796. };
  5797. //post存儲過程處理
  5798. postmysql3 = function(req, res, functionname) {
  5799. //mode的處理
  5800. if (req.body) {
  5801. p = Object.values(req.body);
  5802. p.unshift(_mysqlLabor[0], _mysqlLabor[1], functionname);
  5803. //執行存儲過程
  5804. mysql.usselect(p, function(ret) {
  5805. res.end(JSON.stringify(ret));
  5806. });
  5807. }
  5808. };
  5809. //get獲取數據庫信息
  5810. getmysql = function(req, res, functionname, ...p) {
  5811. p = p || [];
  5812. p.unshift(_mysqlLabor[0], _mysqlLabor[1], functionname);
  5813. //執行存儲過程
  5814. mysql.usselect(p, function(ret) {
  5815. res.end(JSON.stringify(ret));
  5816. }); //
  5817. };
  5818. //post存储过程处理
  5819. userpostmysql = function(req, res, functionname) {
  5820. //mode的处理
  5821. if (req.body.mode) {
  5822. p = req.body.mode.split(",");
  5823. p.unshift(_mysqluser[0], _mysqluser[1], functionname);
  5824. //执行存储过程
  5825. mysql.usselect(p, function(ret) {
  5826. res.end(JSON.stringify(ret));
  5827. });
  5828. }
  5829. };
  5830. //get获取数据库信息
  5831. usergetmysql = function(req, res, functionname, ...p) {
  5832. p = p || [];
  5833. p.unshift(_mysqluser[0], _mysqluser[1], functionname);
  5834. //执行存储过程
  5835. mysql.usselect(p, function(ret) {
  5836. res.end(JSON.stringify(ret));
  5837. }); //
  5838. };
  5839. module.exports = router;