views.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. # -*- coding: utf-8 -*-
  2. from django.shortcuts import render, redirect
  3. # from apps.SystemManage.forms import AddUserForm
  4. from django.http import HttpResponse
  5. from django.template import RequestContext
  6. from django.contrib import auth
  7. from django.contrib.auth import authenticate, login as auth_login, logout
  8. from django.contrib.auth import get_user_model
  9. from django.contrib.auth.models import User, Group, Permission
  10. from django.contrib.auth.hashers import make_password, check_password
  11. from django.contrib.auth.decorators import login_required
  12. from django.views.decorators.csrf import csrf_exempt
  13. from django.views.generic import ListView
  14. from django.views.generic.base import View
  15. import datetime
  16. from PIL import Image
  17. import time
  18. import json
  19. import base64
  20. import redis
  21. from django.core.cache import cache
  22. import os
  23. # from configure import verification_code
  24. from apps.AppInfo.models import Equip, Equip_type, MyUser, QXZdata, QXZstatus, QXZdata_New, JKdata, Article, QXZstatus_New, QXZswitchdata, QXZswitchstatus, CKArticle, GardenManage, Video_data,\
  25. Product, Pick_Pub, FarmList, Hotel_Info, GardenArea, Sightsee_Info,Hotel_Info
  26. from django.utils.decorators import method_decorator
  27. # Create your views here.
  28. class Home_Test(View):
  29. def get(self, request):
  30. pass
  31. def post(self, request):
  32. pass
  33. # 用户登录
  34. @method_decorator(csrf_exempt, name='dispatch')
  35. class Login_View(View):
  36. def get(self, request):
  37. HTTP_HOST = request.META['HTTP_HOST']
  38. print('HTTP_HOST:', HTTP_HOST)
  39. # form = AddUserForm()
  40. # return render(request, 'home/login.html', context={'form': form})
  41. if request.user.is_authenticated():
  42. user_name = request.user.username
  43. print('user_name=', user_name)
  44. current_user = MyUser.objects.get(username=user_name)
  45. if current_user.is_superuser:
  46. role = "superuser"
  47. elif current_user.is_staff:
  48. role = "staff"
  49. else:
  50. role = "user"
  51. print("当前用户类型:是否为超级管理员", current_user.is_superuser)
  52. return render(request, 'home/home.html', context={'user_name': user_name, 'role': role})
  53. else:
  54. if HTTP_HOST == "127.0.0.1" or HTTP_HOST == "120.27.222.26":
  55. return render(request, 'home/login.html', context={})
  56. def post(self, request):
  57. user_name = request.POST.get('username')
  58. pass_word = request.POST.get('password')
  59. print('输入的用户名:', user_name)
  60. user = MyUser.objects.extra(
  61. where=['binary username=%s'], params=[user_name])
  62. print("user.exists():", user.exists())
  63. if user.exists() == False:
  64. data = "0"
  65. return HttpResponse(data)
  66. else:
  67. user = MyUser.objects.get(username=user_name)
  68. if user.is_active != True:
  69. data = "2"
  70. return HttpResponse(data)
  71. else:
  72. if check_password(pass_word, user.password) != True:
  73. data = "3"
  74. return HttpResponse(data)
  75. else:
  76. print('登陆成功')
  77. current_user = MyUser.objects.get(username=user_name)
  78. auth_user = authenticate(
  79. username=user_name, password=pass_word)
  80. auth_login(request, auth_user)
  81. # 将当前登录的用户名写入session
  82. request.session['username'] = user_name
  83. if user.is_superuser:
  84. role = "superuser"
  85. elif user.is_staff:
  86. role = "staff"
  87. else:
  88. role = "user"
  89. data = "1"
  90. returnUrl = request.POST.get('returnUrl')
  91. print("returnUrl:", returnUrl)
  92. if returnUrl == None:
  93. print("returnUrl is none!!!!!!!!")
  94. return HttpResponse(data)
  95. else:
  96. if returnUrl == "":
  97. print("returnUrl is empty")
  98. return render(request, 'outerNet/index2.html')
  99. elif returnUrl != "":
  100. print("returnUrl is not empty")
  101. return render(request, 'outerNet/index.html')
  102. # 用户登录2
  103. class Login2_View(View):
  104. def get(self, request):
  105. return render(request, 'outerNet/login2.html', context={})
  106. def post(self, request):
  107. pass
  108. # 注册
  109. class ForgetPaw_View(View):
  110. def get(self, request):
  111. return render(request, 'outerNet/forgetPaw.html', context={})
  112. def post(self, request):
  113. pass
  114. # 注册
  115. class register_View(View):
  116. def get(self, request):
  117. return render(request, 'outerNet/register.html', context={})
  118. def post(self, request):
  119. pass
  120. # 外网首页
  121. class Home(View):
  122. def get(self, request):
  123. user_news = CKArticle.objects.filter(art_type=5)[0:10]
  124. zero_news = CKArticle.objects.filter(art_type=0)[0:10]
  125. one_news = CKArticle.objects.filter(art_type=1)[0:10]
  126. two_news = CKArticle.objects.filter(art_type=2)[0:10]
  127. video_news = Video_data.objects.all()[0:4]
  128. product = Product.objects.all()[0:8]
  129. pick = Pick_Pub.objects.all()[0:6]
  130. farm = FarmList.objects.all()
  131. garden = GardenArea.objects.all()[0:6]
  132. hotel = Hotel_Info.objects.all()[0:6]
  133. article = CKArticle.objects.all()[0:12]
  134. sightsee = Sightsee_Info.objects.all()[0:6]
  135. hotel2 = Hotel_Info.objects.all().order_by('-upl_time')[0:6]
  136. if request.user.is_authenticated():
  137. user_name = request.user.username
  138. curr_user = MyUser.objects.get(username=user_name)
  139. print('user_name=', user_name)
  140. print('user=', curr_user.username)
  141. else:
  142. curr_user = ""
  143. return render(request, 'outerNet/index2.html', context={"user_news": user_news,"zero_news": zero_news, "one_news": one_news,"article":article,
  144. "two_news": two_news, "video_news": video_news,"hotel":hotel,"garden":garden,"hotel2":hotel2,
  145. "product": product, "pick": pick, "farm": farm, "curr_user": curr_user,"sightsee":sightsee})
  146. def post(self, request):
  147. pass
  148. # # 外网首页2-------------暂时不用
  149. # class Home2(View):
  150. # def get(self, request):
  151. # user_news = CKArticle.objects.filter(art_type=5)[0:10]
  152. # zero_news = CKArticle.objects.filter(art_type=0)[0:10]
  153. # one_news = CKArticle.objects.filter(art_type=1)[0:10]
  154. # two_news = CKArticle.objects.filter(art_type=2)[0:10]
  155. # video_news = Video_data.objects.all()[0:4]
  156. # product = Product.objects.all()[0:8]
  157. # pick = Pick_Pub.objects.all()[0:6]
  158. # garden = GardenArea.objects.all()
  159. # farm = FarmList.objects.all()
  160. # hotel = Hotel_Info.objects.all()[0:5]
  161. # article = CKArticle.objects.all()[0:12]
  162. # if request.user.is_authenticated():
  163. # user_name = request.user.username
  164. # curr_user = MyUser.objects.get(username=user_name)
  165. # print('user_name=', user_name)
  166. # print('user=', curr_user.username)
  167. # else:
  168. # curr_user = ""
  169. # return render(request, 'outerNet/index2.html', context={"user_news": user_news,"zero_news": zero_news, "one_news": one_news,"farm":farm,
  170. # "two_news": two_news, "video_news": video_news,"hotel":hotel,"article":article,
  171. # "product": product, "pick": pick, "garden": garden, "curr_user": curr_user})
  172. # def post(self, request):
  173. # pass
  174. # 首页设备显示
  175. class Home_Equip(View):
  176. def get(self, request):
  177. pass
  178. def post(self, request):
  179. pass
  180. #修改个人信息,
  181. class Modify_Head(ListView):
  182. def get(self, request):
  183. art_list = MyUser.objects.get(username="admin")
  184. print(art_list.username)
  185. return render(request, "backstageNet/systemSet/systemSet.html", context={"art_list": art_list})
  186. def post(self, request):
  187. head = request.POST.get("user_picture")
  188. remark = request.POST.get("user_remark")
  189. phone = request.POST.get("user_phone")
  190. name = request.POST.get("username")
  191. try:
  192. art_list = MyUser.objects.filter(username=name).update(
  193. user_picture=head,
  194. user_remark=remark,
  195. user_phone=phone
  196. )
  197. data = "1"
  198. except Exception as e:
  199. print(e)
  200. data = "0"
  201. return HttpResponse(data)
  202. # 头像上传
  203. class User_Img(ListView):
  204. def get(self, request):
  205. pass
  206. def post(self, request):
  207. user_photo = request.FILES.get('user_photo')
  208. if user_photo:
  209. print("头像图片:", user_photo)
  210. user_photo_dir = 'user_photo/'
  211. end_name = user_photo.name.split('.')[-1]
  212. # 判断如果路径不存在,即创建路径
  213. if os.path.exists(user_photo_dir) == False:
  214. os.makedirs(user_photo_dir)
  215. img = Image.open(user_photo)
  216. now_time = time.strftime(
  217. '%Y%m%d%H%M%S', time.localtime(time.time()))
  218. pic_name = now_time + '.' + end_name
  219. print("pic_name:", pic_name)
  220. img.save(user_photo_dir + pic_name)
  221. user_photo = user_photo_dir + pic_name
  222. print("user_photo:", user_photo)
  223. data = {"code": 0, "msg": "", "data": {"src": user_photo}}
  224. else:
  225. user_photo = "0"
  226. data = {"code": 404, "msg": "", "data": {"src": user_photo}}
  227. data = json.dumps(data)
  228. return HttpResponse(data)
  229. #新建用户
  230. class User_News(ListView):
  231. def get(self,request):
  232. pass
  233. def post(self,request):
  234. username = request.POST.get("username")
  235. user_remark = request.POST.get("user_remark")
  236. user_phone = request.POST.get("user_phone")
  237. email = request.POST.get("email")
  238. #用户登陆
  239. class User_Land(ListView):
  240. def get(self,request):
  241. pass
  242. def post(self, request):
  243. user_name = request.POST.get("username")
  244. pass_word = request.POST.get("password")
  245. print('输入的用户名', user_name)
  246. print('输入的密码:', pass_word)
  247. user = MyUser.objects.extra(
  248. where=['binary username=%s'], params=[user_name])
  249. print("user.exists():", user.exists())
  250. if user.exists() == False:
  251. data = 0
  252. print("用户不存在")
  253. data = json.dumps(data)
  254. return HttpResponse(data)
  255. else:
  256. user = MyUser.objects.get(username=user_name)
  257. if user.is_active != True:
  258. data = 2
  259. print("用户名错误")
  260. data = json.dumps(data)
  261. return HttpResponse(data)
  262. else:
  263. if check_password(pass_word, user.password) != True:
  264. data = 3
  265. print('密码错误')
  266. data = json.dumps(data)
  267. return HttpResponse(data)
  268. else:
  269. print('登陆成功')
  270. auth_user = authenticate(
  271. username=user_name, password=pass_word)
  272. auth_login(request, auth_user)
  273. # 将当前登录的用户名写入session
  274. request.session['username'] = user_name
  275. art_list = MyUser.objects.filter(username=user_name)
  276. for i in art_list:
  277. he = {"username":i.username,"user_img":i.user_picture.name,"code":1 }
  278. data = json.dumps(he)
  279. print("data:", data)
  280. return HttpResponse(data)
  281. # 用户退出
  282. @login_required
  283. def logout(request):
  284. print("用户退出")
  285. del request.session['username']# 删除session
  286. auth.logout(request)
  287. return redirect('/login2')
  288. #判断用户是否已登陆
  289. class User_Check(ListView):
  290. # def get(self,request):
  291. # pass
  292. def get(self, request):
  293. ret_url = request.path_info
  294. print(ret_url)
  295. if ret_url == "/home":
  296. return HttpResponse(ret_url)
  297. else:
  298. print(000)
  299. return HttpResponse("00000")
  300. #发送验证码
  301. #1验证码不正确,2两次密码不一致4用户不存在请注册3手机号不正确 0重置密码成功
  302. class Prove_Code(ListView):
  303. def post(self, request):
  304. phone = json.loads(request.body.decode())
  305. # num = verification_code()
  306. num = 123456
  307. mobile = phone["mobile"]
  308. pass_word1 = phone["password"]
  309. pass_word2 = phone["password2"]
  310. code = phone["code"]
  311. ret = phone["ret"]
  312. imei = phone["imei"]
  313. try:
  314. #提取imei
  315. imei = json.loads(imei)
  316. imeid = imei["uuid"]
  317. if imeid.find(",") != -1:
  318. imeid = imeid.split(",")[0]
  319. else:
  320. pass
  321. print("imeid",imeid)
  322. except Exception as e:
  323. print(e)
  324. data = 0
  325. return HttpResponse(data)
  326. mobile_pat = re.compile('^(13\d|14[5|7]|15\d|166|17\d|18\d)\d{8}$')
  327. res = re.search(mobile_pat, mobile)
  328. if ret == "see":
  329. if res:
  330. #手机号正确的情况下,校验该手机是否已经注册
  331. if MyUser.objects.filter(imei=imeid).exists():
  332. data = 6
  333. else:
  334. #校验手机号是否已经注册
  335. if MyUser.objects.filter(username=mobile).exists():
  336. data = 1
  337. else:
  338. #发送短信验证码
  339. template_id = 496156 # NOTE: 这里的模板 ID`7839`只是示例,真实的模板 ID 需要在短信控制台中申请
  340. # # 签名
  341. ssender = SmsSingleSender(appid, appkey)
  342. params = [num, "1"]
  343. #发送短信验证码
  344. result = ssender.send_with_param(86, mobile,
  345. template_id, params, sign=sms_sign, extend="", ext="")
  346. if result["result"] == 0:
  347. data = 0
  348. request.session["code"] = num
  349. else:
  350. data = 2
  351. else:
  352. data = 3
  353. elif ret == "land": #注册
  354. try:
  355. #登陆校验 获取存到session 中的验证码,与用户输入的验证码比较,
  356. #如果在60内没有输入正确的验证码会直接删除,而这个时候就获取不到code 了
  357. num = request.session.get('code')
  358. except Exception as e:
  359. print(e)
  360. data = 2
  361. return HttpResponse(data)
  362. if MyUser.objects.filter(imei=imeid).exists():
  363. data = 6
  364. else:
  365. if MyUser.objects.filter(username=mobile).exists():
  366. data = 1
  367. else:
  368. if code == num:
  369. #在验证码输入正确的情况下,校验输入的两次密码是否一致
  370. if pass_word1 == pass_word2:
  371. code = mobile[:5]
  372. user_remark = "勤劳的园丁"+ code
  373. MyUser.objects.create_user(
  374. username=mobile, password=pass_word1, imei=imeid,user_remark=user_remark)
  375. data = 5
  376. # 验证码存在session中,在用户注册成功后要删除设置的验证码,
  377. del request.session['code']
  378. else:
  379. data = 4
  380. else:
  381. data = 2
  382. return HttpResponse(data)