views.py 19 KB

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