''' Created on 2019年10月15日 @author: lg ''' 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 # 關鎖 # encData.append(0x43) # encSum += 0x43 # 鳴笛 # encData.append(0x55) # encSum += 0x55 # 數據段 for i in range(11): encData.append(0xEE) encSum += 0xEE # 校驗和 encData.append(int(encSum / 256)) encData.append(encSum % 256) print(encData) # 明文list轉爲bytes類型 encBytes = bytes(encData) # encBytes = b'\x00\x01\x4F\x11\x11\x11\x11\x11\x11\x11\x11\x11\x11\x11\x01\x0B' print("明文爲:", encBytes) print("明文爲:", b2a_hex(encBytes)) # 祕鑰,字符串格式的轉爲bytes格式,實際需要傳入的應是bytes格式 key = 'I637S01KYHH00000'.encode('ISO-8859-1') # 將明文的bytes類型轉爲str類型傳入,加密。返回值同上,第一個爲實際的bytes格式密文 str(encBytes,'utf-8') enc = encrypt(encBytes, key) print("加密後:", enc) print("加密後:", b2a_hex(enc)) # 解密,將bytes類型密文傳入,返回值即爲最後的bytes類型明文,同上 dec = decrypt(enc, key) print("解密後:", dec) print("解密後:", b2a_hex(dec))
python3對接微信小程序藍牙
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.