代码拉取完成,页面将自动刷新
#md5加密
import hashlib
hash_md5 = hashlib.md5()
x = input("Please input your text:")
print("Text:", x)
data = x.encode('utf-8', errors='ignore') # 对x编码,忽略潜在错误
hash_md5.update(data) # 更新数据,保证数据被成功编码
md5_str = hash_md5.hexdigest() # hash.hexdigest()返回摘要,作为十六进制数据字符串值
print("MD5:", md5_str) # 打印十六进制字符串值
#形成key
from random import *
rad = "".join([choice("0123456789ABCDEF") for i in range(32)]) # 从0到F中随机选取一个数,并形成一个32位的密钥
print("key:", rad) # 打印密钥
#xor加密
txt1 = []
t = ''
u = ''
for a in range(32):
i = '0x'+md5_str[a] # 添加16进制的前缀0x,形成标准十六进制数
j = '0x'+rad[a] # 添加16进制的前缀0x,形成标准十六进制数
p = bin(eval(i)).replace('0b', '') # 将十六进制数转换成二进制数,并去掉二进制数前缀0b
q = bin(eval(j)).replace('0b', '') # 将十六进制数转换成二进制数,并去掉二进制数前缀0b
for c in range(min(len(p), len(q))): # 对p和q按位异或运算
if (p[-c] == q[-c]):
e ='0'
elif(p[-c] !=q [-c]):
e ='1'
t = e + t
t ='0b'+t # 得到按位异或运算结果
d = t # 把按位异或运算结果赋值给d
t = '' # 重新给t赋值为空字符串
s = hex(eval(d)).replace('0x', '') # eval()函数用于返回表达式计算结果,同时转换为十六进制数,去掉前缀0x
u = u+s # 得到CipherText
print("CipherText:", u) # 打印CipherText
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。