views.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  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 apps.AppInfo.models import Equip, Equip_type, MyUser, QXZdata, QXZstatus, QXZdata_New, JKdata, Article, QXZstatus_New, QXZswitchdata, QXZswitchstatus, CKArticle, GardenManage, Video_data,\
  24. Product, Pick_Pub, FarmList, Hotel_Info
  25. from django.utils.decorators import method_decorator
  26. # Create your views here.
  27. class Home_Test(View):
  28. def get(self, request):
  29. pass
  30. def post(self, request):
  31. pass
  32. # 用户登录
  33. @method_decorator(csrf_exempt, name='dispatch')
  34. class Login_View(View):
  35. def get(self, request):
  36. HTTP_HOST = request.META['HTTP_HOST']
  37. print('HTTP_HOST:', HTTP_HOST)
  38. # form = AddUserForm()
  39. # return render(request, 'home/login.html', context={'form': form})
  40. if request.user.is_authenticated():
  41. user_name = request.user.username
  42. print('user_name=', user_name)
  43. current_user = MyUser.objects.get(username=user_name)
  44. if current_user.is_superuser:
  45. role = "superuser"
  46. elif current_user.is_staff:
  47. role = "staff"
  48. else:
  49. role = "user"
  50. print("当前用户类型:是否为超级管理员", current_user.is_superuser)
  51. return render(request, 'home/home.html', context={'user_name': user_name, 'role': role})
  52. else:
  53. if HTTP_HOST == "127.0.0.1" or HTTP_HOST == "120.27.222.26":
  54. return render(request, 'home/login.html', context={})
  55. def post(self, request):
  56. user_name = request.POST.get('username')
  57. pass_word = request.POST.get('password')
  58. print('输入的用户名:', user_name)
  59. user = MyUser.objects.extra(
  60. where=['binary username=%s'], params=[user_name])
  61. print("user.exists():", user.exists())
  62. if user.exists() == False:
  63. data = "0"
  64. return HttpResponse(data)
  65. else:
  66. user = MyUser.objects.get(username=user_name)
  67. if user.is_active != True:
  68. data = "2"
  69. return HttpResponse(data)
  70. else:
  71. if check_password(pass_word, user.password) != True:
  72. data = "3"
  73. return HttpResponse(data)
  74. else:
  75. print('登陆成功')
  76. current_user = MyUser.objects.get(username=user_name)
  77. auth_user = authenticate(
  78. username=user_name, password=pass_word)
  79. auth_login(request, auth_user)
  80. # 将当前登录的用户名写入session
  81. request.session['username'] = user_name
  82. if user.is_superuser:
  83. role = "superuser"
  84. elif user.is_staff:
  85. role = "staff"
  86. else:
  87. role = "user"
  88. data = "1"
  89. returnUrl = request.POST.get('returnUrl')
  90. print("returnUrl:", returnUrl)
  91. if returnUrl == None:
  92. print("returnUrl is none!!!!!!!!")
  93. return HttpResponse(data)
  94. else:
  95. if returnUrl == "":
  96. print("returnUrl is empty")
  97. return render(request, 'outerNet/index.html')
  98. elif returnUrl != "":
  99. print("returnUrl is not empty")
  100. return render(request, 'outerNet/index.html')
  101. # 用户登录2
  102. class Login2_View(View):
  103. def get(self, request):
  104. return render(request, 'outerNet/login2.html', context={})
  105. def post(self, request):
  106. pass
  107. # 外网首页
  108. class Home(View):
  109. def get(self, request):
  110. user_news = CKArticle.objects.filter(art_type=5)[0:10]
  111. zero_news = CKArticle.objects.filter(art_type=0)[0:10]
  112. one_news = CKArticle.objects.filter(art_type=1)[0:10]
  113. two_news = CKArticle.objects.filter(art_type=2)[0:10]
  114. video_news = Video_data.objects.all()[0:4]
  115. product = Product.objects.all()[0:8]
  116. pick = Pick_Pub.objects.all()[0:6]
  117. farm = FarmList.objects.all()[0:6]
  118. hotel = Hotel_Info.objects.all()[0:5]
  119. if request.user.is_authenticated():
  120. user_name = request.user.username
  121. curr_user = MyUser.objects.get(username=user_name)
  122. print('user_name=', user_name)
  123. print('user=', curr_user.username)
  124. else:
  125. curr_user = ""
  126. return render(request, 'outerNet/index.html', context={"user_news": user_news,"zero_news": zero_news, "one_news": one_news,
  127. "two_news": two_news, "video_news": video_news,"hotel":hotel,
  128. "product": product, "pick": pick, "farm": farm, "curr_user": curr_user})
  129. def post(self, request):
  130. pass
  131. # 外网首页2
  132. class Home2(View):
  133. def get(self, request):
  134. user_news = CKArticle.objects.filter(art_type=5)[0:10]
  135. zero_news = CKArticle.objects.filter(art_type=0)[0:10]
  136. one_news = CKArticle.objects.filter(art_type=1)[0:10]
  137. two_news = CKArticle.objects.filter(art_type=2)[0:10]
  138. video_news = Video_data.objects.all()[0:4]
  139. product = Product.objects.all()[0:8]
  140. pick = Pick_Pub.objects.all()[0:6]
  141. farm = FarmList.objects.all()[0:6]
  142. hotel = Hotel_Info.objects.all()[0:5]
  143. if request.user.is_authenticated():
  144. user_name = request.user.username
  145. curr_user = MyUser.objects.get(username=user_name)
  146. print('user_name=', user_name)
  147. print('user=', curr_user.username)
  148. else:
  149. curr_user = ""
  150. return render(request, 'outerNet/index2.html', context={"user_news": user_news,"zero_news": zero_news, "one_news": one_news,
  151. "two_news": two_news, "video_news": video_news,"hotel":hotel,
  152. "product": product, "pick": pick, "farm": farm, "curr_user": curr_user})
  153. def post(self, request):
  154. pass
  155. # 首页设备显示
  156. class Home_Equip(View):
  157. def get(self, request):
  158. pass
  159. def post(self, request):
  160. pass
  161. #修改个人信息,
  162. class Modify_Head(ListView):
  163. def get(self, request):
  164. art_list = MyUser.objects.get(username="admin")
  165. print(art_list.username)
  166. return render(request, "backstageNet/systemSet/systemSet.html", context={"art_list": art_list})
  167. def post(self, request):
  168. head = request.POST.get("user_picture")
  169. remark = request.POST.get("user_remark")
  170. phone = request.POST.get("user_phone")
  171. name = request.POST.get("username")
  172. try:
  173. art_list = MyUser.objects.filter(username=name).update(
  174. user_picture=head,
  175. user_remark=remark,
  176. user_phone=phone
  177. )
  178. data = "1"
  179. except Exception as e:
  180. print(e)
  181. data = "0"
  182. return HttpResponse(data)
  183. # 头像上传
  184. class User_Img(ListView):
  185. def get(self, request):
  186. pass
  187. def post(self, request):
  188. user_photo = request.FILES.get('user_photo')
  189. if user_photo:
  190. print("头像图片:", user_photo)
  191. user_photo_dir = 'user_photo/'
  192. end_name = user_photo.name.split('.')[-1]
  193. # 判断如果路径不存在,即创建路径
  194. if os.path.exists(user_photo_dir) == False:
  195. os.makedirs(user_photo_dir)
  196. img = Image.open(user_photo)
  197. now_time = time.strftime(
  198. '%Y%m%d%H%M%S', time.localtime(time.time()))
  199. pic_name = now_time + '.' + end_name
  200. print("pic_name:", pic_name)
  201. img.save(user_photo_dir + pic_name)
  202. user_photo = user_photo_dir + pic_name
  203. print("user_photo:", user_photo)
  204. data = {"code": 0, "msg": "", "data": {"src": user_photo}}
  205. else:
  206. user_photo = "0"
  207. data = {"code": 404, "msg": "", "data": {"src": user_photo}}
  208. data = json.dumps(data)
  209. return HttpResponse(data)
  210. #新建用户
  211. class User_News(ListView):
  212. def get(self,request):
  213. pass
  214. def post(self,request):
  215. username = request.POST.get("username")
  216. user_remark = request.POST.get("user_remark")
  217. user_phone = request.POST.get("user_phone")
  218. email = request.POST.get("email")
  219. #用户登陆
  220. class User_Land(ListView):
  221. def get(self,request):
  222. pass
  223. def post(self, request):
  224. user_name = request.POST.get("username")
  225. pass_word = request.POST.get("password")
  226. print('输入的用户名', user_name)
  227. print('输入的密码:', pass_word)
  228. user = MyUser.objects.extra(
  229. where=['binary username=%s'], params=[user_name])
  230. print("user.exists():", user.exists())
  231. if user.exists() == False:
  232. data = 0
  233. print("用户不存在")
  234. data = json.dumps(data)
  235. return HttpResponse(data)
  236. else:
  237. user = MyUser.objects.get(username=user_name)
  238. if user.is_active != True:
  239. data = 2
  240. print("用户名错误")
  241. data = json.dumps(data)
  242. return HttpResponse(data)
  243. else:
  244. if check_password(pass_word, user.password) != True:
  245. data = 3
  246. print('密码错误')
  247. data = json.dumps(data)
  248. return HttpResponse(data)
  249. else:
  250. print('登陆成功')
  251. auth_user = authenticate(
  252. username=user_name, password=pass_word)
  253. auth_login(request, auth_user)
  254. # 将当前登录的用户名写入session
  255. request.session['username'] = user_name
  256. art_list = MyUser.objects.filter(username=user_name)
  257. for i in art_list:
  258. he = {"username":i.username,"user_img":i.user_picture.name,"code":1 }
  259. data = json.dumps(he)
  260. print("data:", data)
  261. return HttpResponse(data)
  262. #判断用户是否已登陆
  263. class User_Check(ListView):
  264. # def get(self,request):
  265. # pass
  266. def get(self, request):
  267. ret_url = request.path_info
  268. print(ret_url)
  269. if ret_url == "/home":
  270. return HttpResponse(ret_url)
  271. else:
  272. print(000)
  273. return HttpResponse("00000")