标签:脚本 int secret token key otp import data
#!/usr/bin/python3 import re import time import hashlib import struct import base64 import hmac from random import choice from string import ascii_letters, digits from sys import argvsecret = '这里是你的secret'
mangling_string = 'ASGIw3gQMAbEw6z4u8xxmfwYx5qG4b16'
def get_hotp_token(secret, intervals_no): key = base64.b32decode(secret, True) msg = struct.pack(">Q", intervals_no) h = hmac.new(key, msg, hashlib.sha1).digest() o = h[19] & 15 h = (struct.unpack(">I", h[o:o+4])[0] & 0x7fffffff) % 1000000 return h
try: token = get_totp_token(xor_crypt_string( secret, mangling_string, decode=True)) except: print("Invalid Secret")
token = '123456' + '%06d' % token print(token)
标签:脚本,int,secret,token,key,otp,import,data 来源: https://www.cnblogs.com/sweetsunnyflower/p/14339847.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。