2021-2022-1 20211420《信息安全专业导论》XOR加密

利用异或门加密的原理

print(True ^ True)
print(False ^ False)
print(True ^ False)
print(True ^ False)
print(1 ^ 1)
print(0 ^ 0)
print(1 ^ 0)
print(0 ^ 1)

对内容进行简单的加密与解密(Elvis)

text = 'Elvis'
key = 169                                 # 设置密钥
list1 = list(text)                        # 创建新列表
result = ''                               # 创建空字符串,用来容纳二进制数结果
result1 = ''                              # 创建空字符串,用来容纳十进制数结果
for char in list1:                        # 遍历列表,转换成数字
    num = ord(char)                       # 转换成十进制数
    num_key = num ^ key                   # 进行按位异或运算加密
    num_key1 = bin(num_key)[2:]           # 将加密形成的十进制数转换成二进制数
    result += str(num_key1) + ' '         # 形成二进制数字符串结果
    result1 += str(num_key) + " "         # 形成十进制数字符串结果
resultsum = result
print("加密后的数据(二进制数):" + resultsum)
print("加密后的数据(十进制数):" + result1)
list2 = resultsum.split(" ")              # 对二进制数字符串创建为列表
list3 = list2.remove('')

# 实现解密
deresult = ''
deresult1 = ''
for item in list2:
    denum = int(item, 2)
    denum_key = denum ^ key
    destr = chr(denum_key)
    deresult += str(destr) + ''
    deresult1 += str(denum_key) + ' '
print("解密后的数据:", deresult)
print("解密后的数据(十进制数):", deresult1)

结果如上图

用MD5实现加密

#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

posted @ 2021-10-25 20:52  シバ鳥  阅读(112)  评论(4编辑  收藏  举报