代码思路很简单,字符串的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))