TokenObject.py 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  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: AnsjerOA
  7. @software: PyCharm
  8. @DATE: 2018/8/13 15:36
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: TokenObject.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. from AnsjerUIDManage.config import OAUTH_ACCESS_TOKEN_SECRET, OAUTH_REFRESH_TOKEN_SECRET, OAUTH_ACCESS_TOKEN_TIME, \
  15. OAUTH_REFRESH_TOKEN_TIME
  16. import jwt, time
  17. from Object.RedisObject import RedisObject
  18. class TokenObject:
  19. def __init__(self, token=None):
  20. self.token = token
  21. self.lang = None
  22. self.userID = None
  23. self.user = ''
  24. self.code = 0
  25. # 令牌校验
  26. self.valid()
  27. def valid(self):
  28. if self.token is None:
  29. self.code = 309
  30. return
  31. try:
  32. res = jwt.decode(self.token, OAUTH_ACCESS_TOKEN_SECRET, algorithms='HS256')
  33. # print(res)
  34. self.userID = res.get('userID', None)
  35. self.lang = res.get('lang', None)
  36. self.user = res.get('user', '')
  37. # 刷新登录时间
  38. # if self.userID:
  39. # print(self.user)
  40. # redisObj = RedisObject(db=3)
  41. # redisObj.set_data(key=self.userID, val=self.user, expire=300)
  42. except jwt.ExpiredSignatureError as e:
  43. print('过期')
  44. print(repr(e))
  45. self.code = 309
  46. return
  47. except Exception as e:
  48. self.code = 309
  49. return
  50. else:
  51. if not self.userID:
  52. self.code = 309
  53. return
  54. else:
  55. if self.userID:
  56. self.code = 0
  57. return res
  58. else:
  59. self.code = 309
  60. return
  61. # token加密
  62. def generate(self, data={}):
  63. try:
  64. access_expire = int(OAUTH_ACCESS_TOKEN_TIME.total_seconds())
  65. refresh_expire = int(OAUTH_REFRESH_TOKEN_TIME.total_seconds())
  66. now_stamp = int(time.time())
  67. access_data = data
  68. refresh_data = data
  69. access_data['exp'] = access_expire + now_stamp
  70. refresh_data['exp'] = refresh_expire + now_stamp
  71. access_token = jwt.encode(access_data,
  72. OAUTH_ACCESS_TOKEN_SECRET,
  73. algorithm='HS256')
  74. refresh_token = jwt.encode(
  75. refresh_data,
  76. OAUTH_REFRESH_TOKEN_SECRET,
  77. algorithm='HS256')
  78. res = {
  79. 'access_token': access_token.decode('utf-8'),
  80. 'access_expire': access_expire,
  81. 'refresh_expire': refresh_expire,
  82. 'refresh_token': refresh_token.decode('utf-8'),
  83. }
  84. except Exception as e:
  85. self.code = 309
  86. print(repr(e))
  87. else:
  88. self.code = 0
  89. return res
  90. def refresh(self):
  91. if not self.token:
  92. self.code = 309
  93. return
  94. try:
  95. res = jwt.decode(self.token, OAUTH_REFRESH_TOKEN_SECRET, algorithms='HS256')
  96. except jwt.ExpiredSignatureError as e:
  97. print('过期')
  98. print(repr(e))
  99. self.code = 309
  100. except Exception as e:
  101. self.code = 309
  102. print(repr(e))
  103. else:
  104. self.code = 0
  105. userID = res.get('userID', '')
  106. user = res.get('user', '')
  107. lang = self.lang
  108. refreshRes = self.generate(data={'userID': userID, 'lang':lang , 'user': user})
  109. return refreshRes
  110. # import jwt
  111. #
  112. #
  113. # token = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySUQiOiIxNTMzODg0NDE4NTE5MTM4MDAxMzgwMDAiLCJleHAiOjE1NTU1NTEwNjUsInVzZXIiOiIxMTFAcXEuY29tIiwibGFuZyI6ImVuIn0.waPlfIBucSA7rFfnsxOKIVJ_cL6xiP33cAiz1IDoteY'
  114. # res = jwt.decode(token, 'a+jbgnw%@1%zy^=@dn62%', algorithms='HS256')
  115. # print(res)