views.py 174 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636
  1. import copy
  2. # Create your views here.
  3. import datetime
  4. import json
  5. import os
  6. import re
  7. import time
  8. import urllib.request
  9. import requests
  10. from django.http import FileResponse
  11. from django.http.response import HttpResponse
  12. from django.shortcuts import render
  13. from django.views.generic import ListView
  14. from django.views.generic.base import View
  15. from django.contrib.auth.hashers import make_password, check_password
  16. from PIL import Image
  17. from django.utils import timezone
  18. import xmltodict
  19. from requests.auth import HTTPBasicAuth
  20. from django.contrib.auth import get_user_model
  21. from apps.AppInfo.models import (
  22. Article, CKArticle, Equip, Equip_type, FarmList, FarmUser, GardenManage,
  23. Hotel_Info, Hotel_Photo, JKdata, MyUser, Pick_Pub, Product, QXZdata,
  24. QXZdata_New, QXZstatus, QXZstatus_New, QXZswitchdata, QXZswitchstatus,
  25. Video_data,GardenArea,Store_Manage,Areacrop,Sell_Manage,Person_Pick,QXZAutoswitch,Sightsee_Info,Pic_Info,
  26. QXZ_Alarm_Log,Experts,Relations,QXZ_Alarm,QXZ_Conf,QXZ_Base_Info,QXZ_Default_Conf,QXZ_Info_Record,SystemPhoto)
  27. from apps.Equipment.all_dict import qxz_dict
  28. import xlwt
  29. from io import BytesIO
  30. # 地图
  31. class Map_Test(View):
  32. def get(self,request):
  33. # current_user = request.session.get('username')
  34. username = request.user.username
  35. print('username:',username)
  36. current_user = MyUser.objects.get(username=username)
  37. # print("current_user:", current_user)
  38. # current_user = MyUser.objects.get(username=current_user)
  39. try:
  40. pic_list = Pic_Info.objects.get(pic_user=current_user)
  41. except:
  42. pic_list = ""
  43. return render(request, 'backstageNet/map/map.html', context={"pic_list":pic_list})
  44. def post(self,request):
  45. pass
  46. # 测试接口
  47. class Equip_Test(View):
  48. def get(self,request):
  49. pass
  50. def post(self,request):
  51. qxz_data = QXZstatus.objects.get(equip_id="16054381")
  52. json_obj = qxz_data.qxz_status.replace("'", "\"")
  53. xml = xmltodict.unparse({'request':json_obj})
  54. return HttpResponse(xml)
  55. # 监控界面
  56. class JKview(ListView):
  57. def get(self,request):
  58. equip_id = request.GET.get('equip_id')
  59. token = "at.0izp4b188fna8vvk8j28o2l4a980qqex-1otrmuqf8l-1k26cbi-cletdiwkp"
  60. return render(request, 'backstageNet/jk/equipmanage_jk.html', context={"equip_id":equip_id,"token":token})
  61. def post(self,request):
  62. pass
  63. # 监控列表
  64. class JKlist(ListView):
  65. def get(self,request):
  66. # current_user = request.user.username
  67. # print("current_user:", current_user)
  68. username = request.user.username
  69. print('username:',username)
  70. current_user = MyUser.objects.get(username=username)
  71. page = request.GET.get('page')
  72. page = int(page)
  73. f_id = request.GET.get('f_id')
  74. print("f_id:", f_id)
  75. if current_user.is_superuser != True and current_user.is_staff != True:
  76. # 用户
  77. if f_id != "":
  78. equip_list = Equip.objects.filter(equip_type=6, equip_user=current_user, equip_id__contains=f_id)
  79. else:
  80. equip_list = Equip.objects.filter(equip_type=6, equip_user=current_user)
  81. else:
  82. # 管理员
  83. if f_id != "":
  84. equip_list = Equip.objects.filter(equip_type=6, equip_id__contains=f_id)
  85. else:
  86. equip_list = Equip.objects.filter(equip_type=6)
  87. e_ids = []
  88. for x in equip_list:
  89. n_d = {"equip_name":x.equip_name, "equip_id":x.equip_id}
  90. e_ids.append(n_d)
  91. nums = len(e_ids)
  92. # print(nums)
  93. ids = e_ids[(10*(page-1)):(page*10)]
  94. data = {'ids': ids, 'nums': nums}
  95. data = json.dumps(data)
  96. return HttpResponse(data)
  97. def post(self,request):
  98. pass
  99. # 视频详情
  100. class JKManage_View(ListView):
  101. def get(self, request):
  102. live_list = []
  103. j_id = request.GET.get("id")
  104. jk_list = JKdata.objects.filter(equip_id=j_id)
  105. for x in jk_list:
  106. # 用token和设备id获取直播地址
  107. live_url = 'https://open.ys7.com/api/lapp/live/address/get'
  108. live_data = {"accessToken":x.jk_token,
  109. "source":"%s:1"%x.equip_id}
  110. print("=================live_data:",live_data)
  111. live_res = requests.post(live_url,data=live_data)
  112. # print("-------------------------------:",type(live_res.text))
  113. live_res = eval(live_res.text)
  114. print("live_res:",live_res)
  115. # 如果返回200 则返回直播地址
  116. if live_res['code'] == "200":
  117. print("token获取成功")
  118. live_list.append(live_res)
  119. # 如果返回其他 则调用获取token之后重新获取直播地址并返回
  120. else:
  121. print("token过期重新获取")
  122. token_url = 'https://open.ys7.com/api/lapp/token/get'
  123. token_data = {"appKey":"e8ec0d52b4b14628a3daf4b88cbcca2a",
  124. "appSecret":"d4565abea1cd0b90b59917111dcb37bd"}
  125. token_res = requests.post(token_url,data=token_data)
  126. print("token_res1:",token_res.text)
  127. token_res = eval(token_res.text)
  128. if token_res["code"] == "200":
  129. token_res["data"]["accessToken"]
  130. x.jk_token = token_res["data"]["accessToken"]
  131. x.upl_time = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))
  132. x.save()
  133. token = x.jk_token
  134. print("-----------------token保存成功")
  135. live_url = 'https://open.ys7.com/api/lapp/live/address/get'
  136. live_data = {"accessToken":x.jk_token,
  137. "source":"%s:1"%x.equip_id}
  138. live_res = requests.post(live_url,data=live_data)
  139. live_res = eval(live_res.text)
  140. print("live_res2:",live_res)
  141. live_list.append(live_res)
  142. data = json.dumps(live_list)
  143. return HttpResponse(data)
  144. # return render(request, 'backstageNet/jk/equipmanage_jk.html', context={"data":data})
  145. def post(self, request):
  146. jk_id = request.POST.get('id')
  147. ctrl = request.POST.get('ctrl')
  148. imei = request.POST.get('imei')
  149. accessToken = JKdata.objects.get(equip_id=jk_id).jk_token
  150. print("accessToken:",accessToken)
  151. if imei:
  152. if Equip.objects.filter(equip_id=imei).exists():
  153. return HttpResponse("0")
  154. else:
  155. # 得到设备类型实例:
  156. equip_t = Equip_type.objects.get(type_id=6)
  157. try:
  158. e_id = Equip.objects.create(equip_id=imei, equip_type=equip_t)
  159. print("<-----监控设备添加成功!----->")
  160. return HttpResponse("1")
  161. except:
  162. print("<-----监控设备添加失败!----->")
  163. if ctrl == "takephoto":
  164. url = 'https://open.ys7.com/api/lapp/device/capture'
  165. channelNo = '1'
  166. data = {'accessToken':accessToken, 'deviceSerial':jk_id, 'channelNo':channelNo}
  167. res = requests.post(url,data=data)
  168. print("截图返回结果为:",json.loads(res.text))
  169. return HttpResponse(res.text)
  170. # 操作命令:0-上,1-下,2-左,3-右,4-左上,5-左下,6-右上,7-右下,8-放大,9-缩小,10-近焦距,11-远焦距
  171. if ctrl == "move":
  172. print("-------球机云台控制开始!")
  173. dire = request.POST.get('movenum')
  174. ctrl_url = 'https://open.ys7.com/api/lapp/device/ptz/start'
  175. channelNo = '1'
  176. speed = '1'
  177. data = {'accessToken':accessToken, 'deviceSerial':jk_id, 'channelNo':channelNo, 'speed':speed, 'direction':dire}
  178. res1 = requests.post(ctrl_url,data=data)
  179. elif ctrl == "stop":
  180. print("-------球机云台控制结束!")
  181. ctrl_url = 'https://open.ys7.com/api/lapp/device/ptz/stop'
  182. channelNo = '1'
  183. data = {'accessToken':accessToken, 'deviceSerial':jk_id, 'channelNo':channelNo}
  184. res2 = requests.post(ctrl_url,data=data)
  185. return HttpResponse("1")
  186. # 新闻列表
  187. class Newslist_View(ListView):
  188. def get(self,request):
  189. con = request.GET.get("condition")
  190. page = int(request.GET.get("page"))
  191. try:
  192. art_type = int(request.GET.get("type"))
  193. art_list = CKArticle.objects.filter(art_type=art_type)
  194. if con:
  195. art_list = CKArticle.objects.filter(art_type=art_type,title__contains=con)
  196. except:
  197. art_list = CKArticle.objects.all()
  198. if con:
  199. art_list = CKArticle.objects.filter(title__contains=con)
  200. nums = art_list.count()
  201. art = art_list[(5*(page-1)):(page*5)]
  202. return render(request, 'outerNet/newsList.html', context={'art':art,"nums":nums,"con":con,"page":page})
  203. def post(self,request):
  204. art_list = CKArticle.objects.all()
  205. data = []
  206. for i in art_list:
  207. data.append({"id":i.id,"title":i.title,"content":i.content,"upl_time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S')})
  208. data = json.dumps(data)
  209. return HttpResponse(data)
  210. # 新闻详情
  211. class News_View(ListView):
  212. def get(self,request):
  213. f_id = request.GET.get("id")
  214. objs = CKArticle.objects.all().order_by("id")
  215. art = objs.get(id=f_id)
  216. on_art = objs.filter(id__lt=f_id,art_type=art.art_type)
  217. up_art = objs.filter(id__gt=f_id,art_type=art.art_type)
  218. return render(request, 'outerNet/newsDetail.html', context={"art":art,"on_art":on_art,"up_art":up_art})
  219. def post(self,request):
  220. art_list = Article.objects.all()
  221. for i in art_list:
  222. print(i.title)
  223. return HttpResponse("1")
  224. # 产品展厅列表
  225. class Equip_Show_List(ListView):
  226. def get(self,request):
  227. page = int(request.GET.get("page"))
  228. product_list = Product.objects.all()
  229. con = request.GET.get("condition")
  230. if con:
  231. product_list = Product.objects.filter(title__contains=con)
  232. nums = product_list.count()
  233. product = product_list[(20*(page-1)):(page*20)]
  234. return render(request, 'outerNet/exhibitionList.html', context={"nums":nums,"page":page,"con":con,"product":product})
  235. def post(self,request):
  236. pass
  237. # 产品展厅详情
  238. class Equip_Show_Detail(ListView):
  239. def get(self,request):
  240. e_id = request.GET.get("id")
  241. e_name = request.GET.get("name")
  242. if e_id:
  243. product = Product.objects.get(id=e_id)
  244. if e_name:
  245. product = Product.objects.get(title=e_name)
  246. return render(request, 'outerNet/exhibitionDetail.html', context={"product":product})
  247. def post(self,request):
  248. pass
  249. # 四季采摘-园区列表
  250. class Garden_List(ListView):
  251. def get(self,request):
  252. pass
  253. def post(self,request):
  254. page = int(request.POST.get("page"))
  255. farm_list = FarmList.objects.all()
  256. farm = []
  257. for i in farm_list:
  258. farm.append({"name":i.name,"id":i.id})
  259. nums = len(farm)
  260. farms = farm[(10*(page-1)):(page*10)]
  261. data = {"farms":farms,"nums":nums}
  262. data = json.dumps(data)
  263. return HttpResponse(data)
  264. # 四季采摘-主页
  265. class Garden_View(ListView):
  266. def get(self,request):
  267. return render(request, 'outerNet/fourPick.html', context={})
  268. def post(self,request):
  269. pass
  270. # 主页四级采摘进入的介绍页
  271. class Garden_Intro(ListView):
  272. def get(self,request):
  273. pid = request.GET.get("id")
  274. pname = request.GET.get("name")
  275. if pid:
  276. pick = Pick_Pub.objects.get(id=pid)
  277. if pname:
  278. pick = Pick_Pub.objects.get(name=pname)
  279. return render(request, 'outerNet/pickIntro.html', context={"pick":pick})
  280. def post(self,request):
  281. pass
  282. # 四季采摘-园区详情
  283. class Garden_Detail(ListView):
  284. def get(self,request):
  285. pass
  286. def post(self,request):
  287. f_id = request.POST.get("id")
  288. page = int(request.POST.get("page"))
  289. farm = FarmList.objects.get(id=f_id)
  290. pick = Pick_Pub.objects.filter(farm=farm)
  291. pick_list = []
  292. for i in pick:
  293. pick_list.append({"id":i.id,"farm":i.farm.name,"pick_s":i.pick_s,"pick_e":i.pick_e,"name":i.name,"time":i.upl_time,"company":i.company,"img":i.pick_img})
  294. nums = len(pick_list)
  295. pick_list = pick_list[(12*(page-1)):(page*12)]
  296. data = {"pick":pick_list,"nums":nums}
  297. data = json.dumps(data)
  298. return HttpResponse(data)
  299. #旅游导览
  300. class Tourist(ListView):
  301. def get(self,request):
  302. sid = request.GET.get("id")
  303. sname = request.GET.get("name")
  304. if sid:
  305. sightsee = Sightsee_Info.objects.get(id=sid)
  306. if sname:
  307. sightsee = Sightsee_Info.objects.get(name=sname)
  308. return render(request, 'outerNet/tourist.html', context={"sightsee":sightsee})
  309. def post(self,request):
  310. pass
  311. #旅游导览
  312. class Tourist_List(ListView):
  313. def get(self,request):
  314. page = int(request.GET.get("page"))
  315. con = request.GET.get("condition")
  316. sightsee = Sightsee_Info.objects.all()
  317. if con:
  318. sightsee = Sightsee_Info.objects.filter(name__contains=con)
  319. nums = sightsee.count()
  320. sightsee = sightsee[(10*(page-1)):(page*10)]
  321. return render(request, 'outerNet/touristList.html', context={"sightsee":sightsee,"nums":nums})
  322. def post(self,request):
  323. pass
  324. # 民宿列表
  325. class Dorm_List(ListView):
  326. def get(self,request):
  327. page = int(request.GET.get("page"))
  328. con = request.GET.get("condition")
  329. hotel_list = Hotel_Info.objects.all()
  330. if con:
  331. hotel_list = Hotel_Info.objects.filter(name__contains=con)
  332. nums = hotel_list.count()
  333. hotel = hotel_list[(10*(page-1)):(page*10)]
  334. return render(request, 'outerNet/hotelList.html', context={"nums":nums,"hotel":hotel,"page":page,"con":con})
  335. def post(self,request):
  336. pass
  337. # 民宿详情
  338. class Dorm_Detail(ListView):
  339. def get(self,request):
  340. hotel_id = request.GET.get("id")
  341. hotel_name = request.GET.get("name")
  342. if hotel_id:
  343. hotel = Hotel_Info.objects.get(id=hotel_id)
  344. if hotel_name:
  345. hotel = Hotel_Info.objects.get(name=hotel_name)
  346. photos = Hotel_Photo.objects.filter(hotel=hotel)
  347. return render(request, 'outerNet/hotelDetail.html', context={"hotel":hotel,"photos":photos})
  348. def post(self,request):
  349. pass
  350. # 农场导览
  351. class Farm_list(ListView):
  352. def get(self,request):
  353. page = int(request.GET.get("page"))
  354. con = request.GET.get("condition")
  355. garden_list = GardenArea.objects.filter(hidden=True)
  356. if con:
  357. garden_list = GardenArea.objects.filter(hidden=True,name__contains=con)
  358. nums = garden_list.count()
  359. garden_list = garden_list[(9*(page-1)):(page*9)]
  360. return render(request, 'outerNet/farmList.html', context={"nums":nums,"garden_list":garden_list,"page":page,"con":con})
  361. def post(self,request):
  362. pass
  363. # 视频列表
  364. class Video_List(ListView):
  365. def get(self,request):
  366. page = int(request.GET.get("page"))
  367. con = request.GET.get("condition")
  368. video_list = Video_data.objects.all()
  369. if con:
  370. video_list = Video_data.objects.filter(title__contains=con)
  371. nums = video_list.count()
  372. video = video_list[(12*(page-1)):(page*12)]
  373. return render(request, 'outerNet/videoList.html', context={"nums":nums,"video":video,"con":con,"page":page})
  374. def post(self,request):
  375. pass
  376. # 视频详情
  377. class Video_Detail(ListView):
  378. def get(self,request):
  379. v_id = request.GET.get("id")
  380. v_name = request.GET.get("name")
  381. if v_id:
  382. video = Video_data.objects.get(id=v_id)
  383. if v_name:
  384. print("name",v_name)
  385. video = Video_data.objects.get(title=v_name)
  386. return render(request, 'outerNet/videoDetail.html', context={"video":video})
  387. def post(self,request):
  388. pass
  389. # 后台管理页面
  390. class Back_Manage(ListView):
  391. def get(self,request):
  392. if request.user.is_authenticated():
  393. current_user = request.user.username
  394. current_user = MyUser.objects.get(username=current_user)
  395. garden = GardenArea.objects.all()
  396. return render(request, 'backstageNet/home.html', context={"current_user":current_user,"garden":garden})
  397. else:
  398. return render(request, 'outerNet/index2.html')
  399. def post(self,request):
  400. current_user = request.user.username
  401. print("current_user:", current_user)
  402. current_user = MyUser.objects.get(username=current_user)
  403. data = current_user.limit
  404. return HttpResponse(data)
  405. # 信息发布页面
  406. class Info_Pub(ListView):
  407. def get(self,request):
  408. return render(request, 'backstageNet/info/infoPub.html', context={})
  409. def post(self,request):
  410. # 文章标题
  411. title = request.POST.get('title')
  412. # 文章简介
  413. intro = request.POST.get('intro')
  414. # 文章内容
  415. info = request.POST.get('info')
  416. # 文章图片
  417. head_img = request.POST.get('upicture')
  418. username = request.user.username
  419. print('username:',username)
  420. current_user = MyUser.objects.get(username=username)
  421. if head_img:
  422. try:
  423. Article.objects.create(title=title,intro=intro,content=info,author=current_user,head_img=head_img)
  424. data = "1"
  425. except:
  426. data = "0"
  427. else:
  428. data = "0"
  429. return HttpResponse(data)
  430. # 信息维护页面
  431. class Info_Manage(ListView):
  432. def get(self,request):
  433. return render(request, 'backstageNet/info/infoManage.html', context={})
  434. def post(self,request):
  435. pass
  436. # 气象站分页接口
  437. class QXZ_Page(ListView):
  438. def get(self,request):
  439. # current_user = request.user.username
  440. # print("current_user:", current_user)
  441. # current_user = MyUser.objects.get(username="admin")
  442. page = request.GET.get('page')
  443. page = int(page)
  444. # f_id = request.GET.get('f_id')
  445. # print("f_id:", f_id)
  446. # if current_user.is_superuser != True and current_user.is_staff != True and current_user.is_agency != True:
  447. # # 用户
  448. # if f_id != "":
  449. # equip_list = Equip.objects.filter(equip_type=5, equip_user=current_user, equip_id__contains=f_id)
  450. # else:
  451. # equip_list = Equip.objects.filter(equip_type=5, equip_user=current_user)
  452. # elif current_user.is_superuser != True and current_user.is_staff != True and current_user.is_agency == True:
  453. # # 代理商
  454. # if f_id != "":
  455. # equip_list = Equip.objects.filter(equip_type=5, equip_agency=current_user.user_agency, equip_id__contains=f_id)
  456. # else:
  457. # equip_list = Equip.objects.filter(equip_type=5, equip_agency=current_user.user_agency)
  458. # else:
  459. # # 管理员
  460. # if f_id != "":
  461. # equip_list = Equip.objects.filter(equip_type=5, equip_id__contains=f_id)
  462. # else:
  463. equip_list = Equip.objects.filter(equip_type=5)
  464. e_ids = []
  465. for x in equip_list:
  466. n_d = {"equip_name":x.equip_name, "equip_id":x.equip_id}
  467. e_ids.append(n_d)
  468. nums = len(e_ids)
  469. # print(nums)
  470. ids = e_ids[(10*(page-1)):(page*10)]
  471. data = {'ids': ids, 'nums': nums}
  472. data = json.dumps(data)
  473. return HttpResponse(data)
  474. def post(self,request):
  475. pass
  476. # 气象站状态
  477. class QXZ_Status(ListView):
  478. def get(self,request):
  479. return render(request, 'backstageNet/qxzctrl/qxzData.html', context={})
  480. def post(self,request):
  481. e_id = request.POST.get("e_id")
  482. qxz_list = QXZstatus_New.objects.filter(equip_id=e_id)
  483. data = []
  484. for i in qxz_list:
  485. data.append({"interval":i.interval,"upl_time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),"e1":i.e1,"e2":i.e2,"e3":i.e3,
  486. "e4":i.e4,"e5":i.e5,"e6":i.e6,"e7":i.e7,"e8":i.e8,"e9":i.e9,"e10":i.e10,"e11":i.e11,"e12":i.e12,"e13":i.e13,"e14":i.e14})
  487. data = json.dumps(data)
  488. return HttpResponse(data)
  489. # 气象站状态测试
  490. class QXZ_Status2(ListView):
  491. def get(self,request):
  492. return render(request, 'backstageNet/qxzctrl/qxzData.html', context={})
  493. def post(self,request):
  494. e_id = request.POST.get("e_id")
  495. qxz_list = QXZstatus_New.objects.filter(equip_id=e_id)
  496. # data = []
  497. for i in qxz_list:
  498. dat = {"e1":i.e1,"e2":i.e2,"e3":i.e3,"e4":i.e4,"e5":i.e5,"e6":i.e6,"e7":i.e7,"e8":i.e8,"e9":i.e9,"e10":i.e10,"e11":i.e11,"e12":i.e12,"e13":i.e13,"e14":i.e14}
  499. data = {"interval":i.interval,"upl_time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),"dat":dat}
  500. data = json.dumps(data)
  501. return HttpResponse(data)
  502. # 气象站控制
  503. class QXZcontrol(ListView):
  504. def get(self,request):
  505. return render(request, 'backstageNet/qxzctrl/qxzctrl.html', context={})
  506. def post(self,request):
  507. e_id = request.POST.get('e_id')
  508. try:
  509. switch_obj = QXZswitchstatus.objects.get(equip_id=e_id)
  510. qxz_switch = switch_obj.qxz_switch
  511. except:
  512. qxz_switch = ""
  513. try:
  514. switch_name_obj = QXZswitchdata.objects.get(equip_id=e_id)
  515. switch_name = switch_name_obj.qxz_switch_data
  516. except:
  517. switch_name = ""
  518. data = {'qxz_switch':qxz_switch, 'switch_name':switch_name}
  519. data = json.dumps(data)
  520. return HttpResponse(data)
  521. # 气象站数据
  522. class QXZchart(ListView):
  523. def get(self,request):
  524. return render(request, 'backstageNet/qxzctrl/qxzchart.html', context={})
  525. def post(self,request):
  526. qxz_dict_2 = copy.deepcopy(qxz_dict)
  527. equip_id = request.POST.get('id')
  528. print("equip_id:", equip_id)
  529. f_tbegin = request.POST.get('begin')
  530. f_tend = request.POST.get('end')
  531. print("f_tbegin:", f_tbegin)
  532. print("f_tend:", f_tend)
  533. current_equip = Equip.objects.get(equip_id=equip_id)
  534. dat = []
  535. if f_tbegin:
  536. begindate = re.findall(r"\d+\.?\d*", f_tbegin)
  537. enddate = re.findall(r"\d+\.?\d*", f_tend)
  538. start_date = datetime.date(int(begindate[0]), int(begindate[1]), int(begindate[2]))
  539. end_date = datetime.date(int(enddate[0]), int(enddate[1]), int(enddate[2]))
  540. print("start_date:", start_date)
  541. print("end_date:", end_date)
  542. sta1 = QXZdata.objects.filter(
  543. equip_id=equip_id, upl_time__range=(start_date, end_date)).values()
  544. for x in sta1:
  545. sta = {"upl_time": x["upl_time"].strftime('%Y-%m-%d %H:%M:%S'),"e_len": len((eval(x["qxz_data"])["data"])),
  546. "unit": [], "equip_id": x["equip_id_id"]}
  547. for i in eval(x["qxz_data"])["data"]:
  548. qxz_dict_2[i["eNum"]][0] = i["eValue"] # 将气象站字典列表里的索引值替换为 数据的eValue
  549. d = copy.deepcopy(qxz_dict_2[i["eNum"]]) # 此处有坑 如果不深拷贝 后一次 qxz_dict[i["eNum"]][0] = i["eValue"] 赋值会把上次赋值替换掉
  550. ek = i["eKey"]
  551. d.append(ek)
  552. d.append(i["eNum"])
  553. sta["unit"].append(d)
  554. # qxz_dict[eval(x.qxz_data)['data'][0]["eNum"]]
  555. # print(sta["unit"])
  556. dat.append(sta)
  557. # print(dat)
  558. data = {"e_name": current_equip.equip_name, "dat": dat}
  559. data = json.dumps(data)
  560. return HttpResponse(data)
  561. # 获取当前日期:
  562. now_time = datetime.datetime.now()
  563. print("当前日期为:",now_time)
  564. print("当前月为:",now_time.month)
  565. sta1 = QXZdata.objects.filter(equip_id=equip_id, upl_time__month=now_time.month).values()
  566. for x in sta1:
  567. sta = {"upl_time": x["upl_time"].strftime('%Y-%m-%d %H:%M:%S'),"e_len": len(eval(x["qxz_data"])["data"]),
  568. "unit": [], "equip_id": x["equip_id_id"]}
  569. for i in eval(x["qxz_data"])["data"]:
  570. qxz_dict_2[i["eNum"]][0] = i["eValue"]
  571. d = copy.deepcopy(qxz_dict_2[i["eNum"]]) # 此处有坑 如果不深拷贝 后一次 qxz_dict[i["eNum"]][0] = i["eValue"] 赋值会把上次赋值替换掉
  572. ek = i["eKey"]
  573. d.append(ek)
  574. d.append(i["eNum"])
  575. sta["unit"].append(d)
  576. # qxz_dict[eval(x.qxz_data)['data'][0]["eNum"]]
  577. dat.append(sta)
  578. # print(dat)
  579. data = {"e_name": current_equip.equip_name, "dat": dat}
  580. # print("------",data)
  581. data = json.dumps(data)
  582. return HttpResponse(data)
  583. # 气象站列表详情
  584. class QXZ_Report_Detail(ListView):
  585. def get(self, request):
  586. qxz_dict_3 = copy.deepcopy(qxz_dict)
  587. page = int(request.GET.get('page'))
  588. print("page:", page)
  589. equip_id = request.GET.get('id')
  590. print("equip_id:", equip_id)
  591. f_tbegin = request.GET.get('begin')
  592. f_tend = request.GET.get('end')
  593. print("f_tbegin:", f_tbegin)
  594. print("f_tend:", f_tend)
  595. current_equip = Equip.objects.get(equip_id=equip_id)
  596. dat = []
  597. if f_tbegin:
  598. begindate = re.findall(r"\d+\.?\d*", f_tbegin)
  599. enddate = re.findall(r"\d+\.?\d*", f_tend)
  600. start_date = datetime.date(int(begindate[0]), int(begindate[1]), int(begindate[2]))
  601. end_date = datetime.date(int(enddate[0]), int(enddate[1]), int(enddate[2]))
  602. print("start_date:", start_date)
  603. print("end_date:", end_date)
  604. sta1 = QXZdata.objects.filter(
  605. equip_id=equip_id, upl_time__range=(start_date, end_date)).values()
  606. for x in sta1:
  607. sta = {"upl_time": x["upl_time"].strftime('%Y-%m-%d %H:%M:%S'), "unit": [], "equip_id": x["equip_id_id"]}
  608. for i in eval(x["qxz_data"])["data"]:
  609. qxz_dict_3[i["eNum"]][0] = i["eValue"]
  610. d = copy.deepcopy(qxz_dict_3[i["eNum"]]) # 此处有坑 如果不深拷贝 后一次 qxz_dict[i["eNum"]][0] = i["eValue"] 赋值会把上次赋值替换掉
  611. ek = i["eKey"]
  612. d.append(ek)
  613. sta["unit"].append(d)
  614. # qxz_dict[eval(x.qxz_data)['data'][0]["eNum"]]
  615. dat.append(sta)
  616. nums = len(dat)
  617. dat = dat[(10*(page-1)):(page*10)]
  618. data = {"dat": dat, "nums":nums}
  619. data = json.dumps(data)
  620. return HttpResponse(data)
  621. sta1 = QXZdata.objects.filter(equip_id=equip_id).values()
  622. for x in sta1:
  623. sta = {"upl_time": x["upl_time"].strftime('%Y-%m-%d %H:%M:%S'), "unit": [], "equip_id": x["equip_id_id"]}
  624. for i in eval(x["qxz_data"])["data"]:
  625. qxz_dict_3[i["eNum"]][0] = i["eValue"]
  626. d = copy.deepcopy(qxz_dict_3[i["eNum"]]) # 此处有坑 如果不深拷贝 后一次 qxz_dict[i["eNum"]][0] = i["eValue"] 赋值会把上次赋值替换掉
  627. ek = i["eKey"]
  628. d.append(ek)
  629. sta["unit"].append(d)
  630. dat.append(sta)
  631. nums = len(dat)
  632. dat = dat[(10*(page-1)):(page*10)]
  633. data = {"dat": dat, "nums":nums}
  634. data = json.dumps(data)
  635. return HttpResponse(data)
  636. class QXZ_Report_Detail2(ListView):
  637. def get(self, request):
  638. pass
  639. def post(self,request):
  640. e_id = request.POST.get("e_id")
  641. page = int(request.POST.get("page"))
  642. qxz_list = QXZdata_New.objects.filter(equip_id=e_id)
  643. f_tbegin = request.POST.get('begin')
  644. f_tend = request.POST.get('end')
  645. if f_tbegin:
  646. print("f_tbegin:", f_tbegin)
  647. print("f_tend:", f_tend)
  648. begindate = re.findall(r"\d+\.?\d*", f_tbegin)
  649. enddate = re.findall(r"\d+\.?\d*", f_tend)
  650. start_date = datetime.date(int(begindate[0]), int(begindate[1]), int(begindate[2]))
  651. end_date = datetime.date(int(enddate[0]), int(enddate[1]), int(enddate[2]))
  652. print("start_date:", start_date)
  653. print("end_date:", end_date)
  654. qxz_list = QXZdata_New.objects.filter(equip_id=e_id, upl_time__range=(start_date, end_date))
  655. data = []
  656. for i in qxz_list:
  657. dat = {"e1":i.e1,"e2":i.e2,"e3":i.e3,"e4":i.e4,"e5":i.e5,"e6":i.e6,"e7":i.e7,"e8":i.e8,"e9":i.e9,"e10":i.e10,"e11":i.e11,"e12":i.e12,"e13":i.e13,"e14":i.e14}
  658. data.append({"upl_time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),"dat":dat})
  659. nums = len(data)
  660. data = data[(10*(page-1)):(page*10)]
  661. datas = {"data":data,"nums":nums}
  662. datas = json.dumps(datas)
  663. return HttpResponse(datas)
  664. # 气象站开关名字
  665. class QXZ_Switch_Name(ListView):
  666. def get(self,request):
  667. pass
  668. def post(self,request):
  669. imei = request.POST.get('imei')
  670. way = request.POST.get('way')
  671. sw_name = request.POST.get('sw_name')
  672. try:
  673. switch_obj = QXZswitchdata.objects.get(equip_id=imei)
  674. except:
  675. return HttpResponse("1")
  676. sw_name_list = eval(switch_obj.qxz_switch_data)
  677. for i in sw_name_list:
  678. if i["JK"] == int(way):
  679. i["name"] = sw_name
  680. print(sw_name_list)
  681. try:
  682. switch_obj.qxz_switch_data = sw_name_list
  683. switch_obj.save()
  684. except:
  685. return HttpResponse("1")
  686. data = "0"
  687. return HttpResponse(data)
  688. # 气象站通信接口
  689. class QXZ_Mqtt(ListView):
  690. def get(self,request):
  691. pass
  692. def post(self,request):
  693. req = request.POST.get('req')
  694. imei = request.POST.get('imei')
  695. topic = "/yfkj/qxz/sub/"+imei
  696. if req == "read":
  697. payload = {"ext":{"type":"status"},"cmd":"read"}
  698. elif req == "set":
  699. way = int(request.POST.get('way'))
  700. switch = int(request.POST.get('switch'))
  701. payload = {"cmd":"control","ext":{"JK":way,"status":switch}}
  702. elif req == "conf":
  703. payload = {"ext":{"type":"jkStatus"},"cmd":"read"}
  704. elif req == "interval":
  705. time = int(request.POST.get('time'))
  706. payload = {"cmd": "config","ext": {"interval": time}}
  707. cmd = {"topic":topic,"payload":json.dumps(payload),'qos':0}
  708. res = requests.post("http://www.yfzhwlw.com:8080/api/v2/mqtt/publish",
  709. data=json.dumps(cmd), auth=HTTPBasicAuth("admin", "yfkj_6019"))
  710. print("res.status_code:", type(res.status_code))
  711. if res.status_code == 200:
  712. data = "0"
  713. return HttpResponse(data)
  714. else:
  715. data = "1"
  716. return HttpResponse(data)
  717. # 新闻审核
  718. class News_Check(ListView):
  719. def get(self,request):
  720. return render(request, 'backstageNet/infoManage/newsManage.html', context={'role':'superuser'})
  721. def post(self,request):
  722. news_id = request.POST.get('id')
  723. news_see_id = request.POST.get("ids")
  724. # 通过后删除
  725. if news_id:
  726. try:
  727. news_sta = CKArticle.objects.get(id=news_id)
  728. news_sta.delete()
  729. return HttpResponse("1")
  730. except:
  731. return HttpResponse("0")
  732. # 通过查看详情
  733. art_list = CKArticle.objects.filter(id=news_see_id)
  734. dat = []
  735. for i in art_list:
  736. dat.append({
  737. "title":i.title,
  738. "intro":i.intro,
  739. "time": i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),
  740. "img": "%s"%i.head_img,
  741. "writer":i.writer,
  742. "author":i.author.username,
  743. "content":i.content,
  744. "art_type":i.art_type,
  745. })
  746. data = json.dumps(dat)
  747. return HttpResponse(data)
  748. # 新闻审核页面
  749. class News_Check_List(ListView):
  750. def get(self,request):
  751. hidden = request.GET.get('hidden')
  752. page = int(request.GET.get('page'))
  753. art_list = CKArticle.objects.filter(art_type=5,hidden=hidden)
  754. nums = art_list.count()
  755. print(nums)
  756. art = art_list[(10*(page-1)):(page*10)]
  757. return render(request, 'backstageNet/infoManage/newsManageList.html', context={"art":art,"nums":nums})
  758. def post(self,request):
  759. art_id = request.POST.get('id')
  760. req = request.POST.get('req')
  761. art_obj = CKArticle.objects.filter(id=art_id)
  762. # 编辑
  763. if req == "edit":
  764. data = []
  765. for i in art_obj:
  766. data.append({
  767. "id":i.id,
  768. "title":i.title,
  769. "intro":i.intro,
  770. "head_img":i.head_img.name,
  771. "content":i.content,
  772. "art_type":i.art_type,
  773. "writer":i.writer,
  774. "upl_time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),
  775. "author":i.author.username
  776. })
  777. # 未审核删除
  778. elif req == "del":
  779. art_obj.delete()
  780. data = "1"
  781. # 通过审核
  782. elif req == "check":
  783. art_obj = CKArticle.objects.get(id=art_id)
  784. art_obj.hidden = True
  785. art_obj.save()
  786. data = "1"
  787. data = json.dumps(data)
  788. return HttpResponse(data)
  789. # 新闻审核上传图片接口
  790. class News_Photo(ListView):
  791. def get(self,request):
  792. pass
  793. def post(self,request):
  794. # e_id = request.POST.get('id')
  795. # news_sta = Article.objects.get(id=e_id)
  796. news_photo = request.FILES.get('upicture')
  797. if news_photo:
  798. print("新闻图片:", news_photo)
  799. news_photo_dir = 'hnews_photo/'
  800. end_name = news_photo.name.split('.')[-1]
  801. # 判断如果路径不存在,即创建路径
  802. if os.path.exists(news_photo_dir) == False:
  803. os.makedirs(news_photo_dir)
  804. img = Image.open(news_photo)
  805. # img = img.convert('RGB')
  806. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  807. pic_name = now_time + '.' + end_name
  808. print("pic_name:", pic_name)
  809. img.save(news_photo_dir + pic_name)
  810. news_photo = news_photo_dir + pic_name
  811. print("new_photo:",news_photo)
  812. data = {"code": 0,"msg": "","data": {"src": news_photo}}
  813. else:
  814. new_photo = "0"
  815. data = {"code": 404,"msg": "","data": {"src": news_photo}}
  816. data = json.dumps(data)
  817. return HttpResponse(data)
  818. # 新闻发布
  819. class News_Pub(ListView):
  820. def get(self,request):
  821. return render(request, 'backstageNet/info/newsPub.html', context={'role':'superuser'})
  822. def post(self,request):
  823. username = request.user.username
  824. print('username:',username)
  825. current_user = MyUser.objects.get(username=username)
  826. news_photo = request.POST.get('upload')
  827. art_type = request.POST.get('type')
  828. writer = request.POST.get('writer')
  829. intro = request.POST.get('intro')
  830. title = request.POST.get('title')
  831. content = request.POST.get('content')
  832. news_id = request.POST.get("id")
  833. if news_id:
  834. if CKArticle.objects.filter(id=news_id).exists():
  835. CKArticle.objects.filter(id=news_id).update(
  836. art_type=art_type,
  837. writer = writer,
  838. intro = intro,
  839. title = title,
  840. content = content,
  841. head_img = news_photo
  842. )
  843. data= "1"
  844. else:
  845. data = "0"
  846. else:
  847. try:
  848. CKArticle.objects.create(author=current_user,art_type=art_type,writer=writer,intro=intro,title=title,content=content,head_img=news_photo)
  849. data = "1"
  850. except Exception as e:
  851. print(e)
  852. data = "0"
  853. return HttpResponse(data)
  854. # 视频发布
  855. class Video_Pub(ListView):
  856. def get(self,request):
  857. return render(request, 'backstageNet/info/videoPub.html', context={})
  858. def post(self,request):
  859. # 视频标题
  860. title = request.POST.get('title')
  861. # 视频简介
  862. intro = request.POST.get('intro')
  863. # 视频链接
  864. video = request.POST.get('video_url')
  865. username = request.user.username
  866. print('username:',username)
  867. current_user = MyUser.objects.get(username=username)
  868. video_img = request.POST.get('video_img')
  869. video_id =request.POST.get('id')
  870. if video_id:
  871. if Video_data.objects.filter(id=video_id).exists():
  872. Video_data.objects.filter(id=video_id).update(
  873. title=title,
  874. intro=intro,
  875. video_url=video,
  876. author=current_user,
  877. video_img=video_img,
  878. )
  879. data = '1'
  880. else:
  881. data = '0'
  882. else:
  883. try:
  884. Video_data.objects.create(title=title,intro=intro,video_url=video,author=current_user,video_img=video_img)
  885. data = "1"
  886. except Exception as e:
  887. print("-------错误信息为----------")
  888. print(e)
  889. data = "0"
  890. # else:
  891. # data = "0"
  892. return HttpResponse(data)
  893. # 视频封面上传图片接口
  894. class Video_Photo(ListView):
  895. def get(self,request):
  896. pass
  897. def post(self,request):
  898. # e_id = request.POST.get('id')
  899. # news_sta = Article.objects.get(id=e_id)
  900. video_photo = request.FILES.get('video_img')
  901. if video_photo:
  902. print("视频图片:", video_photo)
  903. video_photo_dir = 'hvideo_photo/'
  904. end_name = video_photo.name.split('.')[-1]
  905. # 判断如果路径不存在,即创建路径
  906. if os.path.exists(video_photo_dir) == False:
  907. os.makedirs(video_photo_dir)
  908. img = Image.open(video_photo)
  909. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  910. pic_name = now_time + '.' + end_name
  911. print("pic_name:", pic_name)
  912. img.save(video_photo_dir + pic_name)
  913. video_photo = video_photo_dir + pic_name
  914. print("new_photo:",video_photo)
  915. data = {"code": 0,"msg": "","data": {"src": video_photo}}
  916. else:
  917. video_photo = "0"
  918. data = {"code": 404,"msg": "","data": {"src": video_photo}}
  919. data = json.dumps(data)
  920. return HttpResponse(data)
  921. # 视频上传接口
  922. class Video_Upload(ListView):
  923. def get(self,request):
  924. pass
  925. def post(self,request):
  926. obj = request.FILES.get('upload')
  927. f = os.path.join('hvideos',obj.name).replace('\\','/')
  928. print(f)
  929. if not obj:
  930. return HttpResponse("0")
  931. dest=open(f,"wb")
  932. try:
  933. for chunk in obj.chunks():
  934. dest.write(chunk)
  935. finally:
  936. dest.close()
  937. video_dir = "hvideos/" + obj.name
  938. data = {"code": 0,"msg": "","data": {"src":video_dir}}
  939. data = json.dumps(data)
  940. return HttpResponse(data)
  941. # 产品发布
  942. class Equip_Pub(ListView):
  943. def get(self,request):
  944. return render(request, 'backstageNet/info/productPub.html', context={})
  945. def post(self,request):
  946. # 产品标题
  947. title = request.POST.get('title')
  948. # 产品简介
  949. intro = request.POST.get('intro')
  950. # 产品内容
  951. content = request.POST.get('content')
  952. # 产品图片
  953. head_img = request.POST.get('img_url')
  954. mobile = request.POST.get('mobile')
  955. username = request.user.username
  956. print('username:',username)
  957. current_user = MyUser.objects.get(username=username)
  958. equip_id = request.POST.get("id")
  959. if equip_id:
  960. if Product.objects.filter(id=equip_id).exists():
  961. try:
  962. Product.objects.filter(id=equip_id).update(
  963. title=title,
  964. intro=intro,
  965. content=content,
  966. author=current_user,
  967. head_img=head_img,
  968. mobile=mobile
  969. )
  970. data = "1"
  971. except Exception as e:
  972. print("-----------错误信息为-------------")
  973. print(e)
  974. data = "0"
  975. else:
  976. data = "0"
  977. else:
  978. if head_img:
  979. try:
  980. Product.objects.create(title=title,intro=intro,content=content,author=current_user,head_img=head_img,mobile=mobile)
  981. data = "1"
  982. except Exception as e:
  983. print("-----------错误信息为-------------")
  984. print(e)
  985. data = "0"
  986. else:
  987. data = "0"
  988. return HttpResponse(data)
  989. # 产品封面上传图片接口
  990. class Equip_Photo(ListView):
  991. def get(self,request):
  992. pass
  993. def post(self,request):
  994. pro_photo = request.FILES.get('pro_img')
  995. if pro_photo:
  996. print("视频图片:", pro_photo)
  997. pro_photo_dir = 'product_photo/'
  998. # 判断如果路径不存在,即创建路径
  999. end_name = pro_photo.name.split('.')[-1]
  1000. if os.path.exists(pro_photo_dir) == False:
  1001. os.makedirs(pro_photo_dir)
  1002. img = Image.open(pro_photo)
  1003. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  1004. pic_name = now_time + '.' + end_name
  1005. print("pic_name:", pic_name)
  1006. img.save(pro_photo_dir + pic_name)
  1007. pro_photo = pro_photo_dir + pic_name
  1008. print("pro_photo:",pro_photo)
  1009. data = {"code": 0,"msg": "","data": {"src": pro_photo}}
  1010. else:
  1011. pro_photo = "0"
  1012. data = {"code": 404,"msg": "","data": {"src": pro_photo}}
  1013. data = json.dumps(data)
  1014. return HttpResponse(data)
  1015. # 采摘农场选择
  1016. class Farm_Choice(ListView):
  1017. def get(self,request):
  1018. pass
  1019. def post(self,request):
  1020. username = request.user.username
  1021. print('username:',username)
  1022. current_user = MyUser.objects.get(username=username)
  1023. if current_user.is_staff == True:
  1024. farmlist = FarmList.objects.all()
  1025. else:
  1026. farmlist = FarmList.objects.filter(user=current_user)
  1027. dat = []
  1028. for i in farmlist:
  1029. dat.append({"name":i.name})
  1030. dat = json.dumps(dat)
  1031. return HttpResponse(dat)
  1032. # 四季采摘图片上传
  1033. class Pick_Photo(ListView):
  1034. def get(self,request):
  1035. pass
  1036. def post(self,request):
  1037. gar_photo = request.FILES.get('gar_img')
  1038. if gar_photo:
  1039. print("视频图片:", gar_photo)
  1040. garden_photo_dir = 'garden_photo/'
  1041. end_name = gar_photo.name.split('.')[-1]
  1042. # 判断如果路径不存在,即创建路径
  1043. if os.path.exists(garden_photo_dir) == False:
  1044. os.makedirs(garden_photo_dir)
  1045. img = Image.open(gar_photo)
  1046. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  1047. pic_name = now_time + '.' + end_name
  1048. print("pic_name:", pic_name)
  1049. img.save(garden_photo_dir + pic_name)
  1050. gar_photo = garden_photo_dir + pic_name
  1051. print("gar_photo:",gar_photo)
  1052. data = {"code": 0,"msg": "","data": {"src": gar_photo}}
  1053. else:
  1054. pro_photo = "0"
  1055. data = {"code": 404,"msg": "","data": {"src": gar_photo}}
  1056. data = json.dumps(data)
  1057. return HttpResponse(data)
  1058. # 四季采摘发布
  1059. class Garden_Pub(ListView):
  1060. def get(self,request):
  1061. return render(request, 'backstageNet/info/gardenPub.html', context={})
  1062. def post(self,request):
  1063. farm = request.POST.get('farm')
  1064. name = request.POST.get('name')
  1065. time = request.POST.get('time')
  1066. pick_s = request.POST.get('start')
  1067. pick_e = request.POST.get('end')
  1068. ripe_time = request.POST.get('ripe')
  1069. # 规模
  1070. scale = request.POST.get('scale')
  1071. addr = request.POST.get('addr')
  1072. company = request.POST.get('company')
  1073. pick_img = request.POST.get('img_url')
  1074. content = request.POST.get('content')
  1075. garden_id = request.POST.get('id')
  1076. print("garden_id:",garden_id)
  1077. # begindate = re.findall(r"\d+\.?\d*", pick_s)
  1078. # enddate = re.findall(r"\d+\.?\d*", pick_e)
  1079. # start_date = datetime.date(int(begindate[0]), int(begindate[1]), int(begindate[2]))
  1080. # end_date = datetime.date(int(enddate[0]), int(enddate[1]), int(enddate[2]))
  1081. # 编辑更新
  1082. if garden_id:
  1083. if Pick_Pub.objects.filter(id=garden_id).exists():
  1084. farm_obj = FarmList.objects.get(name=farm)
  1085. Pick_Pub.objects.filter(id=garden_id).update(pick_s=pick_s,pick_e=pick_e,ripe_time=ripe_time,content=content,
  1086. scale=scale,addr=addr,farm=farm_obj,name=name,company=company,pick_img=pick_img,upl_time=time)
  1087. data = "1"
  1088. else:
  1089. data = "0"
  1090. return HttpResponse(data)
  1091. else:
  1092. try:
  1093. farm_obj = FarmList.objects.get(name=farm)
  1094. Pick_Pub.objects.create(pick_s=pick_s,pick_e=pick_e,ripe_time=ripe_time,content=content,
  1095. scale=scale,addr=addr,farm=farm_obj,name=name,company=company,pick_img=pick_img,upl_time=time)
  1096. data = "1"
  1097. print(data)
  1098. except Exception as e:
  1099. print("-----------报错信息为-------------")
  1100. print(e)
  1101. data = "0"
  1102. return HttpResponse(data)
  1103. # 民宿封面
  1104. class Dorm_Img(ListView):
  1105. def get(self,request):
  1106. pass
  1107. def post(self,request):
  1108. hotel_photo = request.FILES.get('hotel_photo')
  1109. if hotel_photo:
  1110. print("视频图片:", hotel_photo)
  1111. hotel_photo_dir = 'hotel_photo/'
  1112. end_name = hotel_photo.name.split('.')[-1]
  1113. # 判断如果路径不存在,即创建路径
  1114. if os.path.exists(hotel_photo_dir) == False:
  1115. os.makedirs(hotel_photo_dir)
  1116. img = Image.open(hotel_photo)
  1117. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  1118. pic_name = now_time + '.' + end_name
  1119. print("pic_name:", pic_name)
  1120. img.save(hotel_photo_dir + pic_name)
  1121. hotel_photo = hotel_photo_dir + pic_name
  1122. print("hotel_photo:",hotel_photo)
  1123. data = {"code": 0,"msg": "","data": {"src": hotel_photo}}
  1124. else:
  1125. hotel_photo = "0"
  1126. data = {"code": 404,"msg": "","data": {"src": hotel_photo}}
  1127. data = json.dumps(data)
  1128. return HttpResponse(data)
  1129. # 民宿介绍图
  1130. class Dorm_Photo(ListView):
  1131. def get(self,request):
  1132. pass
  1133. def post(self,request):
  1134. hotel_photos = request.FILES.get('hotel_photos')
  1135. if hotel_photos:
  1136. print("视频图片:", hotel_photos)
  1137. hotel_photo_dir = 'hotel_photos/'
  1138. end_name = hotel_photos.name.split('.')[-1]
  1139. # 判断如果路径不存在,即创建路径
  1140. if os.path.exists(hotel_photo_dir) == False:
  1141. os.makedirs(hotel_photo_dir)
  1142. img = Image.open(hotel_photos)
  1143. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  1144. pic_name = now_time + '.' + end_name
  1145. print("pic_name:", pic_name)
  1146. img.save(hotel_photo_dir + pic_name)
  1147. hotel_photos = hotel_photo_dir + pic_name
  1148. print("hotel_photos:",hotel_photos)
  1149. data = {"code": 0,"msg": "","data": {"src": hotel_photos}}
  1150. else:
  1151. hotel_photos = "0"
  1152. data = {"code": 404,"msg": "","data": {"src": hotel_photos}}
  1153. data = json.dumps(data)
  1154. return HttpResponse(data)
  1155. # 民宿发布
  1156. class Dorm_Pub(ListView):
  1157. def get(self,request):
  1158. return render(request, 'backstageNet/info/dormPub.html', context={})
  1159. def post(self,request):
  1160. username = request.user.username
  1161. print('username:',username)
  1162. current_user = MyUser.objects.get(username=username)
  1163. name = request.POST.get('name')
  1164. price = request.POST.get('price')
  1165. person = request.POST.get('person')
  1166. mobile = request.POST.get('mobile')
  1167. img_url = request.POST.get('img_url')
  1168. addr = request.POST.get('addr')
  1169. location = request.POST.get('location')
  1170. intro = request.POST.get('intro')
  1171. content = request.POST.get('content')
  1172. pic_list = request.POST.get('pic_list')
  1173. Hotel_id= request.POST.get("id")
  1174. if Hotel_id:
  1175. if Hotel_Info.objects.filter(id=Hotel_id).exists():
  1176. try:
  1177. Hotel_Info.objects.filter(id=Hotel_id).update(
  1178. name=name,
  1179. price=price,
  1180. intro=intro,
  1181. addr=addr,
  1182. location=location,
  1183. person=person,
  1184. hotel_img=img_url,
  1185. hotel_tel=mobile,
  1186. content=content,
  1187. author=current_user,
  1188. )
  1189. data="1"
  1190. except Exception as e:
  1191. print("-----------报错信息为-------------")
  1192. print(e)
  1193. data = "0"
  1194. if data == "1":
  1195. try:
  1196. hotel_obj = Hotel_Info.objects.get(name=name)
  1197. pic_list = pic_list.split(',')
  1198. for i in pic_list:
  1199. Hotel_Photo.objects.filter(hotel=hotel_obj).update(hotel=hotel_obj,addr=i)
  1200. except Exception as aa:
  1201. print("滚动图保存错误")
  1202. print(aa)
  1203. else:
  1204. data = "0"
  1205. return HttpResponse(data)
  1206. else:
  1207. try:
  1208. Hotel_Info.objects.create(
  1209. name=name,
  1210. price=price,
  1211. intro=intro,
  1212. addr=addr,
  1213. location=location,
  1214. person=person,
  1215. hotel_img=img_url,
  1216. hotel_tel=mobile,
  1217. content=content,
  1218. author=current_user)
  1219. data = "1"
  1220. except Exception as e:
  1221. print("-----------报错信息为-------------")
  1222. print(e)
  1223. data = "0"
  1224. if data == "1":
  1225. try:
  1226. hotel_obj = Hotel_Info.objects.get(name=name)
  1227. pic_list = pic_list.split(',')
  1228. for i in pic_list:
  1229. Hotel_Photo.objects.create(hotel=hotel_obj,addr=i)
  1230. except Exception as aa:
  1231. print("滚动图保存错误")
  1232. print(aa)
  1233. return HttpResponse(data)
  1234. # 旅游发布介绍图
  1235. class Sightsee_Photo(ListView):
  1236. def get(self,request):
  1237. pass
  1238. def post(self,request):
  1239. sightsee_photos = request.FILES.get('sightsee_photos')
  1240. if sightsee_photos:
  1241. print("视频图片:", sightsee_photos)
  1242. sightsee_photos_dir = 'sightsee_photos/'
  1243. end_name = sightsee_photos.name.split('.')[-1]
  1244. # 判断如果路径不存在,即创建路径
  1245. if os.path.exists(sightsee_photos_dir) == False:
  1246. os.makedirs(sightsee_photos_dir)
  1247. img = Image.open(sightsee_photos)
  1248. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  1249. pic_name = now_time + '.' + end_name
  1250. print("pic_name:", pic_name)
  1251. img.save(sightsee_photos_dir + pic_name)
  1252. sightsee_photos = sightsee_photos_dir + pic_name
  1253. print("sightsee_photos:",sightsee_photos)
  1254. data = {"code": 0,"msg": "","data": {"src": sightsee_photos}}
  1255. else:
  1256. sightsee_photos = "0"
  1257. data = {"code": 404,"msg": "","data": {"src": sightsee_photos}}
  1258. data = json.dumps(data)
  1259. return HttpResponse(data)
  1260. # 旅游发布
  1261. class Sightsee_Pub(ListView):
  1262. def get(self,request):
  1263. return render(request, 'backstageNet/info/SightseePub.html', context={})
  1264. def post(self,request):
  1265. name = request.POST.get('name')
  1266. price = request.POST.get('price')
  1267. sightsee_tel = request.POST.get('mobile')
  1268. sightsee_img = request.POST.get('img_url')
  1269. sightsee_stime = request.POST.get('stime')
  1270. sightsee_etime = request.POST.get('etime')
  1271. # begindate = re.findall(r"\d+\.?\d*", sightsee_stime)
  1272. # enddate = re.findall(r"\d+\.?\d*", sightsee_etime)
  1273. # start_date = datetime.date(int(begindate[0]), int(begindate[1]), int(begindate[2]))
  1274. # end_date = datetime.date(int(enddate[0]), int(enddate[1]), int(enddate[2]))
  1275. # 位置
  1276. location = request.POST.get('location')
  1277. addr = request.POST.get('addr')
  1278. # 内容
  1279. content = request.POST.get('content')
  1280. # 简介
  1281. desc = request.POST.get('desc')
  1282. guide_img = request.POST.get('guide_img')
  1283. s_id = request.POST.get('id')
  1284. if s_id:
  1285. sight_obj = Sightsee_Info.objects.get(id=s_id)
  1286. sight_obj.name=name
  1287. sight_obj.price=price
  1288. sight_obj.location=location
  1289. sight_obj.sightsee_stime=sightsee_stime
  1290. sight_obj.sightsee_etime=sightsee_etime
  1291. sight_obj.sightsee_img=sightsee_img
  1292. sight_obj.sightsee_tel=sightsee_tel
  1293. sight_obj.addr=addr
  1294. sight_obj.guide_img=guide_img
  1295. sight_obj.content=content
  1296. sight_obj.desc=desc
  1297. sight_obj.save()
  1298. data = "1"
  1299. return HttpResponse(data)
  1300. try:
  1301. Sightsee_Info.objects.create(
  1302. name=name,
  1303. price=price,
  1304. location=location,
  1305. sightsee_stime=sightsee_stime,
  1306. sightsee_etime=sightsee_etime,
  1307. sightsee_img=sightsee_img,
  1308. sightsee_tel=sightsee_tel,
  1309. addr=addr,
  1310. guide_img=guide_img,
  1311. content=content,
  1312. desc=desc)
  1313. data = "1"
  1314. except:
  1315. data = "0"
  1316. return HttpResponse(data)
  1317. #我的发布
  1318. class My_Pub(ListView):
  1319. def get(self,request):
  1320. return render(request, 'backstageNet/infoList/myPub.html', context={})
  1321. def post(self,request):
  1322. pass
  1323. #我的发布列表
  1324. class My_Pub_List(ListView):
  1325. def get(self,request):
  1326. page = int(request.GET.get("page",1))
  1327. hidden = request.GET.get("hidden")
  1328. _type = request.GET.get("type")
  1329. print("----->",_type)
  1330. _list = CKArticle.objects.all()
  1331. if _type:
  1332. _list = _list.filter(art_type=_type)
  1333. if _type == "5":
  1334. pub_list = CKArticle.objects.filter(art_type="5")
  1335. elif _type == "6":
  1336. pub_list = Video_data.objects.all()
  1337. elif _type == "7":
  1338. pub_list = Product.objects.all()
  1339. elif _type == "8":
  1340. pub_list = Pick_Pub.objects.all()
  1341. elif _type == "9":
  1342. pub_list = Hotel_Info.objects.all()
  1343. elif _type == "10":
  1344. pub_list = Sightsee_Info.objects.all()
  1345. if hidden:
  1346. _list = _list.filter(hidden=hidden)
  1347. pub_list = pub_list.filter(hidden=hidden)
  1348. nums = pub_list.count()
  1349. print("nums",nums)
  1350. # nums = _list.count()
  1351. pub_list = pub_list[(10*(page-1)):(page*10)]
  1352. art_list = _list[(10*(page-1)):(page*10)]
  1353. return render(request, 'backstageNet/infoList/myPubList.html', context={"pub_list":pub_list,"art_list":art_list,"nums":nums,"type":_type})
  1354. def post(self,request):
  1355. pass
  1356. # 视频审核
  1357. class Video_Check(ListView):
  1358. def get(self,request):
  1359. return render(request, 'backstageNet/infoManage/videoManage.html', context={'role':'superuser'})
  1360. def post(self,request):
  1361. video_id = request.POST.get('id')
  1362. video_see_id = request.POST.get("ids")
  1363. # 审核通过后删除
  1364. if video_id:
  1365. try:
  1366. video_sta = Video_data.objects.get(id=video_id)
  1367. video_sta.delete()
  1368. return HttpResponse("1")
  1369. except:
  1370. return HttpResponse("0")
  1371. # 审核通过查看详情
  1372. art_list = Video_data.objects.filter(id=video_see_id)
  1373. dat = []
  1374. for i in art_list:
  1375. dat.append({
  1376. "title":i.title,
  1377. "intro":i.intro,
  1378. "video_url": i.video_url.name,
  1379. "time": i.publish_date.strftime('%Y-%m-%d %H:%M:%S'),
  1380. "video_img": "%s"%i.video_img.name,
  1381. "author":i.author.username
  1382. })
  1383. data = json.dumps(dat,ensure_ascii=False)
  1384. return HttpResponse(data)
  1385. # 视频审核页面
  1386. class Video_Check_List(ListView):
  1387. def get(self,request):
  1388. hidden = request.GET.get('hidden')
  1389. page = int(request.GET.get('page'))
  1390. art_list = Video_data.objects.filter(hidden=hidden)
  1391. nums = art_list.count()
  1392. art = art_list[(10*(page-1)):(page*10)]
  1393. return render(request, 'backstageNet/infoManage/videoManageList.html', context={"art":art,"nums":nums})
  1394. def post(self,request):
  1395. art_id = request.POST.get('id')
  1396. req = request.POST.get('req')
  1397. art_obj = Video_data.objects.filter(id=art_id)
  1398. # 编辑
  1399. data = []
  1400. if req == "edit":
  1401. for i in art_obj:
  1402. data.append({
  1403. "id":i.id,
  1404. "title":i.title,
  1405. "intro":i.intro,
  1406. "video_img":i.video_img.name,
  1407. "video_url":i.video_url.name,
  1408. "author":i.author.username,
  1409. "time":i.publish_date.strftime('%Y-%m-%d %H:%M:%S'),
  1410. })
  1411. #删除
  1412. elif req == "del":
  1413. i = Video_data.objects.get(id=art_id)
  1414. ckobj = CKArticle.objects.get(title=i.title)
  1415. ckobj.delete()
  1416. art_obj.delete()
  1417. data = "1"
  1418. #保存
  1419. elif req == "check":
  1420. art_obj = Video_data.objects.get(id=art_id)
  1421. ckobj = CKArticle.objects.get(title=art_obj.title)
  1422. ckobj.hidden = True
  1423. ckobj.save()
  1424. art_obj.hidden = True
  1425. art_obj.save()
  1426. data = "1"
  1427. data = json.dumps(data)
  1428. return HttpResponse(data)
  1429. # 产品审核
  1430. class Equip_Check(ListView):
  1431. def get(self,request):
  1432. return render(request, 'backstageNet/infoManage/productManage.html', context={'role':'superuser'})
  1433. def post(self,request):
  1434. delete = request.POST.get('id')
  1435. product_see_id = request.POST.get("ids")
  1436. # 审核通过后删除
  1437. if delete:
  1438. try:
  1439. video_sta = Product.objects.get(id=delete)
  1440. video_sta.delete()
  1441. return HttpResponse("1")
  1442. except:
  1443. return HttpResponse("0")
  1444. # 审核通过查看详情
  1445. art_list = Product.objects.filter(id=product_see_id)
  1446. dat = []
  1447. for i in art_list:
  1448. dat.append({
  1449. "title":i.title,
  1450. "intro":i.intro,
  1451. "content": i.content,
  1452. "time": i.publish_date.strftime('%Y-%m-%d %H:%M:%S'),
  1453. "head_img": "%s"%i.head_img,
  1454. "mobile":i.mobile,
  1455. "author":i.author.username
  1456. })
  1457. data = json.dumps(dat)
  1458. return HttpResponse(data)
  1459. # 产品审核页面
  1460. class Equip_Check_List(ListView):
  1461. def get(self,request):
  1462. hidden = request.GET.get('hidden')
  1463. page = int(request.GET.get('page'))
  1464. art_list = Product.objects.filter(hidden=hidden)
  1465. nums = art_list.count()
  1466. art = art_list[(10*(page-1)):(page*10)]
  1467. return render(request, 'backstageNet/infoManage/productManageList.html', context={"art":art,"nums":nums})
  1468. def post(self,request):
  1469. art_id = request.POST.get('id')
  1470. req = request.POST.get('req')
  1471. art_obj = Product.objects.filter(id=art_id)
  1472. # 编辑
  1473. if req == "edit":
  1474. data = []
  1475. for i in art_obj:
  1476. data.append({
  1477. "id":i.id,
  1478. "title":i.title,
  1479. "intro":i.intro,
  1480. "head_img":i.head_img,
  1481. "content":i.content,
  1482. "mobile":i.mobile,
  1483. "author":i.author.username,
  1484. "time": i.publish_date.strftime('%Y-%m-%d %H:%M:%S'),
  1485. })
  1486. #删除
  1487. elif req == "del":
  1488. i = Product.objects.get(id=art_id)
  1489. ckobj = CKArticle.objects.get(title=i.title)
  1490. ckobj.delete()
  1491. art_obj.delete()
  1492. data = "1"
  1493. #审核通过
  1494. elif req == "check":
  1495. art_obj = Product.objects.get(id=art_id)
  1496. ckobj = CKArticle.objects.get(title=art_obj.title)
  1497. ckobj.hidden = True
  1498. ckobj.save()
  1499. art_obj.hidden = True
  1500. art_obj.save()
  1501. data = "1"
  1502. data = json.dumps(data)
  1503. return HttpResponse(data)
  1504. # 四季采摘审核
  1505. class Garden_Check(ListView):
  1506. def get(self,request):
  1507. return render(request, 'backstageNet/infoManage/pickManage.html', context={'role':'superuser'})
  1508. def post(self,request):
  1509. delete = request.POST.get('id')
  1510. garden_see_id = request.POST.get("ids")
  1511. if delete:
  1512. try:
  1513. garden_sta = Pick_Pub.objects.get(id=delete)
  1514. garden_sta.delete()
  1515. return HttpResponse("1")
  1516. except:
  1517. return HttpResponse("0")
  1518. art_list = Pick_Pub.objects.filter(id=garden_see_id)
  1519. dat = []
  1520. # 查看详情
  1521. for i in art_list:
  1522. dat.append({
  1523. "name":i.name,
  1524. "company":i.company,
  1525. "time": i.upl_time,
  1526. "img": "%s"%i.pick_img,
  1527. "farm":i.farm.name
  1528. })
  1529. data = json.dumps(dat)
  1530. return HttpResponse(data)
  1531. # 四季采摘审核页面
  1532. class Garden_Check_List(ListView):
  1533. def get(self,request):
  1534. hidden = request.GET.get('hidden')
  1535. page = int(request.GET.get('page'))
  1536. art_list = Pick_Pub.objects.filter(hidden=hidden)
  1537. nums = art_list.count()
  1538. art = art_list[(10*(page-1)):(page*10)]
  1539. return render(request, 'backstageNet/infoManage/pickManageList.html', context={"art":art,"nums":nums})
  1540. def post(self,request):
  1541. art_id = request.POST.get('id')
  1542. req = request.POST.get('req')
  1543. art_obj = Pick_Pub.objects.filter(id=art_id)
  1544. # 编辑
  1545. if req == "edit":
  1546. data = []
  1547. for i in art_obj:
  1548. data.append({
  1549. "id":i.id,
  1550. "name":i.name,
  1551. "company":i.company,
  1552. "pick_img":i.pick_img,
  1553. "time": i.upl_time,
  1554. "farm":i.farm.name,
  1555. "scale":i.scale,
  1556. "pick_s":i.pick_s,
  1557. "pick_e":i.pick_e,
  1558. "ripe_time":i.ripe_time,
  1559. "addr":i.addr,
  1560. "content":i.content
  1561. })
  1562. #删除
  1563. elif req == "del":
  1564. i = Pick_Pub.objects.get(id=art_id)
  1565. ckobj = CKArticle.objects.get(title=i.name)
  1566. ckobj.delete()
  1567. art_obj.delete()
  1568. data = "1"
  1569. #审核通过
  1570. elif req == "check":
  1571. art_obj = Pick_Pub.objects.get(id=art_id)
  1572. art_obj.hidden = True
  1573. ckobj = CKArticle.objects.get(title=art_obj.name)
  1574. ckobj.hidden = True
  1575. ckobj.save()
  1576. art_obj.save()
  1577. data = "1"
  1578. data = json.dumps(data,ensure_ascii=False)
  1579. return HttpResponse(data)
  1580. # 民宿审核
  1581. class Dorm_Check(ListView):
  1582. def get(self,request):
  1583. return render(request, 'backstageNet/infoManage/dormManage.html', context={'role':'superuser'})
  1584. def post(self,request):
  1585. hote_see_id = request.POST.get('ids')
  1586. delete = request.POST.get('id')
  1587. #已通过的删除
  1588. if delete:
  1589. try:
  1590. hote_sta = Hotel_Info.objects.get(id=delete)
  1591. hote_sta.delete()
  1592. return HttpResponse("1")
  1593. except:
  1594. return HttpResponse("0")
  1595. art_list = Hotel_Info.objects.filter(id=hote_see_id)
  1596. dat = []
  1597. # 通过后查看详情
  1598. for i in art_list:
  1599. dat.append({
  1600. "name":i.name,
  1601. "price":i.price,
  1602. "intro":i.intro,
  1603. "addr":i.addr,
  1604. "person":i.person,
  1605. "hotel_tel":i.hotel_tel,
  1606. "author":i.author.username,
  1607. "content":i.content,
  1608. "location":i.location,
  1609. # "time": i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),
  1610. "img": "%s"%i.hotel_img,
  1611. })
  1612. data = json.dumps(dat,ensure_ascii=False)
  1613. return HttpResponse(data)
  1614. # 民宿审核页面
  1615. class Dorm_Check_List(ListView):
  1616. def get(self,request):
  1617. hidden = request.GET.get('hidden')
  1618. page = int(request.GET.get('page'))
  1619. art_list = Hotel_Info.objects.filter(hidden=hidden)
  1620. nums = art_list.count()
  1621. art = art_list[(10*(page-1)):(page*10)]
  1622. return render(request, 'backstageNet/infoManage/dormManageList.html', context={"art":art,"nums":nums})
  1623. def post(self,request):
  1624. art_id = request.POST.get('id')
  1625. req = request.POST.get('req')
  1626. art_obj = Hotel_Info.objects.filter(id=art_id)
  1627. art = Hotel_Photo.objects.filter(hotel=art_id)
  1628. data = []
  1629. # 编辑
  1630. if req == "edit":
  1631. for i in art_obj:
  1632. data.append({
  1633. "id":i.id,
  1634. "name":i.name,
  1635. "price":i.price,
  1636. "intro":i.intro,
  1637. "addr":i.addr,
  1638. "location":i.location,
  1639. "person":i.person,
  1640. "hotel_img":i.hotel_img,
  1641. "hotel_tel":i.hotel_tel,
  1642. "content":i.content,
  1643. # "upl_time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),
  1644. })
  1645. for x in art:
  1646. data.append({"addr_photo":x.addr})
  1647. # data.append(x.addr)
  1648. #删除
  1649. elif req == "del":
  1650. i = Hotel_Info.objects.get(id=art_id)
  1651. ckobj = CKArticle.objects.get(title=i.name)
  1652. ckobj.delete()
  1653. art_obj.delete()
  1654. data = "1"
  1655. #审核通过
  1656. elif req == "check":
  1657. art_obj = Hotel_Info.objects.get(id=art_id)
  1658. ckobj = CKArticle.objects.get(title=art_obj.name)
  1659. ckobj.hidden = True
  1660. ckobj.save()
  1661. art_obj.hidden = True
  1662. art_obj.save()
  1663. data = "1"
  1664. data = json.dumps(data,ensure_ascii=False)
  1665. return HttpResponse(data)
  1666. # 农场审核
  1667. class Farm_Check(ListView):
  1668. def get(self,request):
  1669. return render(request, 'backstageNet/infoManage/farmManage.html', context={'role':'superuser'})
  1670. def post(self,request):
  1671. delete = request.POST.get('id')
  1672. garden_see_id = request.POST.get("ids")
  1673. if delete:
  1674. try:
  1675. garden_sta = Pick_Pub.objects.get(id=delete)
  1676. garden_sta.delete()
  1677. return HttpResponse("1")
  1678. except:
  1679. return HttpResponse("0")
  1680. art_list = Pick_Pub.objects.filter(id=garden_see_id)
  1681. dat = []
  1682. # 查看详情
  1683. for i in art_list:
  1684. dat.append({
  1685. "name":i.name,
  1686. "company":i.company,
  1687. "time": i.upl_time,
  1688. "img": "%s"%i.pick_img,
  1689. "farm":i.farm.name
  1690. })
  1691. data = json.dumps(dat)
  1692. return HttpResponse(data)
  1693. # 农场审核页面
  1694. class Farm_Check_List(ListView):
  1695. def get(self,request):
  1696. hidden = request.GET.get('hidden')
  1697. page = int(request.GET.get('page'))
  1698. art_list = GardenArea.objects.filter(hidden=hidden)
  1699. nums = art_list.count()
  1700. art = art_list[(10*(page-1)):(page*10)]
  1701. return render(request, 'backstageNet/infoManage/farmManageList.html', context={"art":art,"nums":nums})
  1702. def post(self,request):
  1703. art_id = request.POST.get('id')
  1704. req = request.POST.get('req')
  1705. art_obj = GardenArea.objects.filter(id=art_id)
  1706. #删除
  1707. if req == "del":
  1708. i = GardenArea.objects.get(id=art_id)
  1709. # ckobj = CKArticle.objects.get(title=i.name)
  1710. # ckobj.delete()
  1711. art_obj.delete()
  1712. data = "1"
  1713. #审核通过
  1714. elif req == "check1":
  1715. art_obj = GardenArea.objects.get(id=art_id)
  1716. # ckobj = CKArticle.objects.get(title=art_obj.name)
  1717. # ckobj.hidden = True
  1718. # ckobj.save()
  1719. art_obj.hidden = True
  1720. art_obj.save()
  1721. data = "1"
  1722. #审核通过
  1723. elif req == "check0":
  1724. art_obj = GardenArea.objects.get(id=art_id)
  1725. art_obj.hidden = False
  1726. art_obj.save()
  1727. data = "1"
  1728. data = json.dumps(data,ensure_ascii=False)
  1729. return HttpResponse(data)
  1730. # 景点审核
  1731. class Sightsee_Check(ListView):
  1732. def get(self,request):
  1733. return render(request, 'backstageNet/infoManage/sightseeManage.html', context={'role':'superuser'})
  1734. def post(self,request):
  1735. delete = request.POST.get('id')
  1736. garden_see_id = request.POST.get("ids")
  1737. if delete:
  1738. try:
  1739. garden_sta = Pick_Pub.objects.get(id=delete)
  1740. garden_sta.delete()
  1741. return HttpResponse("1")
  1742. except:
  1743. return HttpResponse("0")
  1744. art_list = Pick_Pub.objects.filter(id=garden_see_id)
  1745. dat = []
  1746. # 查看详情
  1747. for i in art_list:
  1748. dat.append({
  1749. "name":i.name,
  1750. "company":i.company,
  1751. "time": i.upl_time,
  1752. "img": "%s"%i.pick_img,
  1753. "farm":i.farm.name
  1754. })
  1755. data = json.dumps(dat)
  1756. return HttpResponse(data)
  1757. # 景点审核页面
  1758. class Sightsee_Check_List(ListView):
  1759. def get(self,request):
  1760. hidden = request.GET.get('hidden')
  1761. page = int(request.GET.get('page'))
  1762. sightsee = Sightsee_Info.objects.filter(hidden=hidden)
  1763. nums = sightsee.count()
  1764. sightsee = sightsee[(10*(page-1)):(page*10)]
  1765. return render(request, 'backstageNet/infoManage/sightseeManageList.html', context={"sightsee":sightsee,"nums":nums})
  1766. def post(self,request):
  1767. s_id = request.POST.get('id')
  1768. req = request.POST.get('req')
  1769. i = Sightsee_Info.objects.get(id=s_id)
  1770. if req == "edit":
  1771. data = {"name":i.name,"price":i.price,"desc":i.desc,"location":i.location,"addr":i.addr,"sightsee_stime":i.sightsee_stime,"sightsee_etime":i.sightsee_etime,
  1772. "sightsee_img":i.sightsee_img,"sightsee_tel":i.sightsee_tel,"upl_time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),"guide_img":i.guide_img,"content":i.content}
  1773. data = json.dumps(data,ensure_ascii=False)
  1774. elif req == "check":
  1775. ckobj = CKArticle.objects.get(title=i.name)
  1776. ckobj.hidden = True
  1777. ckobj.save()
  1778. i.hidden = True
  1779. i.save()
  1780. data = "1"
  1781. elif req == "del":
  1782. ckobj = CKArticle.objects.get(title=i.name)
  1783. ckobj.delete()
  1784. i.delete()
  1785. data = "1"
  1786. return HttpResponse(data)
  1787. # 产品发布图片上传
  1788. class Product_Photo(ListView):
  1789. def get(self,request):
  1790. pass
  1791. def post(self,request):
  1792. pass
  1793. # 新闻审核上传图片接口
  1794. class Test_Photo(ListView):
  1795. def get(self,request):
  1796. pass
  1797. def post(self,request):
  1798. # e_id = request.POST.get('id')
  1799. # news_sta = Article.objects.get(id=e_id)
  1800. news_photo = request.FILES['upload']
  1801. if news_photo:
  1802. print("新闻图片:", news_photo)
  1803. news_photo_dir = 'media/uploads/'
  1804. end_name = news_photo.name.split('.')[-1]
  1805. # 判断如果路径不存在,即创建路径
  1806. if os.path.exists(news_photo_dir) == False:
  1807. os.makedirs(news_photo_dir)
  1808. img = Image.open(news_photo)
  1809. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  1810. pic_name = now_time + '.' + end_name
  1811. print("pic_name:", pic_name)
  1812. img.save(news_photo_dir + pic_name)
  1813. news_photo = news_photo_dir + pic_name
  1814. print("new_photo:",news_photo)
  1815. data = {"uploaded": 1,"fileName": pic_name,"url": news_photo}
  1816. else:
  1817. new_photo = "0"
  1818. data = {"code": 404,"msg": "","data": {"src": news_photo}}
  1819. data = json.dumps(data)
  1820. return HttpResponse(data)
  1821. class Guide_Img(ListView):
  1822. def get(self,request):
  1823. pass
  1824. def post(self,request):
  1825. # e_id = request.POST.get('id')
  1826. # news_sta = Article.objects.get(id=e_id)
  1827. guide_photo = request.FILES['upload']
  1828. if guide_photo:
  1829. print("新闻图片:", guide_photo)
  1830. news_photo_dir = 'media/uploads/'
  1831. end_name = guide_photo.name.split('.')[-1]
  1832. # 判断如果路径不存在,即创建路径
  1833. if os.path.exists(news_photo_dir) == False:
  1834. os.makedirs(news_photo_dir)
  1835. img = Image.open(guide_photo)
  1836. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  1837. pic_name = now_time + '.' + end_name
  1838. print("pic_name:", pic_name)
  1839. img.save(news_photo_dir + pic_name)
  1840. news_photo = news_photo_dir + pic_name
  1841. print("new_photo:",news_photo)
  1842. data = {"code": 0,"msg": "","data": {"src": news_photo}}
  1843. else:
  1844. new_photo = "0"
  1845. data = {"code": 404,"msg": "","data": {"src": news_photo}}
  1846. data = json.dumps(data)
  1847. return HttpResponse(data)
  1848. class CKArticle_View(ListView):
  1849. def get(self,request):
  1850. pass
  1851. def post(self,request):
  1852. username = request.user.username
  1853. print('username:',username)
  1854. current_user = MyUser.objects.get(username=username)
  1855. news_photo = request.POST.get('upload')
  1856. writer = request.POST.get('writer')
  1857. intro = request.POST.get('intro')
  1858. title = request.POST.get('title')
  1859. art_type = request.POST.get('art_type')
  1860. content = request.POST.get('content')
  1861. edit = request.POST.get('edit')
  1862. if edit == "1":
  1863. CKArticle.objects.filter(title=title).update(
  1864. art_type=art_type,
  1865. writer=writer,
  1866. intro=intro,
  1867. title=title,
  1868. content=content,
  1869. head_img=news_photo
  1870. )
  1871. return HttpResponse("1")
  1872. if CKArticle.objects.filter(title=title).exists():
  1873. return HttpResponse("2")
  1874. try:
  1875. # CKArticle.objects.create(auther=current_user.username,art_type=art_type,writer=writer,intro=intro,title=title,content=content,head_img=news_photo)
  1876. if art_type == "5":
  1877. return HttpResponse("1")
  1878. CKArticle.objects.create(art_type=art_type,writer=writer,intro=intro,title=title,content=content,head_img=news_photo)
  1879. data = "1"
  1880. except Exception as e:
  1881. print("错误信息为",e)
  1882. data = "0"
  1883. return HttpResponse(data)
  1884. #园区筛选
  1885. class Park_Land(ListView):
  1886. def get(self,request):
  1887. username = request.user.username
  1888. print('username:',username)
  1889. current_user = MyUser.objects.get(username=username)
  1890. data = []
  1891. if current_user.is_superuser != True and current_user.is_staff != True:
  1892. #用户
  1893. art_list = GardenArea.objects.filter(user=current_user)
  1894. else:
  1895. #管理员
  1896. art_list = GardenArea.objects.all()
  1897. for i in art_list:
  1898. data.append({"name":i.name,"id":i.id})
  1899. data = json.dumps(data)
  1900. return HttpResponse(data)
  1901. # 农场管理
  1902. class Garden_Manage_New(ListView):
  1903. def get(self,request):
  1904. gardenid = int(request.GET.get("ids"))
  1905. username = request.user.username
  1906. print('username:',username)
  1907. current_user = MyUser.objects.get(username=username)
  1908. garden = GardenArea.objects.get(id=gardenid)
  1909. art_list = FarmList.objects.filter(garden=garden)
  1910. nums = len(art_list)
  1911. page = int(request.GET.get('page'))
  1912. art = art_list[(9*(page-1)):(page*9)]
  1913. return render(request, 'backstageNet/production/gardenNew.html', context={"art":art,"nums":nums})
  1914. def post(self,request):
  1915. req = request.POST.get("req")
  1916. farm_id = request.POST.get('id')
  1917. art_list=FarmList.objects.filter(id=farm_id)
  1918. print(art_list)
  1919. data = []
  1920. #编辑回显数据
  1921. if req =="edit":
  1922. for i in art_list:
  1923. if i.manage_user:
  1924. data.append({
  1925. "id":i.id,
  1926. "name":i.name,
  1927. "user":i.user.username,
  1928. "manage_user":i.manage_user.name,
  1929. "area":i.area,
  1930. "curr_var":i.curr_var,
  1931. "farm_img":i.farm_img,
  1932. "farm_desc":i.farm_desc
  1933. })
  1934. else:
  1935. data.append({
  1936. "id":i.id,
  1937. "name":i.name,
  1938. "user":i.user.username,
  1939. "manage_user":"",
  1940. "area":i.area,
  1941. "curr_var":i.curr_var,
  1942. "farm_img":i.farm_img,
  1943. "farm_desc":i.farm_desc
  1944. })
  1945. #删除数据
  1946. if req == 'del':
  1947. try:
  1948. Pick_Pub.objects.filter(farm=farm_id).delete()
  1949. FarmList.objects.filter(id=farm_id).delete()
  1950. data = "1"
  1951. except:
  1952. data = "0"
  1953. # if len(pickid) == 0:
  1954. # art.delete()
  1955. # data="1"
  1956. # elif len(pickid) != 0:
  1957. # pickid.delete()
  1958. # art.delete()
  1959. # data="1"
  1960. data = json.dumps(data,ensure_ascii=False)
  1961. return HttpResponse(data)
  1962. # 修改农场管理
  1963. class Garden_Manage_View(ListView):
  1964. def get(self,request):
  1965. username = request.user.username
  1966. print('username:',username)
  1967. current_user = MyUser.objects.get(username=username)
  1968. if current_user.is_staff == True:
  1969. garden = GardenArea.objects.all()
  1970. elif current_user.is_staff != True:
  1971. garden = GardenArea.objects.filter(user=current_user)
  1972. return render(request, 'backstageNet/production/gardenManage.html', context={"garden":garden})
  1973. def post(self,request):
  1974. #农场id
  1975. farm_id = request.POST.get('id')
  1976. #农场名称
  1977. name = request.POST.get('name')
  1978. #农场介绍
  1979. farm_desc = request.POST.get('content')
  1980. #农场面积
  1981. area = request.POST.get('area')
  1982. #农场品种
  1983. curr_var = request.POST.get('curr_var')
  1984. #农场图片
  1985. farm_img = request.POST.get('img_url')
  1986. #园区id
  1987. gardenid = request.POST.get("ids")
  1988. #修改当前数据
  1989. username = request.user.username
  1990. print('username:',username)
  1991. current_user = MyUser.objects.get(username=username)
  1992. if farm_id:
  1993. try:
  1994. hote_sta = FarmList.objects.filter(id=farm_id).update(
  1995. name=name,
  1996. farm_desc=farm_desc,
  1997. area=area,
  1998. curr_var=curr_var,
  1999. farm_img=farm_img,
  2000. user=current_user,
  2001. )
  2002. data="1"
  2003. except Exception as e:
  2004. print(e)
  2005. data="0"
  2006. else:
  2007. try:
  2008. gardens=GardenArea.objects.get(id=gardenid)
  2009. if FarmList.objects.filter(name=name,user=current_user):
  2010. data = "0"
  2011. else:
  2012. FarmList.objects.create(
  2013. name=name,
  2014. farm_desc=farm_desc,
  2015. area=area,
  2016. curr_var=curr_var,
  2017. farm_img=farm_img,
  2018. user=current_user,
  2019. garden=gardens
  2020. )
  2021. data="1"
  2022. except Exception as e:
  2023. print(e)
  2024. data="0"
  2025. return HttpResponse(data)
  2026. # 新建人员管理
  2027. class Garden_User_View(ListView):
  2028. def get(self,request):
  2029. username = request.user.username
  2030. print('username:',username)
  2031. current_user = MyUser.objects.get(username=username)
  2032. gardenname = request.GET.get("name")
  2033. if current_user.is_staff == True:
  2034. garden = GardenArea.objects.all()
  2035. elif current_user.is_staff != True:
  2036. garden = GardenArea.objects.filter(user=current_user)
  2037. if gardenname:
  2038. garden = GardenArea.objects.filter(name=gardenname)
  2039. farm = FarmList.objects.filter(garden=garden[0])
  2040. if current_user.is_staff == True:
  2041. garden = GardenArea.objects.all()
  2042. elif current_user.is_staff != True:
  2043. garden = GardenArea.objects.filter(user=current_user)
  2044. return render(request, 'backstageNet/production/workerManage.html', context={"garden":garden,"farm":farm})
  2045. def post(self,request):
  2046. #管理者id
  2047. farm_id = request.POST.get('id')
  2048. #管理者名称
  2049. name = request.POST.get('name')
  2050. #性别
  2051. gender = request.POST.get('sex')
  2052. #联系方式
  2053. mobile = request.POST.get('mobile')
  2054. #管理农场
  2055. farm_name = request.POST.get("city")
  2056. #修改
  2057. if farm_id:
  2058. try:
  2059. hote_sta = FarmUser.objects.filter(id=farm_id).update(
  2060. name=name,
  2061. gender=gender,
  2062. mobile=mobile,
  2063. )
  2064. data="1"
  2065. if data=="1":
  2066. farms =FarmUser.objects.get(name=name)
  2067. farm = FarmList.objects.filter(name=farm_name).update(
  2068. manage_user=farms
  2069. )
  2070. data="1"
  2071. except Exception as e:
  2072. print(e)
  2073. data="0"
  2074. else:
  2075. #增加
  2076. try:
  2077. FarmUser.objects.create(
  2078. name=name,
  2079. gender=gender,
  2080. mobile=mobile,
  2081. )
  2082. data="1"
  2083. if data=="1":
  2084. farms =FarmUser.objects.get(name=name)
  2085. farm = FarmList.objects.filter(name=farm_name).update(
  2086. manage_user=farms
  2087. )
  2088. data="1"
  2089. except Exception as e:
  2090. print(e)
  2091. data="0"
  2092. return HttpResponse(data)
  2093. # 人员管理
  2094. class Garden_User_New(ListView):
  2095. def get(self,request):
  2096. username = request.user.username
  2097. print('username:',username)
  2098. current_user = MyUser.objects.get(username=username)
  2099. farmid = request.GET.get('id')
  2100. art_list = FarmUser.objects.get(id=farmid)
  2101. FarmUser.objects.all()
  2102. nums = art_list.count()
  2103. page = int(request.GET.get('page'))
  2104. art = art_list[(9*(page-1)):(page*9)]
  2105. return render(request, 'backstageNet/production/workerNew.html', context={"art":art,"nums":nums})
  2106. def post(self,request):
  2107. req = request.POST.get("req")
  2108. farmuser_id = request.POST.get('id')
  2109. art_list = FarmUser.objects.filter(id=farmuser_id)
  2110. data = []
  2111. #编辑数据回显
  2112. if req == "edit":
  2113. for i in art_list:
  2114. data.append({
  2115. "id":i.id,
  2116. "name":i.name,
  2117. "gender":i.gender,
  2118. "mobile":i.mobile
  2119. })
  2120. #删除
  2121. elif req == 'del':
  2122. art_list.delete()
  2123. data = "1"
  2124. data = json.dumps(data,ensure_ascii=False)
  2125. return HttpResponse(data)
  2126. # 库存新建
  2127. class Repertory_View(ListView):
  2128. def get(self,request):
  2129. # page = request.GET.get("page")
  2130. username = request.user.username
  2131. print('username:',username)
  2132. current_user = MyUser.objects.get(username=username)
  2133. data = []
  2134. if current_user.is_superuser != True and current_user.is_staff != True:
  2135. #用户
  2136. art_list = GardenArea.objects.filter(user=current_user)
  2137. else:
  2138. #管理员
  2139. art_list = GardenArea.objects.all()
  2140. return render(request, 'backstageNet/production/repertoryManage.html', context={"art_list":art_list})
  2141. def post(self,request):
  2142. uid = request.user.id
  2143. #库存id
  2144. store_id = request.POST.get('id')
  2145. #物料名称
  2146. name = request.POST.get('name')
  2147. #物料类别
  2148. rtype = request.POST.get('rtype')
  2149. #规格
  2150. spec = request.POST.get('spec')
  2151. #库存
  2152. rese = request.POST.get('rese')
  2153. #园区
  2154. gradenid = request.POST.get('graden')
  2155. #修改
  2156. if store_id:
  2157. try:
  2158. hote_sta = Store_Manage.objects.filter(id=store_id).update(
  2159. name=name,
  2160. rtype=rtype,
  2161. spec=spec,
  2162. rese=rese,
  2163. )
  2164. data = "1"
  2165. except Exception as e:
  2166. print(e)
  2167. data = "0"
  2168. else:
  2169. #新增
  2170. try:
  2171. gradens=GardenArea.objects.get(id=gradenid)
  2172. Store_Manage.objects.create(
  2173. name=name,
  2174. rtype=rtype,
  2175. spec=spec,
  2176. rese=rese,
  2177. graden=gradens
  2178. )
  2179. data = "1"
  2180. except Exception as e:
  2181. print(e)
  2182. data = "0"
  2183. return HttpResponse(data)
  2184. # 库存管理
  2185. class Repertory_New(ListView):
  2186. def get(self,request):
  2187. username = request.user.username
  2188. print('username:',username)
  2189. current_user = MyUser.objects.get(username=username)
  2190. ids = int(request.GET.get('ids'))
  2191. try:
  2192. art = GardenArea.objects.get(id=ids)
  2193. art_list = Store_Manage.objects.filter(graden=art)
  2194. print(art_list)
  2195. except Exception as e:
  2196. print(e)
  2197. art_list = ""
  2198. nums = len(art_list)
  2199. page = int(request.GET.get('page'))
  2200. art = art_list[(9*(page-1)):(page*9)]
  2201. return render(request, 'backstageNet/production/repertoryNew.html', context={"art":art,"nums":nums})
  2202. def post(self,request):
  2203. req = request.POST.get("req")
  2204. store_id = request.POST.get('id')
  2205. art_list=Store_Manage.objects.filter(id=store_id)
  2206. data = []
  2207. #编辑数据回显
  2208. if req == "edit":
  2209. for i in art_list:
  2210. data.append({
  2211. "id":i.id,
  2212. "name":i.name,
  2213. "rtype":i.rtype,
  2214. "spec":i.spec,
  2215. "rese":i.rese
  2216. })
  2217. #删除
  2218. elif req == 'del':
  2219. art_list.delete()
  2220. data = "1"
  2221. data = json.dumps(data,ensure_ascii=False)
  2222. return HttpResponse(data)
  2223. # 库存管理(出库,入库)
  2224. class Repertory_New_View(ListView):
  2225. def get(self,request):
  2226. pass
  2227. def post(self,request):
  2228. req = request.POST.get("req")
  2229. store_id = request.POST.get('id')
  2230. num = int(request.POST.get('num'))
  2231. print("num",num)
  2232. art_list = Store_Manage.objects.filter(id=store_id)
  2233. #出库
  2234. if req == "see":
  2235. for i in art_list:
  2236. res = int(i.rese)
  2237. r = res-num
  2238. if r >0 or r == 0:
  2239. Store_Manage.objects.filter(id=store_id).update(rese=r)
  2240. data = "1"
  2241. else:
  2242. data = "0"
  2243. return HttpResponse(data)
  2244. #入库
  2245. elif req == "add":
  2246. for i in art_list:
  2247. res = int(i.rese)
  2248. r = res+num
  2249. if r:
  2250. Store_Manage.objects.filter(id=store_id).update(rese=r)
  2251. data = "1"
  2252. else:
  2253. data = "0"
  2254. return HttpResponse(data)
  2255. # 园区下地块
  2256. class Sell_Land(ListView):
  2257. def get(self,request):
  2258. username = request.user.username
  2259. print('username:',username)
  2260. data = []
  2261. current_user = MyUser.objects.get(username=username)
  2262. if current_user.is_superuser != True and current_user.is_staff != True:
  2263. farm_l = GardenArea.objects.filter(user=current_user)
  2264. else:
  2265. farm_l = GardenArea.objects.all()
  2266. for i in farm_l:
  2267. print(i.id)
  2268. try:
  2269. farm_list = FarmList.objects.get(garden=i.id)
  2270. # print(farm_list.name)
  2271. farm_list = farm_list.name
  2272. except:
  2273. farm_list = ''
  2274. data.append({"garden":i.name,"farm_name":farm_list})
  2275. data = json.dumps(data)
  2276. return HttpResponse(data)
  2277. #销售图片
  2278. class Sell_Photo(ListView):
  2279. def post(self,request):
  2280. gar_photo = request.FILES.get('gar_img')
  2281. if gar_photo:
  2282. print("视频图片:", gar_photo)
  2283. garden_photo_dir = 'sell_photo/'
  2284. end_name = gar_photo.name.split('.')[-1]
  2285. # 判断如果路径不存在,即创建路径
  2286. if os.path.exists(garden_photo_dir) == False:
  2287. os.makedirs(garden_photo_dir)
  2288. img = Image.open(gar_photo)
  2289. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  2290. pic_name = now_time + '.' + end_name
  2291. print("pic_name:", pic_name)
  2292. img.save(garden_photo_dir + pic_name)
  2293. gar_photo = garden_photo_dir + pic_name
  2294. print("gar_photo:",gar_photo)
  2295. data = {"code": 0,"msg": "","data": {"src": gar_photo}}
  2296. else:
  2297. pro_photo = "0"
  2298. data = {"code": 404,"msg": "","data": {"src": gar_photo}}
  2299. data = json.dumps(data)
  2300. return HttpResponse(data)
  2301. # 销售管理
  2302. class Sell_View(ListView):
  2303. def get(self,request):
  2304. username = request.user.username
  2305. print('username:',username)
  2306. current_user = MyUser.objects.get(username=username)
  2307. area_list = GardenArea.objects.all()
  2308. area_obj = GardenArea.objects.all().first()
  2309. farm_list = FarmList.objects.filter(garden=area_obj)
  2310. return render(request, 'backstageNet/production/sellManage.html',context={"area_list":area_list,"farm_list":farm_list})
  2311. def post(self,request):
  2312. username = request.user.username
  2313. print('username:',username)
  2314. current_user = MyUser.objects.get(username=username)
  2315. page = int(request.POST.get("page"))
  2316. dat = []
  2317. try:
  2318. # user_gar = GardenArea.objects.get(user=current_user)
  2319. # farm_list = FarmList.objects.filter(garden=user_gar)
  2320. if current_user.is_superuser != True and current_user.is_staff != True:
  2321. farm_list = FarmList.objects.filter(garden__user=current_user)
  2322. else:
  2323. farm_list = FarmList.objects.all()
  2324. for i in farm_list:
  2325. for x in Sell_Manage.objects.filter(farm=i):
  2326. dat.append({
  2327. "id":x.id,
  2328. "farm":x.farm.name,"name":x.name,
  2329. "num":x.num,"money":x.money,
  2330. "time":x.upl_time.strftime('%Y-%m-%d'),
  2331. "sell_img":x.sell_img
  2332. })
  2333. except Exception as e:
  2334. print(e)
  2335. dat = []
  2336. nums = len(dat)
  2337. dat = dat[(9*(page-1)):(page*9)]
  2338. data = json.dumps({"dat":dat,"nums":nums})
  2339. return HttpResponse(data)
  2340. # 销售新建
  2341. class Sell_New(ListView):
  2342. def get(self,request):
  2343. pass
  2344. def post(self,request):
  2345. farm = request.POST.get("farm")
  2346. name = request.POST.get("name")
  2347. num = request.POST.get("num")
  2348. money = request.POST.get("money")
  2349. time = request.POST.get("time")
  2350. s_id = request.POST.get("id")
  2351. sell_img = request.POST.get("sell_img")
  2352. username = request.user.id
  2353. if s_id:
  2354. try:
  2355. farm_obj = FarmList.objects.get(name=farm,user=username)
  2356. sell_obj = Sell_Manage.objects.get(id=s_id)
  2357. sell_obj.farm = farm_obj
  2358. sell_obj.name = name
  2359. sell_obj.num = num
  2360. sell_obj.money = money
  2361. sell_obj.upl_time = time
  2362. sell_obj.sell_img = sell_img
  2363. sell_obj.save()
  2364. data = "1"
  2365. except Exception as e:
  2366. print(e)
  2367. data = "0"
  2368. else:
  2369. try:
  2370. farm_obj = FarmList.objects.get(name=farm,user=username)
  2371. Sell_Manage.objects.create(farm=farm_obj,name=name,num=num,money=money,upl_time=time,sell_img=sell_img)
  2372. data = "1"
  2373. except Exception as e:
  2374. print(e)
  2375. data = "0"
  2376. return HttpResponse(data)
  2377. # 销售删除
  2378. class Sell_Del(ListView):
  2379. def get(self,request):
  2380. pass
  2381. def post(self,request):
  2382. s_id = request.POST.get("id")
  2383. try:
  2384. sell_obj = Sell_Manage.objects.get(id=s_id)
  2385. sell_obj.delete()
  2386. data = "1"
  2387. except Exception as e:
  2388. print(e)
  2389. data = "0"
  2390. return HttpResponse(data)
  2391. # 数据分析
  2392. class Cropdata(ListView):
  2393. def get(self,request):
  2394. return render(request, 'backstageNet/production/cropdata.html', context={})
  2395. def post(self,request):
  2396. pass
  2397. # 种植统计
  2398. class CropCount(ListView):
  2399. def get(self,request):
  2400. username = request.user.username
  2401. print('username:',username)
  2402. current_user = MyUser.objects.get(username=username)
  2403. gardenname = request.GET.get("name")
  2404. if current_user.is_staff == True:
  2405. garden = GardenArea.objects.all()
  2406. elif current_user.is_staff != True:
  2407. garden = GardenArea.objects.filter(user=current_user)
  2408. if gardenname:
  2409. garden = GardenArea.objects.filter(name=gardenname)
  2410. farm = FarmList.objects.filter(garden=garden[0])
  2411. if current_user.is_staff == True:
  2412. garden = GardenArea.objects.all()
  2413. elif current_user.is_staff != True:
  2414. garden = GardenArea.objects.filter(user=current_user)
  2415. return render(request, 'backstageNet/production/cropcount.html', context={"garden":garden,"farm":farm})
  2416. def post(self,request):
  2417. username = request.user.username
  2418. crop_count = request.POST.get('crop_count')
  2419. area = request.POST.get('area')
  2420. crop_id = request.POST.get('id')
  2421. upl_time = request.POST.get("upl_time")
  2422. cropname = request.POST.get('cropname')
  2423. city = request.POST.get("city")
  2424. crop_img = request.POST.get("crop_img")
  2425. count=crop_count + city
  2426. print(count)
  2427. #修改
  2428. if crop_id:
  2429. print("修改")
  2430. try:
  2431. crops =FarmList.objects.get(name=area)
  2432. crop = Areacrop.objects.filter(id=crop_id).update(
  2433. cropname=cropname,
  2434. area=crops,
  2435. upl_time=upl_time,
  2436. crop_count=count,
  2437. crop_img=crop_img,
  2438. )
  2439. data = "1"
  2440. except Exception as e:
  2441. print(e)
  2442. data = "0"
  2443. else:
  2444. print("新增")
  2445. #新增
  2446. try:
  2447. crops =FarmList.objects.get(name=area)
  2448. Areacrop.objects.create(
  2449. cropname=cropname,
  2450. area=crops,
  2451. upl_time=upl_time,
  2452. crop_count=count,
  2453. crop_img=crop_img,
  2454. )
  2455. data = "1"
  2456. except Exception as e:
  2457. print(e)
  2458. data = "0"
  2459. return HttpResponse(data)
  2460. #种植管理
  2461. class CropCount_Photo(ListView):
  2462. def get(self,request):
  2463. pass
  2464. def post(self,request):
  2465. gar_photo = request.FILES.get('gar_img')
  2466. if gar_photo:
  2467. print("视频图片:", gar_photo)
  2468. garden_photo_dir = 'cropcount_photo/'
  2469. end_name = gar_photo.name.split('.')[-1]
  2470. # 判断如果路径不存在,即创建路径
  2471. if os.path.exists(garden_photo_dir) == False:
  2472. os.makedirs(garden_photo_dir)
  2473. img = Image.open(gar_photo)
  2474. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  2475. pic_name = now_time + '.' + end_name
  2476. print("pic_name:", pic_name)
  2477. img.save(garden_photo_dir + pic_name)
  2478. gar_photo = garden_photo_dir + pic_name
  2479. print("gar_photo:",gar_photo)
  2480. data = {"code": 0,"msg": "","data": {"src": gar_photo}}
  2481. else:
  2482. pro_photo = "0"
  2483. data = {"code": 404,"msg": "","data": {"src": gar_photo}}
  2484. data = json.dumps(data)
  2485. return HttpResponse(data)
  2486. # 种植管理
  2487. class CropCount_View(ListView):
  2488. def get(self,request):
  2489. username = request.user.username
  2490. print('username:',username)
  2491. current_user = MyUser.objects.get(username=username)
  2492. gardenid = request.GET.get("ids")
  2493. page = int(request.GET.get("page"))
  2494. dat = []
  2495. art = FarmList.objects.filter(id=gardenid)
  2496. if art:
  2497. for i in art:
  2498. art_list = Areacrop.objects.filter(area=i)
  2499. for x in art_list:
  2500. time = int(x.upl_time.strftime("%Y%m%d"))
  2501. time_now = int(timezone.now().strftime("%Y%m%d"))
  2502. data = time_now-time
  2503. print(data)
  2504. curro = ""
  2505. h2 = {"cropname":x.cropname,
  2506. "area":x.area.name,
  2507. "crop_count":x.crop_count,
  2508. "img":x.area.farm_img,
  2509. "time":data,
  2510. "id":x.id,
  2511. "upl_time":x.upl_time.strftime('%Y-%m-%d'),
  2512. "crop_img":x.crop_img,
  2513. }
  2514. dat.append({"data":h2,"curro":curro})
  2515. nums = len(dat)
  2516. dat = dat[(9*(page-1)):(page*9)]
  2517. data = json.dumps({"dat":dat,"nums":nums})
  2518. return HttpResponse(data)
  2519. def post(self,request):
  2520. req = request.POST.get("req")
  2521. areacropid = request.POST.get("id")
  2522. art_list = Areacrop.objects.filter(id=areacropid)
  2523. data = []
  2524. #结束时间
  2525. if req == "end":
  2526. for x in art_list:
  2527. Areacrop.objects.filter(id=areacropid).update(
  2528. end_time=datetime.datetime.now()
  2529. )
  2530. data = "1"
  2531. #编辑数据返现
  2532. elif req == "edit":
  2533. for i in art_list:
  2534. data.append({
  2535. "id":i.id,
  2536. "area":i.area.name,
  2537. "crop_count":i.crop_count,
  2538. "cropname":i.cropname,
  2539. "upl_time":i.upl_time.strftime('%Y-%m-%d'),
  2540. "crop_img":i.crop_img,
  2541. })
  2542. #删除
  2543. elif req == "del":
  2544. art_list.delete()
  2545. data = "1"
  2546. data = json.dumps(data)
  2547. return HttpResponse(data)
  2548. # 个人采摘
  2549. class Pick(ListView):
  2550. def get(self,request):
  2551. username = request.user.username
  2552. print('username:',username)
  2553. current_user = MyUser.objects.get(username=username)
  2554. try:
  2555. # user_gar = GardenArea.objects.get(user=current_user)
  2556. farm_list = FarmList.objects.filter(garden__user=current_user)
  2557. except Exception as e:
  2558. print(e)
  2559. farm_list = ""
  2560. nums = farm_list.count()
  2561. return render(request, 'backstageNet/production/pick.html', context={"farm_list":farm_list,"nums":nums})
  2562. def post(self,request):
  2563. username = request.user.username
  2564. print('username:',username)
  2565. current_user = MyUser.objects.get(username=username)
  2566. page = int(request.POST.get("page"))
  2567. dat = []
  2568. try:
  2569. farm_list = FarmList.objects.filter(garden__user=current_user)
  2570. for i in farm_list:
  2571. for x in Person_Pick.objects.filter(farm=i):
  2572. dat.append({
  2573. "id":x.id,
  2574. "farm":x.farm.name,"name":x.name,
  2575. "num":x.num,"var":x.var,
  2576. "time":x.upl_time.strftime('%Y-%m-%d')
  2577. })
  2578. except Exception as e:
  2579. print(e)
  2580. dat = []
  2581. nums = len(dat)
  2582. dat = dat[(9*(page-1)):(page*9)]
  2583. data = json.dumps({"dat":dat,"nums":nums})
  2584. return HttpResponse(data)
  2585. # 采摘新建
  2586. class Pick_New(ListView):
  2587. def get(self,request):
  2588. pass
  2589. def post(self,request):
  2590. farm = request.POST.get("farm")
  2591. name = request.POST.get("name")
  2592. num = request.POST.get("num")
  2593. var = request.POST.get("var")
  2594. time = request.POST.get("time")
  2595. p_id = request.POST.get("id")
  2596. if p_id:
  2597. try:
  2598. farm_obj = FarmList.objects.get(name=farm)
  2599. pick_obj = Person_Pick.objects.get(id=p_id)
  2600. pick_obj.farm = farm_obj
  2601. pick_obj.name = name
  2602. pick_obj.num = num
  2603. pick_obj.var = var
  2604. pick_obj.upl_time = time
  2605. pick_obj.save()
  2606. data = "1"
  2607. except Exception as e:
  2608. print(e)
  2609. data = "0"
  2610. else:
  2611. try:
  2612. farm_obj = FarmList.objects.get(name=farm)
  2613. Person_Pick.objects.create(farm=farm_obj,name=name,num=num,var=var,upl_time=time)
  2614. data = "1"
  2615. except Exception as e:
  2616. print(e)
  2617. data = "0"
  2618. return HttpResponse(data)
  2619. # 采摘删除
  2620. class Pick_Del(ListView):
  2621. def get(self,request):
  2622. pass
  2623. def post(self,request):
  2624. p_id = request.POST.get("id")
  2625. try:
  2626. pick_obj = Person_Pick.objects.get(id=p_id)
  2627. pick_obj.delete()
  2628. data = "1"
  2629. except Exception as e:
  2630. print(e)
  2631. data = "0"
  2632. return HttpResponse(data)
  2633. # 类型分析
  2634. class Type_View(ListView):
  2635. def get(self,request):
  2636. username = request.user.username
  2637. print('username:',username)
  2638. current_user = MyUser.objects.get(username=username)
  2639. area_list = GardenArea.objects.all()
  2640. return render(request, 'backstageNet/datacenter/cropdata.html', context={"area_list":area_list})
  2641. def post(self,request):
  2642. area = request.POST.get("id")
  2643. username = request.user.username
  2644. print('username:',username)
  2645. current_user = MyUser.objects.get(username=username)
  2646. year = datetime.datetime.now().year
  2647. start_1 = datetime.date(year,1,1)
  2648. end_1 = datetime.date(year,3,31)
  2649. start_2 = datetime.date(year,4,1)
  2650. end_2 = datetime.date(year,6,30)
  2651. start_3 = datetime.date(year,7,1)
  2652. end_3 = datetime.date(year,9,30)
  2653. start_4 = datetime.date(year,10,1)
  2654. end_4 = datetime.date(year,12,31)
  2655. money = 0
  2656. dat = []
  2657. dat1 = []
  2658. dat2 = []
  2659. dat3 = []
  2660. dat4 = []
  2661. start_date = datetime.datetime.now().year
  2662. start_date = datetime.date(start_date,1,1)
  2663. end_date = datetime.datetime.now()
  2664. if area:
  2665. # area_obj = GardenArea.objects.get(id=area)
  2666. for i in FarmList.objects.filter(garden_id=area):
  2667. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_1, end_1)):
  2668. money = money + int(x.money)
  2669. dat1.append({"farm":i.name,"money":money})
  2670. money = 0
  2671. for i in FarmList.objects.filter(garden_id=area):
  2672. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_2, end_2)):
  2673. money = money + int(x.money)
  2674. dat2.append({"farm":i.name,"money":money})
  2675. money = 0
  2676. for i in FarmList.objects.filter(garden_id=area):
  2677. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_3, end_3)):
  2678. money = money + int(x.money)
  2679. dat3.append({"farm":i.name,"money":money})
  2680. money = 0
  2681. for i in FarmList.objects.filter(garden_id=area):
  2682. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_4, end_4)):
  2683. money = money + int(x.money)
  2684. dat4.append({"farm":i.name,"money":money})
  2685. money = 0
  2686. for i in FarmList.objects.filter(garden_id=area):
  2687. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_date, end_date)):
  2688. money = money + int(x.money)
  2689. dat.append({"area":i.area,"name":i.name,"money":money})
  2690. money = 0
  2691. data = json.dumps({"1":dat1,"2":dat2,"3":dat3,"4":dat4,"dat":dat})
  2692. return HttpResponse(data)
  2693. # 对比分析
  2694. class Contrast_View(ListView):
  2695. def get(self,request):
  2696. username = request.user.username
  2697. print('username:',username)
  2698. current_user = MyUser.objects.get(username=username)
  2699. area_list = GardenArea.objects.all()
  2700. area_obj = GardenArea.objects.all().first()
  2701. farm_list = FarmList.objects.filter(garden=area_obj)
  2702. return render(request, 'backstageNet/datacenter/contrast.html', context={"area_list":area_list,"farm_list":farm_list})
  2703. def post(self,request):
  2704. area_id = request.POST.get("id")
  2705. farm_list = FarmList.objects.filter(garden_id=area_id)
  2706. dat= []
  2707. for i in farm_list:
  2708. dat.append({"name":i.name,"id":i.id})
  2709. data = json.dumps(dat)
  2710. return HttpResponse(data)
  2711. # 对比分析详情
  2712. class Contrast_Detail(ListView):
  2713. def get(self,request):
  2714. pass
  2715. def post(self,request):
  2716. farm_id = request.POST.get("id")
  2717. year = datetime.datetime.now().year
  2718. start_1 = datetime.date(year,1,1)
  2719. end_1 = datetime.date(year,12,31)
  2720. start_2 = datetime.date(year-1,1,1)
  2721. end_2 = datetime.date(year-1,12,31)
  2722. start_3 = datetime.date(year-2,1,1)
  2723. end_3 = datetime.date(year-2,12,31)
  2724. start_4 = datetime.date(year-3,1,1)
  2725. end_4 = datetime.date(year-3,12,31)
  2726. dat1 = []
  2727. dat2 = []
  2728. dat3 = []
  2729. dat4 = []
  2730. money = 0
  2731. if farm_id != "":
  2732. print("+++++++++++++++++")
  2733. # area_obj = GardenArea.objects.get(id=area)
  2734. for i in FarmList.objects.filter(id=farm_id):
  2735. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_1, end_1)):
  2736. money = money + int(x.money)
  2737. dat1.append({"farm":i.name,"money":money})
  2738. money = 0
  2739. for i in FarmList.objects.filter(id=farm_id):
  2740. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_2, end_2)):
  2741. money = money + int(x.money)
  2742. dat2.append({"farm":i.name,"money":money})
  2743. money = 0
  2744. for i in FarmList.objects.filter(id=farm_id):
  2745. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_3, end_3)):
  2746. money = money + int(x.money)
  2747. dat3.append({"farm":i.name,"money":money})
  2748. money = 0
  2749. for i in FarmList.objects.filter(id=farm_id):
  2750. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_4, end_4)):
  2751. money = money + int(x.money)
  2752. dat4.append({"farm":i.name,"money":money})
  2753. money = 0
  2754. elif farm_id == "":
  2755. print("--------")
  2756. dat1 = []
  2757. dat2 = []
  2758. dat3 = []
  2759. dat4 = []
  2760. data = json.dumps({"1":dat1,"2":dat2,"3":dat3,"4":dat4})
  2761. return HttpResponse(data)
  2762. # 对比分析列表
  2763. class Contrast_List(ListView):
  2764. def get(self,request):
  2765. pass
  2766. def post(self,request):
  2767. area_id = request.POST.get("id")
  2768. page = int(request.POST.get("page"))
  2769. dat = []
  2770. farm_list = FarmList.objects.filter(garden_id=area_id)
  2771. for i in farm_list:
  2772. for x in Sell_Manage.objects.filter(farm=i):
  2773. dat.append({"name":x.farm.name,"num":x.num,"area":x.farm.area,"money":x.money,"upl_time":x.upl_time.strftime('%Y-%m-%d %H:%M:%S')})
  2774. nums = len(dat)
  2775. dat = dat[(10*(page-1)):(page*10)]
  2776. data = json.dumps({"dat":dat,"nums":nums})
  2777. return HttpResponse(data)
  2778. # 产业数据
  2779. class Industry_Data(ListView):
  2780. def get(self,request):
  2781. username = request.user.username
  2782. print('username:',username)
  2783. current_user = MyUser.objects.get(username=username)
  2784. area_list = GardenArea.objects.all()
  2785. return render(request, 'backstageNet/datacenter/industrydata.html', context={"area_list":area_list})
  2786. def post(self,request):
  2787. username = request.user.username
  2788. print('username:',username)
  2789. current_user = MyUser.objects.get(username=username)
  2790. area = request.POST.get("id")
  2791. page = int(request.POST.get("page"))
  2792. dat = []
  2793. money = 0
  2794. start_date = datetime.datetime.now().year
  2795. start_date = datetime.date(start_date,1,1)
  2796. end_date = datetime.datetime.now()
  2797. if area:
  2798. # area_obj = GardenArea.objects.get(id=area)
  2799. for i in FarmList.objects.filter(garden_id=area):
  2800. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_date, end_date)):
  2801. money = money + int(x.money)
  2802. dat.append({"farm":i.name,"money":money,"manage":i.manage_user,"area":i.area})
  2803. money = 0
  2804. else:
  2805. area_obj = GardenArea.objects.get(user=current_user)
  2806. for i in FarmList.objects.filter(garden=area_obj):
  2807. for x in Sell_Manage.objects.filter(farm=i,upl_time__range=(start_date, end_date)):
  2808. money = money + int(x.money)
  2809. dat.append({"farm":i.name,"money":money,"manage":i.manage_user,"area":i.area})
  2810. money = 0
  2811. nums = len(dat)
  2812. dat_split = dat[(10*(page-1)):(page*10)]
  2813. data = json.dumps({"dat":dat,"nums":nums,"dat_split":dat_split})
  2814. return HttpResponse(data)
  2815. # 气象站阈值设置
  2816. class QXZ_Warning_View(ListView):
  2817. def get(self,request):
  2818. user_name = request.user.username
  2819. print('user_name=', user_name)
  2820. current_user = MyUser.objects.get(username=user_name)
  2821. equip_list = Equip.objects.filter(equip_user=current_user,equip_type=5)
  2822. if current_user.is_staff:
  2823. equip_list = Equip.objects.filter(equip_type=5)
  2824. return render(request, 'backstageNet/warn/warnSet.html', context={"equip_list":equip_list})
  2825. def post(self,request):
  2826. equip_id = request.POST.get('equip_id')
  2827. try:
  2828. alarm = QXZ_Alarm.objects.get(equip_id=equip_id).conf
  2829. except:
  2830. alarm = ""
  2831. x = QXZ_Conf.objects.get(equip_id=equip_id)
  2832. conf = {"e1":x.e1,"e2":x.e2,"e3":x.e3,"e4":x.e4,"e5":x.e5,
  2833. "e6":x.e6,"e7":x.e7,"e8":x.e8,"e9":x.e9,"e10":x.e10,
  2834. "e11":x.e11,"e12":x.e12,"e13":x.e13,"e14":x.e14,
  2835. "e15":x.e15,"e16":x.e16,"e17":x.e17,"e18":x.e18,
  2836. "e19":x.e19,"e20":x.e20,"e21":x.e21,"e22":x.e22,
  2837. "e23":x.e23,"e24":x.e24,"e25":x.e25,"e26":x.e26,
  2838. "e27":x.e27,"e28":x.e28,"e29":x.e29,"e30":x.e30}
  2839. data = {"alarm":alarm,"conf":conf}
  2840. data = json.dumps(data)
  2841. return HttpResponse(data)
  2842. # 气象站阈值记录
  2843. class QXZ_Warning_List(ListView):
  2844. def get(self,request):
  2845. return render(request, 'backstageNet/warn/warnRecord.html', context={})
  2846. def post(self,request):
  2847. alarm = request.POST.get('alarm')
  2848. print(alarm)
  2849. print(eval(alarm)["equip_id"])
  2850. e_id = eval(alarm)["equip_id"]
  2851. tel = eval(alarm)["tel"]
  2852. equip_obj = Equip.objects.get(equip_id=e_id)
  2853. if QXZ_Alarm.objects.filter(equip_id=e_id).exists():
  2854. alarm_obj = QXZ_Alarm.objects.get(equip_id=equip_obj)
  2855. alarm_obj.conf = alarm
  2856. alarm_obj.tel = tel
  2857. alarm_obj.save()
  2858. print("修改成功")
  2859. else:
  2860. QXZ_Alarm.objects.create(equip_id=equip_obj,conf=alarm,tel=tel)
  2861. return HttpResponse("0")
  2862. # 生产方式设置
  2863. class Production_Set(ListView):
  2864. def get(self,request):
  2865. user_name = request.user.username
  2866. print('user_name=', user_name)
  2867. current_user = MyUser.objects.get(username=user_name)
  2868. equip_list = Equip.objects.filter(equip_user=current_user,equip_type=5)
  2869. if current_user.is_staff:
  2870. equip_list = Equip.objects.filter(equip_type=5)
  2871. return render(request, 'backstageNet/warn/productionset.html', context={"equip_list":equip_list})
  2872. def post(self,request):
  2873. pass
  2874. # 农场划分
  2875. class Farm_Mark(ListView):
  2876. def get(self,request):
  2877. return render(request, 'backstageNet/basicSet/farmmark.html', context={})
  2878. def post(self,request):
  2879. pass
  2880. # 农场列表
  2881. class Farm_List(ListView):
  2882. def get(self,request):
  2883. return render(request, 'backstageNet/basicSet/farmlist.html', context={})
  2884. def post(self,request):
  2885. pass
  2886. # 交通指引
  2887. class Traffic_Line(ListView):
  2888. def get(self,request):
  2889. return render(request, 'backstageNet/trafficLine/trafficLine.html', context={})
  2890. def post(self,request):
  2891. pass
  2892. # 管理员新闻发布
  2893. class Policy_Pub(ListView):
  2894. def get(self,request):
  2895. return render(request, 'backstageNet/annunciate/policyPub.html', context={})
  2896. def post(self,request):
  2897. username = request.user.username
  2898. print('username:',username)
  2899. current_user = MyUser.objects.get(username=username)
  2900. # news_photo = request.POST.get('upload')
  2901. art_type = request.POST.get('type')
  2902. # writer = request.POST.get('writer')
  2903. # intro = request.POST.get('intro')
  2904. title = request.POST.get('title')
  2905. content = request.POST.get('content')
  2906. policyid = request.POST.get("id")
  2907. #修改
  2908. if policyid:
  2909. try:
  2910. CKArticle.objects.filter(id=policyid).update(art_type=art_type,title=title,content=content,hidden=True)
  2911. data = "1"
  2912. except Exception as e:
  2913. print(e)
  2914. data = "0"
  2915. #创建
  2916. else:
  2917. try:
  2918. CKArticle.objects.create(author=current_user,art_type=art_type,title=title,content=content,hidden=True)
  2919. data = "1"
  2920. except Exception as e:
  2921. print(e)
  2922. data = "0"
  2923. return HttpResponse(data)
  2924. # 管理员新闻列表
  2925. class Policy_List_View(ListView):
  2926. def get(self,request):
  2927. return render(request, 'backstageNet/annunciate/policyListView.html', context={})
  2928. def post(self,request):
  2929. policyid = request.POST.get("id")
  2930. req = request.POST.get("req")
  2931. art_list = CKArticle.objects.filter(id=policyid)
  2932. data = []
  2933. #查看
  2934. if req == "see":
  2935. for i in art_list:
  2936. data.append({
  2937. "art_type":i.art_type,
  2938. "title":i.title,
  2939. "content":i.content,
  2940. "time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S'),
  2941. "author":i.author.username
  2942. })
  2943. elif req == "del":
  2944. art_list.delete()
  2945. data="1"
  2946. data = json.dumps(data,ensure_ascii=False)
  2947. return HttpResponse(data)
  2948. # 管理员新闻列表
  2949. class Policy_List(ListView):
  2950. def get(self,request):
  2951. page = int(request.GET.get("page"))
  2952. art_list = CKArticle.objects.all().exclude(art_type=5)
  2953. nums = art_list.count()
  2954. art = art_list[(10*(page-1)):(page*10)]
  2955. return render(request, 'backstageNet/annunciate/policyList.html', context={"art":art,"nums":nums})
  2956. def post(self,request):
  2957. data = []
  2958. req = request.POST.get("req")
  2959. page = int(request.POST.get("page"))
  2960. print(req)
  2961. if req == "":
  2962. art_list = CKArticle.objects.filter(art_type__lte=2)
  2963. nums = art_list.count()
  2964. else:
  2965. art_list = CKArticle.objects.filter(art_type=req)
  2966. #筛选
  2967. nums = art_list.count()
  2968. art = art_list[(10*(page-1)):(page*10)]
  2969. return render(request, 'backstageNet/annunciate/policyList.html', context={"art":art,"nums":nums})
  2970. # 个人农场主页
  2971. class Person_Farm(ListView):
  2972. def get(self,request):
  2973. uname = request.GET.get('name')
  2974. current_user = MyUser.objects.get(username=uname)
  2975. news = CKArticle.objects.filter(author=current_user)
  2976. garden = GardenArea.objects.get(user=current_user)
  2977. video = Video_data.objects.filter(author=current_user)
  2978. product = Product.objects.filter(author=current_user)
  2979. return render(request, 'outerNet/person_farm.html', context={"news":news,"garden":garden,"video":video,"product":product})
  2980. def post(self,request):
  2981. pass
  2982. # 农场管理界面
  2983. class Person_Farm_Edit(ListView):
  2984. def get(self,request):
  2985. username = request.user.username
  2986. print('username:',username)
  2987. user = MyUser.objects.get(username=username)
  2988. print("当前用户为:", username)
  2989. return render(request, 'backstageNet/production/person_farm_edit.html', context={"current_user":user})
  2990. def post(self,request):
  2991. username = request.user.username
  2992. print('username:',username)
  2993. current_user = MyUser.objects.get(username=username)
  2994. try:
  2995. gar_area = GardenArea.objects.get(user=current_user)
  2996. data = {"id":current_user.id,"name":gar_area.name,"manage":gar_area.manage,"mobile":gar_area.mobile,
  2997. "area":gar_area.area,"location":gar_area.location,"location_2":gar_area.location_2,"addr":gar_area.addr,
  2998. "desc":gar_area.desc,"img":gar_area.img,"guide_img":gar_area.guide_img
  2999. }
  3000. except Exception as e:
  3001. print(e)
  3002. data = {"id":"","name":"","manage":"","mobile":"",
  3003. "area":"","location":"","addr":"",
  3004. "desc":"","img":"","guide_img":""
  3005. }
  3006. data = json.dumps(data)
  3007. return HttpResponse(data)
  3008. # 园区发布
  3009. class Person_Area_Pub(ListView):
  3010. def get(self,request):
  3011. pass
  3012. def post(self,request):
  3013. # current_user = MyUser.objects.get(username='admin')
  3014. username = request.user.username
  3015. print('username:',username)
  3016. user = MyUser.objects.get(username=username)
  3017. print("当前用户为:", username)
  3018. # 农场名称
  3019. name = request.POST.get('name')
  3020. # 负责人
  3021. manage = request.POST.get('manage')
  3022. # 联系电话
  3023. mobile = request.POST.get('mobile')
  3024. # 面积
  3025. area = request.POST.get('area')
  3026. # 农场介绍
  3027. desc = request.POST.get('desc')
  3028. # 图片
  3029. img = request.POST.get('img')
  3030. img_1 = request.POST.get('img_1')
  3031. location = request.POST.get('location')
  3032. location_2 = request.POST.get('location_2')
  3033. addr = request.POST.get('addr')
  3034. guide_img = request.POST.get('guide_img')
  3035. if GardenArea.objects.filter(user=user).exists():
  3036. try:
  3037. gar_obj = GardenArea.objects.get(user=user)
  3038. gar_obj.name = name
  3039. gar_obj.manage = manage
  3040. gar_obj.mobile = mobile
  3041. gar_obj.area = area
  3042. gar_obj.desc = desc
  3043. gar_obj.img = img
  3044. gar_obj.location = location
  3045. gar_obj.location_2 = location_2
  3046. gar_obj.addr = addr
  3047. gar_obj.guide_img = guide_img
  3048. gar_obj.img_1 = img_1
  3049. gar_obj.save()
  3050. data = "1"
  3051. except Exception as e:
  3052. print(e)
  3053. data = "0"
  3054. else:
  3055. try:
  3056. GardenArea.objects.create(user=user,name=name,manage=manage,mobile=mobile,
  3057. area=area,desc=desc,img=img,guide_img=guide_img,img_1=img_1,location_2=location_2,
  3058. location=location,addr=addr)
  3059. data = "1"
  3060. except Exception as e:
  3061. print(e)
  3062. data = "0"
  3063. return HttpResponse(data)
  3064. class Person_View(ListView):
  3065. def get(self,request):
  3066. # 接收当前用户
  3067. # current_user = request.session.get('username')
  3068. username = request.user.username
  3069. print('username:',username)
  3070. current_user = MyUser.objects.get(username=username)
  3071. # print("current_user:", current_user)
  3072. # current_user = MyUser.objects.get(username=current_user)
  3073. page = request.GET.get("page")
  3074. uname = request.GET.get("uname")
  3075. user_list = MyUser.objects.all()
  3076. nums = user_list.count()
  3077. return render(request, 'backstageNet/systemSet/userManage.html', context={"nums": nums,"page":page,"uname":uname})
  3078. def post(self, request):
  3079. pass
  3080. # 地图设置
  3081. class SetMap_View(ListView):
  3082. def get(self,request):
  3083. # 接收当前用户
  3084. # current_user = request.session.get('username')
  3085. username = request.user.username
  3086. print('username:',username)
  3087. current_user = MyUser.objects.get(username=username)
  3088. # print("current_user:", current_user)
  3089. # current_user = MyUser.objects.get(username=current_user)
  3090. page = request.GET.get("page")
  3091. uname = request.GET.get("uname")
  3092. user_list = MyUser.objects.all()
  3093. nums = user_list.count()
  3094. pic_list = Pic_Info.objects.filter(pic_user=current_user)
  3095. return render(request, 'backstageNet/systemSet/mapManage.html', context={"nums": nums,"page":page,"uname":uname,"pic_list":pic_list})
  3096. def post(self, request):
  3097. map_photo = request.FILES.get('upicture')
  3098. if map_photo:
  3099. print("地图图片:", map_photo)
  3100. map_photo_dir = 'map_photo/'
  3101. end_name = map_photo.name.split('.')[-1]
  3102. # 判断如果路径不存在,即创建路径
  3103. if os.path.exists(map_photo_dir) == False:
  3104. os.makedirs(map_photo_dir)
  3105. img = Image.open(map_photo)
  3106. # img = img.convert('RGB')
  3107. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  3108. pic_name = now_time + '.' + end_name
  3109. print("pic_name:", pic_name)
  3110. img.save(map_photo_dir + pic_name)
  3111. news_photo = map_photo_dir + pic_name
  3112. print("new_photo:",news_photo)
  3113. data = {"code": 0,"msg": "","data": {"src": news_photo}}
  3114. else:
  3115. new_photo = "0"
  3116. data = {"code": 404,"msg": "","data": {"src": news_photo}}
  3117. data = json.dumps(data)
  3118. return HttpResponse(data)
  3119. class Person_List(ListView):
  3120. def get(self,request):
  3121. page = int(request.GET.get('page'))
  3122. print("page=", page)
  3123. uname = request.GET.get("uname")
  3124. # 接收当前用户
  3125. # current_user = request.session.get('username')
  3126. username = request.user.username
  3127. print('username:',username)
  3128. current_user = MyUser.objects.get(username=username)
  3129. # print("current_user:", current_user)
  3130. # current_user = MyUser.objects.get(username=current_user)
  3131. # if current_user.is_superuser == True:
  3132. user_list = MyUser.objects.all().order_by(
  3133. "-date_joined")[(10*(page-1)):(page*10)]
  3134. if uname:
  3135. user_list = MyUser.objects.filter(username__contains=uname).order_by(
  3136. "-date_joined")[(10*(page-1)):(page*10)]
  3137. return render(request, 'backstageNet/systemSet/user_list.html', context={'user_list': user_list})
  3138. def post(self,request):
  3139. # current_user = request.session.get('username')
  3140. # print("current_user:", current_user)
  3141. username = request.user.username
  3142. print('username:',username)
  3143. current_user = MyUser.objects.get(username=username)
  3144. print("筛选:")
  3145. f_name = request.POST.get('uname')
  3146. page = int(request.POST.get('page'))
  3147. print("page:", page)
  3148. user_list = MyUser.objects.filter(username__contains=f_name)
  3149. nums = user_list.count()
  3150. user_list = user_list[(10*(page-1)):(page*10)]
  3151. return render(request, 'backstageNet/systemSet/user_list.html', context={'user_list': user_list, "nums": nums})
  3152. class Area_Create(ListView):
  3153. def get(self,request):
  3154. username = request.user.username
  3155. print('username:',username)
  3156. current_user = MyUser.objects.get(username=username)
  3157. currpage = request.GET.get('currpage')
  3158. uname = request.GET.get("uname")
  3159. f_name = request.GET.get("f_name")
  3160. c_id = request.GET.get("id")
  3161. user_obj = MyUser.objects.get(username=uname)
  3162. try:
  3163. curr_area = GardenArea.objects.get(user=user_obj)
  3164. # user_area = {"name":curr_area.name,"location":curr_area.location}
  3165. except Exception as e:
  3166. print(e)
  3167. curr_area = ""
  3168. # user_area = {"name":"","location":""}
  3169. return render(request, 'backstageNet/systemSet/onlineSplit.html', context={"currpage":currpage,"uname":uname,"f_name":f_name,"curr_area":curr_area,"id":c_id})
  3170. def post(self,request):
  3171. uname = request.POST.get("uname")
  3172. name = request.POST.get("name")
  3173. area = request.POST.get("area")
  3174. location = request.POST.get("location")
  3175. location_2 = request.POST.get("location_2")
  3176. user_obj = MyUser.objects.get(username=uname)
  3177. if GardenArea.objects.filter(user=user_obj).exists():
  3178. try:
  3179. area_obj = GardenArea.objects.get(user=user_obj)
  3180. area_obj.name = name
  3181. area_obj.area = area
  3182. area_obj.location = location
  3183. area_obj.location_2 = location_2
  3184. area_obj.upl_time = datetime.datetime.now()
  3185. area_obj.save()
  3186. data = "1"
  3187. except Exception as e:
  3188. print(e)
  3189. data = "0"
  3190. else:
  3191. try:
  3192. GardenArea.objects.create(user=user_obj,name=name,area=area,location=location,location_2=location_2,upl_time=datetime.datetime.now())
  3193. data = "1"
  3194. except Exception as e:
  3195. print(e)
  3196. data = "0"
  3197. return HttpResponse(data)
  3198. class Area_Map(ListView):
  3199. def get(self,request):
  3200. return render(request, 'backstageNet/systemSet/onlineSplitMap.html', context={})
  3201. def post(self,request):
  3202. uname = request.POST.get("uname")
  3203. user_obj = MyUser.objects.get(username=uname)
  3204. all_area = []
  3205. area_list = GardenArea.objects.all().exclude(user=user_obj)
  3206. for i in area_list:
  3207. all_area.append({"name":i.name,"location_2":i.location_2})
  3208. try:
  3209. curr_area = GardenArea.objects.get(user=user_obj)
  3210. user_area = {"name":curr_area.name,"location_2":curr_area.location_2}
  3211. except Exception as e:
  3212. print(e)
  3213. user_area = {"name":"","location_2":""}
  3214. data = json.dumps({"all_area":all_area,"user_area":user_area})
  3215. return HttpResponse(data)
  3216. # 菜单权限
  3217. class Limit(ListView):
  3218. def get(self,request):
  3219. currpage = request.GET.get('currpage')
  3220. uname = request.GET.get("uname")
  3221. f_name = request.GET.get("f_name")
  3222. return render(request, 'backstageNet/limit/limit.html', context={"currpage":currpage,"uname":uname,"f_name":f_name})
  3223. def post(self,request):
  3224. uname = request.POST.get("uname")
  3225. user_obj = MyUser.objects.get(username=uname)
  3226. return HttpResponse(user_obj.limit)
  3227. class Limit_View(ListView):
  3228. def get(self,request):
  3229. # 接收当前用户
  3230. # current_user = request.session.get('username')
  3231. username = request.user.username
  3232. print('username:',username)
  3233. current_user = MyUser.objects.get(username=username)
  3234. # print("current_user:", current_user)
  3235. # current_user = MyUser.objects.get(username=current_user)
  3236. page = request.GET.get("page")
  3237. uname = request.GET.get("uname")
  3238. user_list = MyUser.objects.all()
  3239. nums = user_list.count()
  3240. return render(request, 'backstageNet/limit/limitUserManage.html', context={"nums": nums,"page":page,"uname":uname})
  3241. def post(self, request):
  3242. uname = request.POST.get("uname")
  3243. limit = request.POST.get("limit")
  3244. user_obj = MyUser.objects.get(username=uname)
  3245. try:
  3246. user_obj.limit = limit
  3247. user_obj.save()
  3248. data = "1"
  3249. except Exception as e:
  3250. print("错误信息为",e)
  3251. data = "0"
  3252. return HttpResponse(data)
  3253. class Person_Limit(ListView):
  3254. def get(self,request):
  3255. page = int(request.GET.get('page'))
  3256. print("page=", page)
  3257. uname = request.GET.get("uname")
  3258. # 接收当前用户
  3259. # current_user = request.session.get('username')
  3260. username = request.user.username
  3261. print('username:',username)
  3262. current_user = MyUser.objects.get(username=username)
  3263. # print("current_user:", current_user)
  3264. # current_user = MyUser.objects.get(username=current_user)
  3265. # if current_user.is_superuser == True:
  3266. user_list = MyUser.objects.all().order_by(
  3267. "-date_joined")[(10*(page-1)):(page*10)]
  3268. if uname:
  3269. user_list = MyUser.objects.filter(username__contains=uname).order_by(
  3270. "-date_joined")[(10*(page-1)):(page*10)]
  3271. return render(request, 'backstageNet/limit/limit_user_list.html', context={'user_list': user_list})
  3272. def post(self,request):
  3273. # current_user = request.session.get('username')
  3274. # print("current_user:", current_user)
  3275. username = request.user.username
  3276. print('username:',username)
  3277. current_user = MyUser.objects.get(username=username)
  3278. print("筛选:")
  3279. f_name = request.POST.get('uname')
  3280. page = int(request.POST.get('page'))
  3281. print("page:", page)
  3282. user_list = MyUser.objects.filter(username__contains=f_name)
  3283. nums = user_list.count()
  3284. user_list = user_list[(10*(page-1)):(page*10)]
  3285. return render(request, 'backstageNet/limit/limit_user_list.html', context={'user_list': user_list, "nums": nums})
  3286. # 专家诊断
  3287. class Expert(ListView):
  3288. def get(self,request):
  3289. username = request.user.username
  3290. print('username:',username)
  3291. user = MyUser.objects.get(username=username)
  3292. role = "0"
  3293. if user.is_staff == True:
  3294. role = "1"
  3295. return render(request, 'backstageNet/limit/expert.html', context={"role":role})
  3296. def post(self,request):
  3297. pass
  3298. class learnDepot(ListView):
  3299. def get(self,request):
  3300. return render(request, 'backstageNet/limit/learnDepot.html', context={})
  3301. def post(self,request):
  3302. pass
  3303. # 创建新用户
  3304. class Create_User(ListView):
  3305. def get(self,request):
  3306. currpage = request.GET.get("currpage")
  3307. f_name = request.GET.get("f_name")
  3308. userId = request.GET.get("userId")
  3309. return render(request, 'backstageNet/systemSet/creatUser.html', context={"currpage":currpage,"f_name":f_name,"userId":userId})
  3310. def post(self,request):
  3311. name = request.POST.get("name")
  3312. email = request.POST.get("email")
  3313. phone = request.POST.get("phone")
  3314. role = request.POST.get("role")
  3315. user_remark = request.POST.get("desc")
  3316. uid = request.POST.get("id")
  3317. if uid:
  3318. userobj = MyUser.objects.get(id=uid)
  3319. userobj.user_phone = phone
  3320. userobj.is_staff = role
  3321. userobj.user_remark = user_remark
  3322. userobj.save()
  3323. return HttpResponse("1")
  3324. if MyUser.objects.extra(where=['binary username=%s'], params=[name]).exists():
  3325. # 用户已存在!!!
  3326. data = "3"
  3327. return HttpResponse(data)
  3328. elif MyUser.objects.filter(email = email).exists():
  3329. # 该邮箱已注册!!!
  3330. data = "2"
  3331. return HttpResponse(data)
  3332. else:
  3333. UserModel = get_user_model()
  3334. # 创建用户:
  3335. try:
  3336. user = UserModel.objects.create_user(username=name, email=email,\
  3337. user_phone=phone, password="yf123456",\
  3338. is_active = 1,is_staff = int(role),user_remark = user_remark,limit =
  3339. [{
  3340. "id": 1,
  3341. "title": "首页",
  3342. "icon": "&#xe626;",
  3343. "url": "map",
  3344. "checked": "false",
  3345. "children": []
  3346. },
  3347. {
  3348. "id": 3,
  3349. "title": "信息发布",
  3350. "icon": "&#xe765;",
  3351. "url": "",
  3352. "children": [
  3353. {
  3354. "id": 3.1,
  3355. "title": "新闻资讯",
  3356. "url": "news_pub",
  3357. },
  3358. {
  3359. "id": 3.2,
  3360. "title": "视频资讯",
  3361. "url": "video_pub",
  3362. },
  3363. {
  3364. "id": 3.2,
  3365. "title": "产品展厅",
  3366. "url": "equip_pub",
  3367. },
  3368. {
  3369. "id": 3.3,
  3370. "title": "四季采摘",
  3371. "url": "garden_pub",
  3372. },
  3373. {
  3374. "id": 3.4,
  3375. "title": "民宿导览",
  3376. "url": "dorm_pub",
  3377. },
  3378. ]
  3379. },
  3380. ])
  3381. user.save()
  3382. data = "1"
  3383. except Exception as e:
  3384. print(e)
  3385. data = "0"
  3386. return HttpResponse(data)
  3387. # 管理员修改密码
  3388. class Change_Pwd(ListView):
  3389. def get(self,request):
  3390. pass
  3391. def post(self,request):
  3392. uname = request.POST.get("uname")
  3393. new_pwd = request.POST.get("userpassword")
  3394. print("uname:",uname)
  3395. print("new_pwd:",new_pwd)
  3396. user = MyUser.objects.get(username=uname)
  3397. user.set_password(new_pwd)
  3398. try:
  3399. user.save()
  3400. data = "1"
  3401. except:
  3402. data = "0"
  3403. return HttpResponse(data)
  3404. # 删除用户
  3405. class Delete_User(ListView):
  3406. def get(self,request):
  3407. pass
  3408. def post(self,request):
  3409. uname = request.POST.get("uname")
  3410. try:
  3411. user_obj = MyUser.objects.get(username=uname)
  3412. user_obj.delete()
  3413. data = "1"
  3414. except Exception as e:
  3415. print(e)
  3416. data = "0"
  3417. return HttpResponse(data)
  3418. # 用户修改自己密码
  3419. class User_Change_Pwd(ListView):
  3420. def get(self,request):
  3421. return render(request, 'backstageNet/systemSet/changePwd.html', context={})
  3422. def post(self,request):
  3423. username = request.user.username
  3424. print('username:',username)
  3425. user = MyUser.objects.get(username=username)
  3426. print("当前用户为:", username)
  3427. oldpassword = request.POST.get('oldpassword')
  3428. password = request.POST.get('password')
  3429. print("post的oldpassword:", oldpassword)
  3430. print("post的password:", password)
  3431. if(check_password(oldpassword, user.password)):
  3432. user.set_password(password)
  3433. user.save()
  3434. data = "1"
  3435. else:
  3436. data = "0"
  3437. return HttpResponse(data)
  3438. # 用户信息
  3439. class User_Info(ListView):
  3440. def get(self,request):
  3441. pass
  3442. def post(self,request):
  3443. uid = request.POST.get('id')
  3444. user = MyUser.objects.get(id=uid)
  3445. data = {"name":user.username,"email":user.email,"phone":user.user_phone,"remark":user.user_remark,"role":user.is_staff}
  3446. data = json.dumps(data)
  3447. return HttpResponse(data)
  3448. # 气象站阈值接口
  3449. class QXZ_Auto(ListView):
  3450. def get(self,request):
  3451. pass
  3452. def post(self,request):
  3453. imei = request.POST.get('imei')
  3454. try:
  3455. auto_list = QXZAutoswitch.objects.get(equip_id_id=imei)
  3456. qxz_list = QXZstatus.objects.get(equip_id_id=imei)
  3457. data = {"qxz_list":eval(qxz_list.qxz_status)['data'],"auto_list":auto_list.qxz_auto}
  3458. except:
  3459. data = {"qxz_list":[],"auto_list":[]}
  3460. data = json.dumps(data)
  3461. return HttpResponse(data)
  3462. # 气象站阈值设置接口
  3463. class QXZ_Value_Mqtt(ListView):
  3464. def get(self,request):
  3465. pass
  3466. def post(self,request):
  3467. req = request.POST.get('req')
  3468. jk = request.POST.get('JK')
  3469. ekey = request.POST.get('eKey')
  3470. upper = request.POST.get('upper')
  3471. lower = request.POST.get('lower')
  3472. method = request.POST.get('method')
  3473. imei = request.POST.get('imei')
  3474. # topic = "/yfkj/qxz/sub/"+imei
  3475. # if req == "read":
  3476. # payload = {"ext":{"type":"status"},"cmd":"read"}
  3477. # elif req == "set":
  3478. # way = int(request.POST.get('way'))
  3479. # switch = int(request.POST.get('switch'))
  3480. # payload = {"cmd":"control","ext":{"JK":way,"status":switch}}
  3481. # elif req == "conf":
  3482. # payload = {"ext":{"type":"jkStatus"},"cmd":"read"}
  3483. # cmd = {"topic":topic,"payload":json.dumps(payload),'qos':0}
  3484. # res = requests.post("http://www.yfzhwlw.com:8080/api/v2/mqtt/publish",
  3485. # data=json.dumps(cmd), auth=HTTPBasicAuth("admin", "yfkj_6019"))
  3486. # print("res.status_code:", type(res.status_code))
  3487. # if res.status_code == 200:
  3488. # data = "0"
  3489. # return HttpResponse(data)
  3490. # else:
  3491. # data = "1"
  3492. # return HttpResponse(data)
  3493. return HttpResponse("0")
  3494. # 保存图片信息
  3495. class Pic_locat(ListView):
  3496. def get(self,request):
  3497. pass
  3498. def post(self,request):
  3499. username = request.user.username
  3500. print('username:',username)
  3501. user = MyUser.objects.get(username=username)
  3502. print("当前用户为:", username)
  3503. # 东北点
  3504. locat1 = request.POST.get('locat1')
  3505. # 西南点
  3506. locat2 = request.POST.get('locat2')
  3507. # 图片地址
  3508. addr = request.POST.get('addr')
  3509. locat_info = request.POST.get('locat_info')
  3510. pic_center = request.POST.get('pic_center')
  3511. if Pic_Info.objects.filter(pic_user=user).exists():
  3512. pic_obj = Pic_Info.objects.get(pic_user=user)
  3513. pic_obj.locat1=locat1
  3514. pic_obj.locat2=locat2
  3515. pic_obj.pic_center=pic_center
  3516. pic_obj.addr=addr
  3517. pic_obj.locat_info=locat_info
  3518. pic_obj.save()
  3519. return HttpResponse("1")
  3520. try:
  3521. Pic_Info.objects.create(pic_user=user,locat1=locat1,locat2=locat2,pic_center=pic_center,addr=addr,locat_info=locat_info)
  3522. return HttpResponse("1")
  3523. except Exception as e:
  3524. print("--->>",e)
  3525. return HttpResponse("0")
  3526. class Home_Farm(ListView):
  3527. def get(self,request):
  3528. username = request.user.username
  3529. print('username:',username)
  3530. user = MyUser.objects.get(username=username)
  3531. print("当前用户为:", username)
  3532. farm_list = FarmList.objects.all()
  3533. return render(request, 'backstageNet/home.html', context={"farm_list":farm_list})
  3534. def post(self, request):
  3535. pass
  3536. class Alarm_Record(ListView):
  3537. def get(self,request):
  3538. pass
  3539. def post(self, request):
  3540. alarm_list = QXZ_Alarm_Log.objects.all()
  3541. page = int(request.POST.get("page"))
  3542. dat = []
  3543. for i in alarm_list:
  3544. dat.append({"equip_id":i.equip_id_id,"logs":i.logs,"ekey":i.ekey,"upl_time":i.upl_time.strftime('%Y-%m-%d %H:%M:%S')})
  3545. nums = len(dat)
  3546. dat = dat[(10*(page-1)):(page*10)]
  3547. data = {"dat":dat,"nums":nums}
  3548. data = json.dumps(data)
  3549. return HttpResponse(data)
  3550. class Expert_Img(ListView):
  3551. def get(self,request):
  3552. pass
  3553. def post(self,request):
  3554. # e_id = request.POST.get('id')
  3555. # news_sta = Article.objects.get(id=e_id)
  3556. guide_photo = request.FILES['upload']
  3557. if guide_photo:
  3558. print("新闻图片:", guide_photo)
  3559. news_photo_dir = 'media/uploads/'
  3560. end_name = guide_photo.name.split('.')[-1]
  3561. # 判断如果路径不存在,即创建路径
  3562. if os.path.exists(news_photo_dir) == False:
  3563. os.makedirs(news_photo_dir)
  3564. img = Image.open(guide_photo)
  3565. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  3566. pic_name = now_time + '.' + end_name
  3567. print("pic_name:", pic_name)
  3568. img.save(news_photo_dir + pic_name)
  3569. news_photo = news_photo_dir + pic_name
  3570. print("new_photo:",news_photo)
  3571. data = {"code": 0,"msg": "","data": {"src": news_photo}}
  3572. else:
  3573. new_photo = "0"
  3574. data = {"code": 404,"msg": "","data": {"src": news_photo}}
  3575. data = json.dumps(data)
  3576. return HttpResponse(data)
  3577. class Expert_Info(ListView):
  3578. def get(self,request):
  3579. page = int(request.GET.get("page"))
  3580. expert = Experts.objects.all()
  3581. nums = expert.count()
  3582. username = request.user.username
  3583. print('username:',username)
  3584. user = MyUser.objects.get(username=username)
  3585. role = "0"
  3586. if user.is_staff == True:
  3587. role = "1"
  3588. expert = expert[(9*(page-1)):(page*9)]
  3589. return render(request, 'backstageNet/limit/expertList.html', context={"expert":expert,"nums":nums,"role":role})
  3590. def post(self, request):
  3591. ex_id = request.POST.get('id')
  3592. if ex_id:
  3593. Experts.objects.get(id=ex_id).delete()
  3594. return HttpResponse("1")
  3595. name = request.POST.get('name')
  3596. relation = request.POST.get('relation')
  3597. desc = request.POST.get('desc')
  3598. pic = request.POST.get('pic')
  3599. Experts.objects.create(name=name,relation=relation,desc=desc,pic=pic)
  3600. return HttpResponse("1")
  3601. class Add_Relation(ListView):
  3602. def get(self,request):
  3603. return render(request, 'backstageNet/systemSet/partners.html', context={})
  3604. def post(self, request):
  3605. ex_id = request.POST.get('id')
  3606. if ex_id:
  3607. Relations.objects.get(id=ex_id).delete()
  3608. return HttpResponse("1")
  3609. name = request.POST.get('name')
  3610. relation = request.POST.get('relation')
  3611. desc = request.POST.get('desc')
  3612. pic = request.POST.get('pic')
  3613. Relations.objects.create(name=name,relation=relation,pic=pic)
  3614. return HttpResponse("1")
  3615. class Add_Relation_List(ListView):
  3616. def get(self,request):
  3617. page = int(request.GET.get("page"))
  3618. partner = Relations.objects.all()
  3619. nums = partner.count()
  3620. partner = partner[(10*(page-1)):(page*10)]
  3621. return render(request, 'backstageNet/systemSet/partnersList.html', context={"partner":partner,"nums":nums})
  3622. def post(self, request):
  3623. pass
  3624. class Equip_Addr(ListView):
  3625. def get(self,request):
  3626. pass
  3627. def post(self, request):
  3628. username = request.user.username
  3629. print('username:',username)
  3630. user = MyUser.objects.get(username=username)
  3631. if user.is_staff == True:
  3632. equip_list = Equip.objects.all()
  3633. else:
  3634. equip_list = Equip.objects.filter(equip_user=user)
  3635. data = []
  3636. for i in equip_list:
  3637. data.append({"equip_id":i.equip_id,"lng":i.lng,"lat":i.lat,"equip_type":i.equip_type.type_id})
  3638. data = json.dumps(data)
  3639. return HttpResponse(data)
  3640. class Equip_Location(ListView):
  3641. def get(self,request):
  3642. pass
  3643. def post(self, request):
  3644. eid = request.POST.get("e_id")
  3645. ename = request.POST.get("ename")
  3646. lng = request.POST.get("lng")
  3647. lat = request.POST.get("lat")
  3648. if ename:
  3649. if Equip.objects.filter(equip_name=ename).exists():
  3650. return HttpResponse("0")
  3651. equip_obj = Equip.objects.get(equip_id=eid)
  3652. equip_obj.equip_name = ename
  3653. equip_obj.save()
  3654. if lat:
  3655. equip_obj = Equip.objects.get(equip_id=eid)
  3656. equip_obj.lng = lng
  3657. equip_obj.lat = lat
  3658. equip_obj.save()
  3659. return HttpResponse("1")
  3660. import json
  3661. class Add_Qxz_Test(ListView):
  3662. def get(self,request):
  3663. pass
  3664. def post(self, request):
  3665. payload = request.body
  3666. payload = json.loads(payload.decode())
  3667. print("payload",payload)
  3668. print("type",type(payload))
  3669. if payload.get("cmd") == "terminalData":
  3670. print("<-----uploading data!----->")
  3671. extdata = payload.get("ext")
  3672. print(type(extdata))
  3673. qxzdata = extdata['data']
  3674. print(qxzdata)
  3675. device_id = extdata['StationID']
  3676. print(device_id)
  3677. e1 = ''
  3678. e2 = ''
  3679. e3 = ''
  3680. e4 = ''
  3681. e5 = ''
  3682. e6 = ''
  3683. e7 = ''
  3684. e8 = ''
  3685. e9 = ''
  3686. e10 = ''
  3687. e11 = ''
  3688. e12 = ''
  3689. e13 = ''
  3690. e14 = ''
  3691. e15 = ''
  3692. e16 = ''
  3693. e17 = ''
  3694. e18 = ''
  3695. e19 = ''
  3696. e20 = ''
  3697. e21 = ''
  3698. e22 = ''
  3699. e23 = ''
  3700. e24 = ''
  3701. e25 = ''
  3702. e26 = ''
  3703. e27 = ''
  3704. e28 = ''
  3705. e29 = ''
  3706. e30 = ''
  3707. conf1 = ''
  3708. conf2 = ''
  3709. conf3 = ''
  3710. conf4 = ''
  3711. conf5 = ''
  3712. conf6 = ''
  3713. conf7 = ''
  3714. conf8 = ''
  3715. conf9 = ''
  3716. conf10 = ''
  3717. conf11 = ''
  3718. conf12 = ''
  3719. conf13 = ''
  3720. conf14 = ''
  3721. conf15 = ''
  3722. conf16 = ''
  3723. conf17 = ''
  3724. conf18 = ''
  3725. conf19 = ''
  3726. conf20 = ''
  3727. conf21 = ''
  3728. conf22 = ''
  3729. conf23 = ''
  3730. conf24 = ''
  3731. conf25 = ''
  3732. conf26 = ''
  3733. conf27 = ''
  3734. conf28 = ''
  3735. conf29 = ''
  3736. conf30 = ''
  3737. for i in qxzdata:
  3738. if i['eKey'] == 'e1':
  3739. e1 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3740. conf1 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3741. if e1[0] == "#":
  3742. continue
  3743. elif i['eKey'] == 'e2':
  3744. e2 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3745. conf2 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3746. if e2[0] == "#":
  3747. continue
  3748. elif i['eKey'] == 'e3':
  3749. e3 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3750. conf3 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3751. if e3[0] == "#":
  3752. continue
  3753. elif i['eKey'] == 'e4':
  3754. e4 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3755. conf4 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3756. if e4[0] == "#":
  3757. continue
  3758. elif i['eKey'] == 'e5':
  3759. e5 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3760. conf5 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3761. if e5[0] == "#":
  3762. continue
  3763. elif i['eKey'] == 'e6':
  3764. e6 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3765. conf6 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3766. if e6[0] == "#":
  3767. continue
  3768. elif i['eKey'] == 'e7':
  3769. e7 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3770. conf7 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3771. if e7[0] == "#":
  3772. continue
  3773. elif i['eKey'] == 'e8':
  3774. e8 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3775. conf8 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3776. if e8[0] == "#":
  3777. continue
  3778. elif i['eKey'] == 'e9':
  3779. e9 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3780. conf9 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3781. if e9[0] == "#":
  3782. continue
  3783. elif i['eKey'] == 'e10':
  3784. e10 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3785. conf10 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3786. if e10[0] == "#":
  3787. continue
  3788. elif i['eKey'] == 'e11':
  3789. e11 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3790. conf11 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3791. if e11[0] == "#":
  3792. continue
  3793. elif i['eKey'] == 'e12':
  3794. e12 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3795. conf12 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3796. if e12[0] == "#":
  3797. continue
  3798. elif i['eKey'] == 'e13':
  3799. e13 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3800. conf13 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3801. if e13[0] == "#":
  3802. continue
  3803. elif i['eKey'] == 'e14':
  3804. e14 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3805. conf14 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3806. if e14[0] == "#":
  3807. continue
  3808. elif i['eKey'] == 'e15':
  3809. e15 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3810. conf15 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3811. if e15[0] == "#":
  3812. continue
  3813. elif i['eKey'] == 'e16':
  3814. e16 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3815. conf16 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3816. if e16[0] == "#":
  3817. continue
  3818. elif i['eKey'] == 'e17':
  3819. e17 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3820. conf17 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3821. if e17[0] == "#":
  3822. continue
  3823. elif i['eKey'] == 'e18':
  3824. e18 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3825. conf18 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3826. if e18[0] == "#":
  3827. continue
  3828. elif i['eKey'] == 'e19':
  3829. e19 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3830. conf19 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3831. if e19[0] == "#":
  3832. continue
  3833. elif i['eKey'] == 'e20':
  3834. e20 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3835. conf20 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3836. if e20[0] == "#":
  3837. continue
  3838. elif i['eKey'] == 'e21':
  3839. e21 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3840. conf21 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3841. if e21[0] == "#":
  3842. continue
  3843. elif i['eKey'] == 'e22':
  3844. e22 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3845. conf22 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3846. if e22[0] == "#":
  3847. continue
  3848. elif i['eKey'] == 'e23':
  3849. e23 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3850. conf23 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3851. if e23[0] == "#":
  3852. continue
  3853. elif i['eKey'] == 'e24':
  3854. e24 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3855. conf24 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3856. if e24[0] == "#":
  3857. continue
  3858. elif i['eKey'] == 'e25':
  3859. e25 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3860. conf25 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3861. if e25[0] == "#":
  3862. continue
  3863. elif i['eKey'] == 'e26':
  3864. e26 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3865. conf26 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3866. if e26[0] == "#":
  3867. continue
  3868. elif i['eKey'] == 'e27':
  3869. e27 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3870. conf27 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3871. if e27[0] == "#":
  3872. continue
  3873. elif i['eKey'] == 'e28':
  3874. e28 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3875. conf28 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3876. if e28[0] == "#":
  3877. continue
  3878. elif i['eKey'] == 'e29':
  3879. e29 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3880. conf29 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3881. if e29[0] == "#":
  3882. continue
  3883. elif i['eKey'] == 'e30':
  3884. e30 = str(i['eValue']) + '#' + str(i['eNum']) + '#' + str(i['eKey'])
  3885. conf30 = qxz_dict[i['eNum']][1] + '#' + qxz_dict[i['eNum']][2]
  3886. if e30[0] == "#":
  3887. continue
  3888. qxz_exist = Equip.objects.filter(equip_id=device_id)
  3889. # print("extdata:", extdata)
  3890. # 设备存在,进一步判断状态表是否存在:
  3891. times = datetime.datetime.now()
  3892. if qxz_exist.exists():
  3893. print("<-----this equip is existed!----->")
  3894. try:
  3895. e_id = Equip.objects.get(equip_id=device_id)
  3896. except:
  3897. print("<-----this equip didn't exist!----->")
  3898. try:
  3899. # 设备数据表直接储存数据
  3900. # QXZdata.objects.create(equip_id=e_id, qxz_data=extdata)
  3901. QXZdata_New.objects.create(equip_id=e_id,
  3902. e1=e1,e2=e2,e3=e3,e4=e4,e5=e5,e6=e6,e7=e7,e8=e8,e9=e9,e10=e10,
  3903. e11=e11,e12=e12,e13=e13,e14=e14,e15=e15,e16=e16,e17=e17,e18=e18,e19=e19,e20=e20,
  3904. e21=e21,e22=e22,e23=e23,e24=e24,e25=e25,e26=e26,e27=e27,e28=e28,e29=e29,e30=e30)
  3905. print("<-----data update success!----->")
  3906. except:
  3907. print("<-----data update failed!----->")
  3908. if QXZstatus_New.objects.filter(equip_id=e_id).exists():
  3909. print("<-----this equip's status is existed!----->")
  3910. try:
  3911. sta = QXZstatus_New.objects.get(equip_id=e_id)
  3912. sta.e1 = e1
  3913. sta.e2 = e2
  3914. sta.e3 = e3
  3915. sta.e4 = e4
  3916. sta.e5 = e5
  3917. sta.e6 = e6
  3918. sta.e7 = e7
  3919. sta.e8 = e8
  3920. sta.e9 = e9
  3921. sta.e10 = e10
  3922. sta.e11 = e11
  3923. sta.e12 = e12
  3924. sta.e13 = e13
  3925. sta.e14 = e14
  3926. sta.e15 = e15
  3927. sta.e16 = e16
  3928. sta.e17 = e17
  3929. sta.e18 = e18
  3930. sta.e19 = e19
  3931. sta.e20 = e20
  3932. sta.e21 = e21
  3933. sta.e22 = e22
  3934. sta.e23 = e23
  3935. sta.e24 = e24
  3936. sta.e25 = e25
  3937. sta.e26 = e26
  3938. sta.e27 = e27
  3939. sta.e28 = e28
  3940. sta.e29 = e29
  3941. sta.e30 = e30
  3942. sta.is_online = "1"
  3943. sta.save()
  3944. print("<-----status update success!----->")
  3945. except:
  3946. print("<-----status update failed!----->")
  3947. else:
  3948. # 设备状态表不存在、创建状态表:
  3949. print("<-----this equip's status is not existed!----->")
  3950. try:
  3951. QXZstatus_New.objects.create(equip_id=e_id,
  3952. e1=e1,e2=e2,e3=e3,e4=e4,e5=e5,e6=e6,e7=e7,e8=e8,e9=e9,e10=e10,
  3953. e11=e11,e12=e12,e13=e13,e14=e14,e15=e15,e16=e16,e17=e17,e18=e18,e19=e19,e20=e20,
  3954. e21=e21,e22=e22,e23=e23,e24=e24,e25=e25,e26=e26,e27=e27,e28=e28,e29=e29,e30=e30,is_online="1")
  3955. # QXZstatus.objects.create(equip_id=e_id, qxz_status=extdata)
  3956. print("<-----this equip's status table re-create successed!----->")
  3957. except:
  3958. print("<-----this equip's status table re-create failed!----->")
  3959. # 判断标题配置表
  3960. if QXZ_Conf.objects.filter(equip_id=e_id).exists():
  3961. print("------conf create default-------")
  3962. else:
  3963. QXZ_Conf.objects.create(equip_id=e_id,
  3964. e1=conf1,e2=conf2,e3=conf3,e4=conf4,e5=conf5,e6=conf6,e7=conf7,e8=conf8,e9=conf9,e10=conf10,
  3965. e11=conf11,e12=conf12,e13=conf13,e14=conf14,e15=conf15,e16=conf16,e17=conf17,e18=conf18,e19=conf19,e20=conf20,
  3966. e21=conf21,e22=conf22,e23=conf23,e24=conf24,e25=conf25,e26=conf26,e27=conf27,e28=conf28,e29=conf29,e30=conf30)
  3967. QXZ_Default_Conf.objects.create(equip_id=e_id,
  3968. e1=conf1,e2=conf2,e3=conf3,e4=conf4,e5=conf5,e6=conf6,e7=conf7,e8=conf8,e9=conf9,e10=conf10,
  3969. e11=conf11,e12=conf12,e13=conf13,e14=conf14,e15=conf15,e16=conf16,e17=conf17,e18=conf18,e19=conf19,e20=conf20,
  3970. e21=conf21,e22=conf22,e23=conf23,e24=conf24,e25=conf25,e26=conf26,e27=conf27,e28=conf28,e29=conf29,e30=conf30)
  3971. print("------conf create success-------")
  3972. # 设备状态表存在、刷新状态表:
  3973. print("2222222")
  3974. else:
  3975. print("<-----this equip not existed!----->")
  3976. # 设备不存在,在设备列表中创建:
  3977. try:
  3978. e_type = Equip_type.objects.get(type_id="5")
  3979. e_id = Equip.objects.create(equip_id=device_id, equip_type=e_type)
  3980. print("<-----this imei add successed!----->")
  3981. try:
  3982. # 设备数据表直接储存数据
  3983. QXZdata_New.objects.create(equip_id=e_id,
  3984. e1=e1,e2=e2,e3=e3,e4=e4,e5=e5,e6=e6,e7=e7,e8=e8,e9=e9,e10=e10,
  3985. e11=e11,e12=e12,e13=e13,e14=e14,e15=e15,e16=e16,e17=e17,e18=e18,e19=e19,e20=e20,
  3986. e21=e21,e22=e22,e23=e23,e24=e24,e25=e25,e26=e26,e27=e27,e28=e28,e29=e29,e30=e30)
  3987. # QXZdata.objects.create(equip_id=e_id, qxz_data=extdata)
  3988. print("<-----data update success!----->")
  3989. except:
  3990. print("<-----data update failed!----->")
  3991. try:
  3992. QXZstatus_New.objects.create(equip_id=e_id,
  3993. e1=e1,e2=e2,e3=e3,e4=e4,e5=e5,e6=e6,e7=e7,e8=e8,e9=e9,e10=e10,
  3994. e11=e11,e12=e12,e13=e13,e14=e14,e15=e15,e16=e16,e17=e17,e18=e18,e19=e19,e20=e20,
  3995. e21=e21,e22=e22,e23=e23,e24=e24,e25=e25,e26=e26,e27=e27,e28=e28,e29=e29,e30=e30,is_online="1")
  3996. # QXZstatus.objects.create(equip_id=e_id, qxz_status=extdata)
  3997. print("<-----this imei register successed!----->")
  3998. except:
  3999. print("<-----this imei register failed!----->")
  4000. # 判断标题配置表
  4001. if QXZ_Conf.objects.filter(equip_id=e_id).exists():
  4002. print("------conf create default-------")
  4003. else:
  4004. QXZ_Conf.objects.create(equip_id=e_id,
  4005. e1=conf1,e2=conf2,e3=conf3,e4=conf4,e5=conf5,e6=conf6,e7=conf7,e8=conf8,e9=conf9,e10=conf10,
  4006. e11=conf11,e12=conf12,e13=conf13,e14=conf14,e15=conf15,e16=conf16,e17=conf17,e18=conf18,e19=conf19,e20=conf20,
  4007. e21=conf21,e22=conf22,e23=conf23,e24=conf24,e25=conf25,e26=conf26,e27=conf27,e28=conf28,e29=conf29,e30=conf30)
  4008. QXZ_Default_Conf.objects.create(equip_id=e_id,
  4009. e1=conf1,e2=conf2,e3=conf3,e4=conf4,e5=conf5,e6=conf6,e7=conf7,e8=conf8,e9=conf9,e10=conf10,
  4010. e11=conf11,e12=conf12,e13=conf13,e14=conf14,e15=conf15,e16=conf16,e17=conf17,e18=conf18,e19=conf19,e20=conf20,
  4011. e21=conf21,e22=conf22,e23=conf23,e24=conf24,e25=conf25,e26=conf26,e27=conf27,e28=conf28,e29=conf29,e30=conf30)
  4012. print("------conf create success-------")
  4013. except Exception as e:
  4014. print(e)
  4015. print("<-----this imei add failed!----->")
  4016. if payload.get("cmd") == "Status":
  4017. extdata = payload.get("ext")['terminalStatus']
  4018. print(extdata)
  4019. try:
  4020. volt = extdata["VOLT"]
  4021. rssi = extdata["RSSI"]
  4022. iccid = extdata["ICCID"]
  4023. lng = extdata["longitude"]
  4024. lat = extdata["latitude"]
  4025. led = extdata["Dotled"]
  4026. except:
  4027. pass
  4028. try:
  4029. dver = extdata["Version"]
  4030. except:
  4031. dver = ""
  4032. if qxz_exist.exists():
  4033. print("<-----this equip is existed!----->")
  4034. try:
  4035. e_id = Equip.objects.get(equip_id=device_id)
  4036. except:
  4037. print("<-----this equip didn't exist!----->")
  4038. QXZ_Info_Record.objects.create(equip_id=e_id, volt=volt,rssi=rssi)
  4039. if QXZ_Base_Info.objects.filter(equip_id=e_id).exists():
  4040. print("<-----this qxz_base_info is existed!----->")
  4041. try:
  4042. sta = QXZ_Base_Info.objects.get(equip_id=device_id)
  4043. sta.volt = volt
  4044. sta.rssi = rssi
  4045. sta.iccid = iccid
  4046. sta.lng = lng
  4047. sta.lat = lat
  4048. sta.led = led
  4049. sta.dver = dver
  4050. sta.save()
  4051. sta1 = Equip.objects.get(equip_id=device_id)
  4052. sta1.lng = lng
  4053. sta1.lat = lat
  4054. sta1.save()
  4055. print("<-----qxz_base_info update success!----->")
  4056. except:
  4057. print("<-----qxz_base_info update failed!----->")
  4058. try:
  4059. sta = QXZ_Base_Info.objects.get(equip_id=device_id)
  4060. sta.volt = volt
  4061. sta.rssi = rssi
  4062. sta.save()
  4063. print("<-----qxz_base_info update success!!!----->")
  4064. except:
  4065. pass
  4066. else:
  4067. # 设备阈值表不存在、创建阈值表:
  4068. print("<-----this qxz_base_info is not existed!----->")
  4069. try:
  4070. QXZ_Base_Info.objects.create(equip_id=device_id, volt=volt,rssi=rssi,iccid=iccid,lng=lng,lat=lat,led=led)
  4071. print("<-----this qxz_base_info table re-create successed!----->")
  4072. except:
  4073. print("<-----this qxz_base_info table re-create failed!----->")
  4074. return HttpResponse("1")
  4075. # 气象站数据导出接口
  4076. class QXZ_Data_Export(ListView):
  4077. def get(self,request):
  4078. equip_id = request.GET.get('id')
  4079. print("请求数据的设备id:",equip_id)
  4080. f_tbegin = request.GET.get('begin')
  4081. f_tend = request.GET.get('end')
  4082. filename = request.GET.get('filename')
  4083. print("f_tbegin:", f_tbegin)
  4084. print("f_tend:", f_tend)
  4085. print("f_tbegin:", type(f_tbegin))
  4086. print("f_tend:", type(f_tend))
  4087. # 查询时间段
  4088. if f_tbegin:
  4089. begindate = re.findall(r"\d+\.?\d*", f_tbegin)
  4090. enddate = re.findall(r"\d+\.?\d*", f_tend)
  4091. start_date = datetime.date(int(begindate[0]), int(begindate[1]), int(begindate[2]))
  4092. end_date = datetime.date(int(enddate[0]), int(enddate[1]), int(enddate[2]))
  4093. print("start_date:", start_date)
  4094. print("end_date:", end_date)
  4095. sta1 = QXZdata.objects.filter(equip_id=equip_id, upl_time__range=(start_date, end_date))
  4096. print("sta1:", sta1)
  4097. sta2 = [{"equip_name": x.equip_id.equip_name,
  4098. "qxz_data": eval(x.qxz_data)["data"],
  4099. "upl_time": x.upl_time.strftime("%Y-%m-%d %H:%M:%S")} for x in sta1]
  4100. # 查询全部
  4101. else:
  4102. sta1 = QXZdata.objects.filter(equip_id=equip_id)
  4103. print("sta1:",sta1)
  4104. sta2 = [{"equip_name": x.equip_id.equip_name,
  4105. "qxz_data": eval(x.qxz_data)["data"],
  4106. "upl_time": x.upl_time.strftime("%Y-%m-%d %H:%M:%S")} for x in sta1]
  4107. # print(sta2)
  4108. try:
  4109. # 遍历标题
  4110. title = []
  4111. for aaa in sta2[0]['qxz_data']:
  4112. # print(qxz_dict[aaa['eNum']][1])
  4113. title.append(qxz_dict[aaa['eNum']][1]+aaa['eKey'])
  4114. title.append("上报时间")
  4115. print(title)
  4116. # print(sta2[0]['qxz_data'])
  4117. except:
  4118. book = xlwt.Workbook() # 创建一个excel对象
  4119. sheet = book.add_sheet('Sheet1',cell_overwrite_ok=True) # 添加一个sheet页
  4120. sheet.write(0,0,"错误的时间段") # 将title数组中的字段写入到0行i列中
  4121. # 写出到IO
  4122. output = BytesIO()
  4123. book.save(output)
  4124. # 重新定位到开始
  4125. output.seek(0)
  4126. response = HttpResponse(content_type='application/vnd.ms-excel')
  4127. response['Content-Disposition'] = 'attachment;filename=%s.xls'%filename
  4128. response.write(output.getvalue())
  4129. return response
  4130. book = xlwt.Workbook() # 创建一个excel对象
  4131. sheet = book.add_sheet('Sheet1',cell_overwrite_ok=True) # 添加一个sheet页
  4132. for i in range(len(title)): # 遍历列
  4133. sheet.write(0,i,title[i]) # 将title数组中的字段写入到0行i列中
  4134. for x in range(len(sta2)): # 遍历列表
  4135. # print("行",x)
  4136. for xx in range(len(title)):
  4137. print("行",x+1,"列",xx)
  4138. # print(sta2[x]["qxz_data"][xx-1])
  4139. if xx+1 == len(title):
  4140. # print(x+1,xx,sta2[x]["upl_time"])
  4141. sheet.write(x+1,xx,sta2[x]["upl_time"])
  4142. break
  4143. # print(x+1,xx,sta2[x]["qxz_data"][xx]["eValue"]+" "+qxz_dict[sta2[x]["qxz_data"][xx]["eNum"]][2])
  4144. sheet.write(x+1,xx,sta2[x]["qxz_data"][xx]["eValue"]+" "+qxz_dict[sta2[x]["qxz_data"][xx]["eNum"]][2])
  4145. # 写出到IO
  4146. output = BytesIO()
  4147. book.save(output)
  4148. # 重新定位到开始
  4149. output.seek(0)
  4150. response = HttpResponse(content_type='application/vnd.ms-excel')
  4151. response['Content-Disposition'] = 'attachment;filename=%s.xls'%filename
  4152. response.write(output.getvalue())
  4153. return response
  4154. def post(self,request):
  4155. pass
  4156. # 系统管理上传图片
  4157. class System_Photo(ListView):
  4158. def get(self,request):
  4159. return render(request, 'backstageNet/systemSet/imageUpload.html', context={})
  4160. def post(self,request):
  4161. basestr = request.FILES.get("upload")
  4162. base_dir = 'media/uploads/'
  4163. now_time = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
  4164. if basestr:
  4165. img = Image.open(basestr)
  4166. img.save(base_dir + now_time +".png")
  4167. SystemPhoto.objects.create(name=base_dir +now_time +".png",pic_1=base_dir +now_time +".png")
  4168. return HttpResponse("1")
  4169. # 系统管理上传图片
  4170. class System_Photo_Save(ListView):
  4171. def get(self,request):
  4172. pass
  4173. def post(self,request):
  4174. pic_1 = request.POST.get('pic_1')
  4175. pic_2 = request.POST.get('pic_2')
  4176. if pic_1:
  4177. name = pic_1
  4178. elif pic_2:
  4179. name = pic_2
  4180. SystemPhoto.objects.create(name=name,pic_1=pic_1,pic_2=pic_2)
  4181. return HttpResponse("1")