Python使用异或对文件加密

Python使用‘异或’对文本进行加密

#初始密码
password="hello"
#需处理的文本
text="abcdefjhigk"
#密码初始长度
pwdLen=len(password)
#文本长度
textLen=len(text)
#处理生成秘钥,每个字符与需处理文本一一对应
key=textLen//pwdLen*password+password[:textLen%pwdLen]
list=[]
for i in range(len(key)):
    textBytes=bytes(key,"ASCII")[i]^bytes(text,"ASCII")[i]#转换成二进制格式一对一异或处理
    list.append(chr(textBytes))#转换成字符格式
#将字符数组串联起来生成加密字符
text01="".join(list)

#解密
list1=[]
for i in range(len(key)):
    textBytes=bytes(key,"ASCII")[i]^bytes(text01,"ASCII")[i]#转换成二进制格式一对一异或处理
    list1.append(chr(textBytes))#转换成字符格式
text02="".join(list1)
print(text02)

运行结果为:

abcdefjhigk#与原文本相同

对视频文件加密

import time
time_start=time.time()#生成开始时间
#需要加密的文件路径
fildPath=r"D:\连续剧\100.mp4"
picRead=open(fildPath,mode="rb")
#读取二进制文件
picData=picRead.read()
picLen=len(picData)
#需要写出的文件路径
f_write = open(r"D:\连续剧\101.mp4","wb")
#提供密码的txt文件
keyPath=r"C:\Users\liubb\Pictures\key.txt"
keyRead=open(keyPath,mode="rb")
#读取二进制密钥文件
keyData=keyRead.read()
keyLen=keyData.__len__()
#获取Key
key=picLen//keyLen*keyData+keyData[:picLen%keyLen]
#进行循环加密
for i in range(len(key)):
    newByte=key[i]^picData[i]
    #写出二进制文件
    f_write.write(bytes([newByte]))
f_write.close()
picRead.close()
keyRead.close()


time_end=time.time()#生成结束时间
print('time cost',time_end-time_start,'s')#打印运行时间

解密就是把输出路径改为输入路径即可

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python可以通过位运算符 `^` 来实现异或加密。可以将明文的每个字节与密钥的对应字节进行异或运算,得到密文的对应字节。加密和解密使用相同的密钥,因为异或运算具有可逆性。 以下是一个简单的Python代码示例,实现了一个基于异或加密加密和解密函数: ```python def xor_encrypt(plaintext, key): ciphertext = bytearray(plaintext) key = bytes(key) for i in range(len(ciphertext)): ciphertext[i] ^= key[i % len(key)] return bytes(ciphertext) def xor_decrypt(ciphertext, key): return xor_encrypt(ciphertext, key) ``` 上述代码中,`xor_encrypt` 函数接受明文和密钥作为输入,返回密文。`xor_decrypt` 函数接受密文和密钥作为输入,返回明文。在 `xor_encrypt` 函数中,我们先将明文转化为一个字节数组,然后逐字节与密钥进行异或运算,得到密文对应的字节。在 `xor_decrypt` 函数中,我们直接调用 `xor_encrypt` 函数,因为异或运算具有可逆性。 以下是一个简单的示例,展示如何使用这两个函数: ```python plaintext = b"hello world" key = b"secret" # 加密 ciphertext = xor_encrypt(plaintext, key) print("加密后的密文:", ciphertext) # 解密 decrypted_text = xor_decrypt(ciphertext, key) print("解密后的明文:", decrypted_text) ``` 输出结果如下: ``` 加密后的密文: b'\x03\x1a\x0e\x0e\x08\x17\x1d\x0c\x1d\x19\r' 解密后的明文: b'hello world' ``` 注意,这种加密方式并不是十分安全,因为密钥的长度是有限的,而且密文可以被暴力破解。因此,在实际应用中,建议使用更加安全的加密方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值