UidUser.py 23 KB

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