UidUser.py 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563
  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: AnsjerFormal
  7. @software: PyCharm
  8. @DATE: 2019/11/15 16:45
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: UserUid.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. # 添加设备字段
  15. import oss2
  16. import re
  17. import time
  18. import simplejson as json
  19. from django.utils.decorators import method_decorator
  20. from django.views.decorators.csrf import csrf_exempt
  21. from django.views.generic.base import View
  22. from Ansjer.config import OSS_STS_ACCESS_SECRET, OSS_STS_ACCESS_KEY
  23. from Model.models import UID_Bucket, UID_Preview, UidSetModel
  24. from Model.models import UidUserModel
  25. from Object.ResponseObject import ResponseObject
  26. from Object.TokenObject import TokenObject
  27. from Service.CommonService import CommonService
  28. from Service.ModelService import ModelService
  29. from Object.RedisObject import RedisObject
  30. import base64
  31. from Controller.CheckUserData import RandomStr
  32. '''
  33. http://192.168.136.40:8077/uiduser/add?token=local&UID=z123asdfqwerzxcvqw12&NickName=xxoxox&View_Account=user&View_Password=password&ChannelIndex=8&is_ap=1&Type=5&NickName=1234zcxv
  34. http://192.168.136.40:8077/uiduser/query?token=local&page=1&line=10&is_ap=1&NickName=1234zcxv&uid=zxcvasdfqwerzxcvqwer
  35. http://192.168.136.40:8077/uiduser/delete?token=local&id=138001380001573884997393980&is_ap=1
  36. '''
  37. # 添加设备字段
  38. def addInterface(request):
  39. request.encoding = 'utf-8'
  40. response = ResponseObject()
  41. if request.method == 'POST':
  42. request_dict = request.POST
  43. elif request.method == 'GET':
  44. request_dict = request.GET
  45. else:
  46. return response.json(444)
  47. token = request_dict.get('token', None)
  48. UID = request_dict.get('UID', None)
  49. NickName = request_dict.get('NickName', None)
  50. View_Account = request_dict.get('View_Account', None)
  51. View_Password = request_dict.get('View_Password', '')
  52. Type = request_dict.get('Type', None)
  53. ChannelIndex = request_dict.get('ChannelIndex', None)
  54. is_ap = request_dict.get('is_ap', None)
  55. if all([UID, NickName, View_Account, Type, ChannelIndex]):
  56. tko = TokenObject(token)
  57. response.lang = tko.lang
  58. if tko.code == 0:
  59. userID = tko.userID
  60. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  61. sy_uid = re.compile(r'^[A-Za-z0-9]{14}$')
  62. if re_uid.match(UID) or sy_uid.match(UID):
  63. is_ap = int(is_ap)
  64. is_exist = UidUserModel.objects.filter(UID=UID, userID_id=userID, is_ap=is_ap)
  65. if is_exist:
  66. return response.json(174)
  67. else:
  68. try:
  69. pk = CommonService.getUserID(getUser=False)
  70. create_data = {
  71. 'id': pk, 'userID_id': userID, 'UID': UID,
  72. 'NickName': NickName, 'View_Account': View_Account,
  73. 'View_Password': View_Password, 'Type': Type, 'ChannelIndex': ChannelIndex
  74. }
  75. UidUserModel.objects.create(**create_data)
  76. # 判断影子信息
  77. nowTime = int(time.time())
  78. us_qs = UidSetModel.objects.filter(uid=UID)
  79. if not us_qs.exists():
  80. uid_set_create_dict = {
  81. 'uid': UID,
  82. 'addTime': nowTime,
  83. 'updTime': nowTime,
  84. 'ip': CommonService.get_ip_address(request),
  85. 'channel': ChannelIndex,
  86. 'nickname': NickName}
  87. UidSetModel.objects.create(**uid_set_create_dict)
  88. except Exception as e:
  89. return response.json(10, repr(e))
  90. else:
  91. uid_user_qs = UidUserModel.objects.filter(id=pk). \
  92. values('id', 'userID', 'NickName', 'UID', 'View_Account', 'View_Password',
  93. 'ChannelIndex', 'Type', 'isShare', 'primaryUserID', 'primaryMaster',
  94. 'data_joined', 'version', 'isVod', 'isExist','is_ap')
  95. uid_user_ql = CommonService.qs_to_list(uid_user_qs)
  96. ubqs = UID_Bucket.objects.filter(uid=UID). \
  97. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  98. res = uid_user_ql[0]
  99. res['vod'] = list(ubqs)
  100. return response.json(0, res)
  101. else:
  102. return response.json(444, {'param': 'UID'})
  103. else:
  104. return response.json(tko.code)
  105. else:
  106. return response.json(444, {'param': 'UID,NickName,View_Account,View_Password,Type,ChannelIndex'})
  107. # 新查询设备字段
  108. def queryInterface(request):
  109. request.encoding = 'utf-8'
  110. response = ResponseObject()
  111. if request.method == 'POST':
  112. request_dict = request.POST
  113. elif request.method == 'GET':
  114. request_dict = request.GET
  115. else:
  116. return response.json(444)
  117. token = request_dict.get('token', None)
  118. page = request_dict.get('page', None)
  119. line = request_dict.get('line', None)
  120. NickName = request_dict.get('NickName', None)
  121. uid = request_dict.get('uid', None)
  122. is_ap = request_dict.get('is_ap', None)
  123. page = int(page)
  124. line = int(line)
  125. tko = TokenObject(token)
  126. response.lang = tko.lang
  127. if page <= 0:
  128. return response.json(0)
  129. if tko.code == 0:
  130. userID = tko.userID
  131. # redisObj = RedisObject(db=8)
  132. # redisObj.del_data(key='uid_qs_' + userID)
  133. uid_user_qs = UidUserModel.objects.filter(userID_id=userID)
  134. if is_ap:
  135. is_ap = int(is_ap)
  136. uid_user_qs = uid_user_qs.filter(is_ap=is_ap)
  137. if NickName:
  138. uid_user_qs = uid_user_qs.filter(NickName__icontains=NickName)
  139. if uid:
  140. uid_user_qs = uid_user_qs.filter(UID=uid)
  141. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  142. values('id', 'userID', 'NickName', 'UID', 'View_Account',
  143. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  144. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  145. 'isVod', 'isExist', 'NotificationMode','is_ap')
  146. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  147. uid_list = []
  148. for uid_user in uid_user_ls:
  149. uid_list.append(uid_user['UID'])
  150. ubqs = UID_Bucket.objects.filter(uid__in=uid_list). \
  151. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  152. upqs = UID_Preview.objects.filter(uid__in=uid_list).order_by('channel').values('id', 'uid', 'channel')
  153. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  154. bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
  155. nowTime = int(time.time())
  156. data = []
  157. # 设备拓展信息表
  158. us_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'version', 'nickname')
  159. uv_dict = {}
  160. for us in us_qs:
  161. uv_dict[us['uid']] = {'version': us['version'], 'nickname': us['nickname']}
  162. for p in uid_user_ls:
  163. p['vod'] = []
  164. for dm in ubqs:
  165. if p['UID'] == dm['uid']:
  166. if dm['endTime'] > nowTime:
  167. p['vod'].append(dm)
  168. p['preview'] = []
  169. for up in upqs:
  170. if p['UID'] == up['uid']:
  171. obj = 'uid_preview/{uid}/channel_{channel}.png'.format(uid=up['uid'], channel=up['channel'])
  172. img_sign = bucket.sign_url('GET', obj, 300)
  173. p['preview'].append(img_sign)
  174. p_uid = p['UID']
  175. if p_uid in uv_dict:
  176. # 设备版本号
  177. p['uid_version'] = uv_dict[p_uid]['version']
  178. # 设备昵称
  179. if uv_dict[p_uid]['nickname']:
  180. p['NickName'] = uv_dict[p_uid]['nickname']
  181. else:
  182. # 设备版本号
  183. p['uid_version'] = ''
  184. data.append(p)
  185. return response.json(0, data)
  186. else:
  187. return response.json(tko.code)
  188. # http://192.168.136.40:8077/uiduser/update?token=local&id=138001380001573885065588328&View_Account=12&View_Password=555&NickName=555
  189. # 添加设备字段
  190. def updateInterface(request):
  191. request.encoding = 'utf-8'
  192. response = ResponseObject()
  193. if request.method == 'POST':
  194. request_dict = request.POST
  195. elif request.method == 'GET':
  196. request_dict = request.GET
  197. else:
  198. return response.json(444)
  199. token = request_dict.get('token', None)
  200. NickName = request_dict.get('NickName', None)
  201. View_Account = request_dict.get('View_Account', None)
  202. View_Password = request_dict.get('View_Password', None)
  203. Type = request_dict.get('Type', None)
  204. tko = TokenObject(token)
  205. response.lang = tko.lang
  206. if tko.code == 0:
  207. userID = tko.userID
  208. uid_user_qs = UidUserModel.objects.filter(userID_id=userID,)
  209. if uid_user_qs.exists():
  210. update_dict = {}
  211. if NickName:
  212. update_dict['NickName'] = NickName
  213. if View_Account is not None:
  214. update_dict['View_Account'] = View_Account
  215. if View_Password is not None:
  216. update_dict['View_Password'] = View_Password
  217. if Type is not None:
  218. update_dict['Type'] = Type
  219. is_update = uid_user_qs.update(**update_dict)
  220. if is_update:
  221. return response.json(0)
  222. else:
  223. return response.json(177)
  224. else:
  225. return response.json(174)
  226. else:
  227. return response.json(tko.code)
  228. # 新删除设备
  229. def deleteInterface(request):
  230. '''
  231. 删除用户设备
  232. :param request:
  233. :return:
  234. '''
  235. response = ResponseObject()
  236. request.encoding = 'utf-8'
  237. if request.method == 'POST':
  238. request_dict = request.POST
  239. elif request.method == 'GET':
  240. request_dict = request.GET
  241. else:
  242. return response.json(444)
  243. token = request_dict.get('token', None)
  244. id = request_dict.get('id', None)
  245. is_ap = request_dict.get('is_ap', None)
  246. if all([token, id, is_ap]):
  247. tko = TokenObject(token)
  248. response.lang = tko.lang
  249. if tko.code == 0:
  250. userID = tko.userID
  251. # redisObj = RedisObject(db=8)
  252. # redisObj.del_data(key='uid_qs_' + userID)
  253. uid_user_qs = UidUserModel.objects.filter(userID_id=userID, id=id)
  254. if uid_user_qs.exists():
  255. uid_user_qs.delete()
  256. return response.json(0)
  257. else:
  258. return response.json(173)
  259. else:
  260. return response.json(tko.code)
  261. else:
  262. return response.json(444, {'param': 'token,id,is_ap'})
  263. # 设备信息添加
  264. class UidUserView(View):
  265. @method_decorator(csrf_exempt)
  266. def dispatch(self, *args, **kwargs):
  267. return super(UidUserView, self).dispatch(*args, **kwargs)
  268. def get(self, request, *args, **kwargs):
  269. request.encoding = 'utf-8'
  270. operation = kwargs.get('operation')
  271. return self.validation(request.GET, request, operation)
  272. def post(self, request, *args, **kwargs):
  273. request.encoding = 'utf-8'
  274. operation = kwargs.get('operation')
  275. return self.validation(request.POST, request, operation)
  276. def validation(self, request_dict, request, operation):
  277. response = ResponseObject()
  278. if operation is None:
  279. return response.json(444, 'error path')
  280. token = request_dict.get('token', None)
  281. # 设备主键uid
  282. tko = TokenObject(token)
  283. response.lang = tko.lang
  284. if tko.code != 0:
  285. return response.json(tko.code)
  286. userID = tko.userID
  287. if operation == 'adminDelete':
  288. return self.do_admin_delete(request_dict, userID, response)
  289. elif operation == 'adminQuery':
  290. return self.do_admin_query(request_dict, userID, response)
  291. else:
  292. return response.json(444, 'error path')
  293. # 管理员删除
  294. def do_admin_delete(self, request_dict, userID, response):
  295. own_perm = ModelService.check_perm(userID, 20)
  296. if own_perm is True:
  297. id = request_dict.getlist('id', None)
  298. uid_user_qs = UidUserModel.objects.filter(id__in=id)
  299. if uid_user_qs.exists():
  300. uid_user_qs.delete()
  301. return response.json(0)
  302. else:
  303. return response.json(173)
  304. else:
  305. return response.json(404)
  306. # 管理员查询接口
  307. def do_admin_query(self, request_dict, userID, response):
  308. own_perm = ModelService.check_perm(userID, 20)
  309. if own_perm is True:
  310. page = request_dict.get('page', None)
  311. line = request_dict.get('line', None)
  312. page = int(page)
  313. line = int(line)
  314. deviceContent = request_dict.get('content', None)
  315. if deviceContent:
  316. try:
  317. searchCondition = json.loads(deviceContent)
  318. except Exception as e:
  319. return response.json(10, repr(e))
  320. else:
  321. kwargs = CommonService.get_kwargs(data=searchCondition)
  322. uid_user_qs = UidUserModel.objects.filter(**kwargs).order_by('-id')
  323. if not uid_user_qs.exists():
  324. return response.json(0, [])
  325. count = uid_user_qs.count()
  326. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  327. values('id', 'userID', 'userID__username', 'userID__userEmail', 'userID__NickName' 'NickName',
  328. 'UID', 'View_Account',
  329. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  330. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  331. 'isVod', 'isExist', 'NotificationMode', 'is_ap')
  332. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  333. return response.json(0, {'datas': uid_user_ls, 'count': count})
  334. else:
  335. uid_user_qs = UidUserModel.objects.all().order_by('-id')
  336. if not uid_user_qs.exists():
  337. return response.json(0, [])
  338. count = uid_user_qs.count()
  339. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  340. values('id', 'userID', 'userID__username', 'userID__userEmail', 'userID__NickName', 'NickName',
  341. 'UID', 'View_Account',
  342. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  343. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  344. 'isVod', 'isExist', 'NotificationMode', 'is_ap')
  345. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  346. return response.json(0, {'datas' : uid_user_ls, 'count': count})
  347. else:
  348. return response.json(404)
  349. # v3添加设备字段
  350. def v3addInterface(request):
  351. request.encoding = 'utf-8'
  352. response = ResponseObject()
  353. if request.method == 'POST':
  354. request_dict = request.POST
  355. elif request.method == 'GET':
  356. request_dict = request.GET
  357. else:
  358. return response.json(444)
  359. token = request_dict.get('token', None)
  360. UID = request_dict.get('UID', None)
  361. NickName = request_dict.get('NickName', None)
  362. View_Account = request_dict.get('View_Account', None)
  363. View_Password = request_dict.get('View_Password', '')
  364. Type = request_dict.get('Type', None)
  365. ChannelIndex = request_dict.get('ChannelIndex', None)
  366. is_ap = request_dict.get('is_ap', None)
  367. try:
  368. for i in range(1, 4):
  369. if i == 1:
  370. View_Password = base64.b64decode(View_Password)
  371. View_Password = View_Password.decode('utf-8')
  372. View_Password = View_Password[1:-1]
  373. if i == 2:
  374. View_Password = base64.b64decode(View_Password)
  375. View_Password = View_Password.decode('utf-8')
  376. View_Password = View_Password[2:-2]
  377. if i == 3:
  378. View_Password = base64.b64decode(View_Password)
  379. View_Password = View_Password.decode('utf-8')
  380. View_Password = View_Password[3:-3]
  381. print(View_Password)
  382. except Exception as e:
  383. return response.json(111)
  384. if not View_Password:
  385. return response.json(424)
  386. if all([UID, NickName, View_Account, Type, ChannelIndex]):
  387. tko = TokenObject(token)
  388. response.lang = tko.lang
  389. if tko.code == 0:
  390. userID = tko.userID
  391. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  392. if re_uid.match(UID):
  393. is_ap = int(is_ap)
  394. is_exist = UidUserModel.objects.filter(UID=UID, userID_id=userID, is_ap=is_ap)
  395. if is_exist:
  396. return response.json(174)
  397. else:
  398. try:
  399. pk = CommonService.getUserID(getUser=False)
  400. create_data = {
  401. 'id': pk, 'userID_id': userID, 'UID': UID,
  402. 'NickName': NickName, 'View_Account': View_Account,
  403. 'View_Password': View_Password, 'Type': Type, 'ChannelIndex': ChannelIndex
  404. }
  405. UidUserModel.objects.create(**create_data)
  406. # 判断影子信息
  407. nowTime = int(time.time())
  408. us_qs = UidSetModel.objects.filter(uid=UID)
  409. if not us_qs.exists():
  410. uid_set_create_dict = {
  411. 'uid': UID,
  412. 'addTime': nowTime,
  413. 'updTime': nowTime,
  414. 'ip': CommonService.get_ip_address(request),
  415. 'channel': ChannelIndex,
  416. 'nickname': NickName}
  417. UidSetModel.objects.create(**uid_set_create_dict)
  418. except Exception as e:
  419. return response.json(10, repr(e))
  420. else:
  421. uid_user_qs = UidUserModel.objects.filter(id=pk). \
  422. values('id', 'userID', 'NickName', 'UID', 'View_Account', 'View_Password',
  423. 'ChannelIndex', 'Type', 'isShare', 'primaryUserID', 'primaryMaster',
  424. 'data_joined', 'version', 'isVod', 'isExist','is_ap')
  425. uid_user_ql = CommonService.qs_to_list(uid_user_qs)
  426. ubqs = UID_Bucket.objects.filter(uid=UID). \
  427. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  428. res = uid_user_ql[0]
  429. res['vod'] = list(ubqs)
  430. return response.json(0, res)
  431. else:
  432. return response.json(444, {'param': 'UID'})
  433. else:
  434. return response.json(tko.code)
  435. else:
  436. return response.json(444, {'param': 'UID,NickName,View_Account,View_Password,Type,ChannelIndex'})
  437. # v3新查询设备字段
  438. def v3queryInterface(request):
  439. request.encoding = 'utf-8'
  440. response = ResponseObject()
  441. if request.method == 'POST':
  442. request_dict = request.POST
  443. elif request.method == 'GET':
  444. request_dict = request.GET
  445. else:
  446. return response.json(444)
  447. token = request_dict.get('token', None)
  448. page = request_dict.get('page', None)
  449. line = request_dict.get('line', None)
  450. NickName = request_dict.get('NickName', None)
  451. uid = request_dict.get('uid', None)
  452. is_ap = request_dict.get('is_ap', None)
  453. page = int(page)
  454. line = int(line)
  455. tko = TokenObject(token)
  456. response.lang = tko.lang
  457. if page <= 0:
  458. return response.json(0)
  459. if tko.code == 0:
  460. userID = tko.userID
  461. # redisObj = RedisObject(db=8)
  462. # redisObj.del_data(key='uid_qs_' + userID)
  463. uid_user_qs = UidUserModel.objects.filter(userID_id=userID)
  464. if is_ap:
  465. is_ap = int(is_ap)
  466. uid_user_qs = uid_user_qs.filter(is_ap=is_ap)
  467. if NickName:
  468. uid_user_qs = uid_user_qs.filter(NickName__icontains=NickName)
  469. if uid:
  470. uid_user_qs = uid_user_qs.filter(UID=uid)
  471. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  472. values('id', 'userID', 'NickName', 'UID', 'View_Account',
  473. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  474. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  475. 'isVod', 'isExist', 'NotificationMode','is_ap')
  476. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  477. uid_list = []
  478. for uid_user in uid_user_ls:
  479. uid_list.append(uid_user['UID'])
  480. ubqs = UID_Bucket.objects.filter(uid__in=uid_list). \
  481. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  482. upqs = UID_Preview.objects.filter(uid__in=uid_list).order_by('channel').values('id', 'uid', 'channel')
  483. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  484. bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
  485. nowTime = int(time.time())
  486. data = []
  487. # 设备拓展信息表
  488. us_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'version', 'nickname')
  489. uv_dict = {}
  490. for us in us_qs:
  491. uv_dict[us['uid']] = {'version': us['version'], 'nickname': us['nickname']}
  492. for p in uid_user_ls:
  493. p['vod'] = []
  494. for dm in ubqs:
  495. if p['UID'] == dm['uid']:
  496. if dm['endTime'] > nowTime:
  497. p['vod'].append(dm)
  498. p['preview'] = []
  499. p['View_Password'] = encrypt_pwd(p['View_Password'])
  500. for up in upqs:
  501. if p['UID'] == up['uid']:
  502. obj = 'uid_preview/{uid}/channel_{channel}.png'.format(uid=up['uid'], channel=up['channel'])
  503. img_sign = bucket.sign_url('GET', obj, 300)
  504. p['preview'].append(img_sign)
  505. p_uid = p['UID']
  506. if p_uid in uv_dict:
  507. # 设备版本号
  508. p['uid_version'] = uv_dict[p_uid]['version']
  509. # 设备昵称
  510. if uv_dict[p_uid]['nickname']:
  511. p['NickName'] = uv_dict[p_uid]['nickname']
  512. else:
  513. # 设备版本号
  514. p['uid_version'] = ''
  515. data.append(p)
  516. return response.json(0, data)
  517. else:
  518. return response.json(tko.code)
  519. # #加密
  520. def encrypt_pwd(userPwd):
  521. for i in range(1, 4):
  522. if i == 1:
  523. userPwd = RandomStr(3, False)+userPwd+RandomStr(3, False)
  524. userPwd = base64.b64encode(str(userPwd).encode("utf-8")).decode('utf8')
  525. if i == 2:
  526. userPwd = RandomStr(2, False)+str(userPwd)+RandomStr(2, False)
  527. userPwd = base64.b64encode(str(userPwd).encode("utf-8")).decode('utf8')
  528. if i == 3:
  529. userPwd = RandomStr(1, False)+str(userPwd)+RandomStr(1, False)
  530. userPwd = base64.b64encode(str(userPwd).encode("utf-8")).decode('utf8')
  531. return userPwd