前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >蓝牙自定开锁时间--Python

蓝牙自定开锁时间--Python

作者头像
用户2337871
发布2019-10-25 01:48:17
4770
发布2019-10-25 01:48:17
举报
文章被收录于专栏:gitgit
代码语言:javascript
复制
from Crypto.Cipher import AES
from binascii import b2a_hex, a2b_hex


###强制输入明文增加到16字节的倍数,在末尾补'\0'
def add_to_16(text):
    text = str(text, 'ISO-8859-1')
    if len(text.encode('ISO-8859-1')) % 16:
        add = 16 - (len(text.encode('ISO-8859-1')) % 16)
    else:
        add = 0
    text = text + ('\0' * add)
    return text.encode('ISO-8859-1')


# 加密函数,传入明文和秘钥,返回密文,这三个都是bytes格式的
def encrypt(text, key):
    mode = AES.MODE_ECB
    text = add_to_16(text)
    cryptos = AES.new(key, mode)
    cipher_text = cryptos.encrypt(text)
    return cipher_text


# 解密函数,传入密文和秘钥,返回明文,这三个都是bytes格式的
def decrypt(text, key):
    mode = AES.MODE_ECB
    cryptor = AES.new(key, mode)
    plain_text = cryptor.decrypt(text)
    return plain_text


if __name__ == '__main__':
    # 需要加密的明文。下面打印的返回值第一个为实际的bytes明文数据,第二个其实实际将bytes转成了16进制字符串以便于查看分析,但实际已经不是原来的数了,勿用b2a_hex的第二个数据给小程序,小程序接收的应该是第一个!

    # 初始值
    encData = []
    encSum = 0x00

    # 流水号
    encData.append(0x00)
    encSum += 0x00
    encData.append(0x01)  # 流水号
    encSum += 0x01

    encData.append(0x4F)  # 蓝牙指令
    encSum += 0x4F

    for i in range(3):
        encData.append(0xEE)
        encSum += 0xEE
    # ---------------------自定义时间
    # 10分钟
    encData.append(0x02)
    encSum += 0x02
    encData.append(0x58)
    encSum += 0x58

    # 5分钟
    # encData.append(0x01)
    # encSum += 0x01
    # encData.append(0x2C)
    # encSum += 0x2C
    # ---------------------自定义时间

    # 数据段
    for i in range(6):
        encData.append(0xEE)
        encSum += 0xEE

    # 校验和
    encData.append(int(encSum / 256))
    encData.append(encSum % 256)

    # 明文list转为bytes类型
    encBytes = bytes(encData)
    print("明文为:", encBytes)
    print("明文为:", b2a_hex(encBytes))

    # 秘钥,字符串格式的转为bytes格式,实际需要传入的应是bytes格式
    key = 'I637S01KYHH00000'.encode('ISO-8859-1')

    # 将明文的bytes类型传入,加密。返回值同上,第一个为实际的bytes格式密文
    enc = encrypt(encBytes, key)
    print("加密后:", enc)
    print("加密后:", b2a_hex(enc), len(enc))

    # 解密,将bytes类型密文传入,返回值即为最后的bytes类型明文,同上
    dec = decrypt(enc, key)
    print("解密后:", dec)
    print("解密后:", b2a_hex(dec))
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云开发 CloudBase
云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档