User.py 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD018
  6. @NAME: langer
  7. @software: PyCharm
  8. @DATE: 2019/6/3 17:29
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: User.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. import json
  15. from django.http import HttpResponse
  16. from django.views.generic import TemplateView
  17. from django.views.decorators.csrf import csrf_exempt
  18. from django.utils.decorators import method_decorator
  19. from object.ResponseObject import ResponseObject
  20. from django.contrib.auth.hashers import make_password, check_password
  21. from model.models import UserModel
  22. import time
  23. from object.TokenObject import TokenObject
  24. # http://127.0.0.1:8000/user/register?username=admin&password=admin
  25. class registerView(TemplateView):
  26. def post(self, request, *args, **kwargs):
  27. request.encoding = 'utf-8'
  28. request_dict = json.loads(request.body.decode('utf-8'))
  29. return self.validate(request_dict)
  30. def get(self, request, *args, **kwargs):
  31. request.encoding = 'utf-8'
  32. request_dict = request.GET
  33. return self.validate(request_dict)
  34. def validate(self, request_dict):
  35. response = ResponseObject()
  36. username = request_dict.get('username', None)
  37. password = request_dict.get('password', None)
  38. if username and password:
  39. pwd = make_password(password)
  40. nowTime = int(time.time())
  41. create_dict = {
  42. 'username': username,
  43. 'password': make_password(password),
  44. 'addTime': nowTime,
  45. 'updTime': nowTime}
  46. try:
  47. UserModel.objects.create(**create_dict)
  48. except Exception as e:
  49. return response.json(0, repr(e))
  50. else:
  51. return response.json(0)
  52. else:
  53. return response.json(444)
  54. # http://127.0.0.1:8000/user/login?username=admin&password=admin
  55. class loginView(TemplateView):
  56. def post(self, request, *args, **kwargs):
  57. request.encoding = 'utf-8'
  58. request_dict = json.loads(request.body.decode('utf-8'))
  59. return self.validate(request_dict)
  60. def get(self, request, *args, **kwargs):
  61. request.encoding = 'utf-8'
  62. request_dict = request.GET
  63. return self.validate(request_dict)
  64. def validate(self, request_dict):
  65. response = ResponseObject()
  66. username = request_dict.get('username', None)
  67. password = request_dict.get('password', None)
  68. if username and password:
  69. user_qs = UserModel.objects.filter(username=username)
  70. if check_password(password, user_qs[0].password):
  71. tko = TokenObject()
  72. res = tko.generate({'userID': user_qs[0].id})
  73. return response.json(0, res)
  74. else:
  75. return response.json(401)
  76. else:
  77. return response.json(444)
  78. class queryView(TemplateView):
  79. def post(self, request, *args, **kwargs):
  80. request.encoding = 'utf-8'
  81. request_dict = json.loads(request.body.decode('utf-8'))
  82. return self.validate(request_dict)
  83. def get(self, request, *args, **kwargs):
  84. request.encoding = 'utf-8'
  85. request_dict = request.GET
  86. return self.validate(request_dict)
  87. def validate(self, request_dict):
  88. response = ResponseObject()
  89. token = request_dict.get('token', None)
  90. tko = TokenObject(token)
  91. if tko.code == 0:
  92. um_qs = UserModel.objects.filter().values('id', 'username')
  93. return response.json(0, list(um_qs))
  94. else:
  95. return response.json(tko.code)
  96. class deleteView(TemplateView):
  97. def post(self, request, *args, **kwargs):
  98. request.encoding = 'utf-8'
  99. request_dict = json.loads(request.body.decode('utf-8'))
  100. return self.validate(request_dict)
  101. def get(self, request, *args, **kwargs):
  102. request.encoding = 'utf-8'
  103. request_dict = request.GET
  104. return self.validate(request_dict)
  105. def validate(self, request_dict):
  106. response = ResponseObject()
  107. token = request_dict.get('token', None)
  108. tko = TokenObject(token)
  109. if tko.code == 0:
  110. id = request_dict.get('id', None)
  111. if id:
  112. UserModel.objects.filter(id=id).delete()
  113. return response.json(0)
  114. else:
  115. return response.json(0)
  116. else:
  117. return response.json(tko.code)