代码思路很简单,字符串的encode()方法可以将其编码为字节串,在生成的字节串中插入干扰字节后无法正常解码,要想还原信息,必须清楚干扰字节的位置并删除后再使用decode()解码。本文代码重点在于演示字符串方法和内置函数bytes()的用法,加密算法本身并不具有抗攻击性,很容易被破解。
def encrypt(message, k=3): #使用UTF8编码为字节串 m = message.encode() result = [] #切分,3个字节一组 for i in range(0, len(m), k): result.append(m[i:i+k]) #在每组中间插入干扰字节 #不过这样太明显了 #可以改为增加不同的随机字节 return b'\xf5'.join(result)
def decrypt(message, k=3): #把二进制串转换为数字列表 m = list(message) #删除干扰字节 del m[k::k+1] #转换为字节串并解码返回 return bytes(m).decode()
p = '中文测试。This is a test. 12345' c = encrypt(p,5) print(decrypt(c,5))