本文主要讲解的是通过使用二进制的方式操作文件,来实现对文件内容的加密和解密。
1、加解密简述
我们通常把加密算法分为两类:对称加密(如DES、AES)和非对称加密(如RSA)。加密和解密若使用的相同的秘钥,则称该种加密算法为对称加密算法;加密和解密若使用的不同的秘钥(公钥和私钥,一般使用公钥加密,私钥解密),则称该种加密算法为非对称加密算法。
对于加密解密,我们无非就是想 加密后的数据只有我们自己可以进行解密,且解密后的数据和加密前的数据内容一致。
2、以二进制的方式操作文件,实现对文件内容的加解密
我们知道文件在计算机中是以二进制数据的形式来进行存储的。那通过改变这些二进制数据,就相当于实现了对文件内容的加密,再通过还原这些二进制数据,就相当于实现了对文件内容的解密。
#第一步:创建一个新的文件,并向其中写入“好好学习,天天向上”这句内容
data='好好学习,天天向上'
first_file=open('D:\\1_Python_learn\\文档.txt','w',encoding='UTF-8')
first_file.write(data)
first_file.close()
#第一步完后可以先双击点开文件,查看文件内容,可以看见文件内容是“好好学习,天天向上”
#第二步:对文件进行加密
file=open('D:\\1_Python_learn\\文档.txt','rb')
bin_data=file.read()
file.close()
encry_lst=[]
for i in bin_data: #遍历字节串
i=i^10 #改变二进制数据原本的值:此处通过将原本的数据与10进行异或,来改变二进制数据的值
encry_lst.append(i)
encry_data=bytes(encry_lst) #使用bytes()函数将列表转换为字节串(bytes)
#列表中的每个元素都会被转换为对应的字节,并组成一个字节串。但是这种情况下,每个元素的范围就必须是0-255之间,因为一个字节的二进制数的范围为0-255
encry_file=open('D:\\1_Python_learn\\文档.txt','wb')
encry_file.write(encry_data)
encry_file.close()
#第二步完后可以先双击点开文件,查看文件内容,可以看见文件内容是乱码,说明成功加密了文件内容
#第三步:对文件进行解密
encry_file=open('D:\\1_Python_learn\\文档.txt','rb')
encry_data=encry_file.read()
file.close()
decry_lst=[i^10 for i in encry_data] #恢复原始的二进制数据。 异或运算中,a^b^b=a
decry_data=bytes(decry_lst)
decry_file=open('D:\\1_Python_learn\\文档.txt','wb')
decry_file.write(decry_data)
decry_file.close()
#第三步完后可以先双击点开文件,查看文件内容,可以看见文件内容是“好好学习,天天向上”,说明成功解密了文件内容
大家如果想更深入的了解 “以二进制的方式操作文件”,可以阅读下面这篇文章:
https://blog.csdn.net/m0_45053357/article/details/137614489