| 1234567891011121314151617181920212223242526272829303132333435363738394041 |
- import base64
- import hmac
- import time
- from urllib.parse import quote
- # base64 无法导入microPython,因为文件过大(5M),esp8266只有8Mflash空间
- # 因此要计算好之后再加入到嵌入式设备
- def cal_token(id, access_key): # 官方文档给出的核心秘钥计算算法
- version = '2018-10-31'
- res = 'products/%s' % id # 通过产品ID访问产品API
- # 用户自定义token过期时间:一年后过期
- et = str(int(time.time()) + 31536000)
- # 签名方法,支持md5、sha1、sha256
- method = 'sha1'
- # 对access_key进行decode
- key = base64.b64decode(access_key)
- # 计算sign
- org = et + '\n' + method + '\n' + res + '\n' + version
- sign_b = hmac.new(key=key, msg=org.encode(), digestmod=method)
- sign = base64.b64encode(sign_b.digest()).decode()
- # value 部分进行url编码,method/res/version值较为简单无需编码
- sign = quote(sign, safe='')
- res = quote(res, safe='')
- # token参数拼接
- token = 'version=%s&res=%s&et=%s&method=%s&sign=%s' % (
- version, res, et, method, sign)
- return token
- if __name__ == '__main__':
- PRO_ID = "522417" #产品ID
- accesskey = "dgEP7iOL2/1kVNc1ykDvIhXSVqhb0tLnKinjU2RYpDs=" # 设备秘钥
- password = cal_token(PRO_ID, accesskey)
- print(password)
|