本文实例讲述了RC4文件加密的python实现方法。分享给大家供大家参考。具体分析如下:
基于RC4流加密算法,使用扩展的16*16的S盒,32字节密钥。
目前应该是比较安全的。
刚学习python,好不容易调通了。
而且在VC和python下各实现了一遍,两个平台能够互相加解密,很有成就感的说。
下面是python3.0中的实现,在2.x下需要稍加修改。
# for python 3.0
# from 李勃
import struct,sys,os,binascii
"""
RC4加密算法
16*16 S盒
加密单元:short
"""
def RC4(pkey,keylen,pin,dlen):
N=65536
S = list(range(N))
j = 0
for i in range(N):
j = (j + S[i] + pkey[i%keylen])%N
temp = S[i]
S[i] = S[j]
S[j] = temp
i = j = 0
pout= b''
for x in range(dlen):
i = i+1
j = (j + S[i])%N
temp = S[i]
S[i] = S[j]
S[j] = temp
pout += struct.pack('H',pin[x]^S[(S[i]+S[j])%N])
return(pout)
# bytes->short
def Coding(data):
if(len(data)%2):
data+=b'\0'
dlen = len(data)//2
return(struct.unpack(str(dlen)+'H',data))
# short->bytes
def unCoding(data):
d=b''
for i in range(len(data)):
d += struct.pack('H',data[i])
return(d)
#产生32字节密钥
def CreatKey(Keyt):
pl = len(Keyt)
Key=b''
r=0
for i in range(32):
k=(Keyt[r%pl]+i)%256
Key+= struct.pack('B',k)
r+=1
return Key
#更新密钥
def UpdataKey(Keyt):
Key = unCoding(Keyt)
#循环左移
Key = Key[1:] + struct.pack('B',Key[0])
tem=0
#求和
for i in range(len(Key)):
tem += Key[i];
Keyo=b''
#Xor
for i in range(len(Key)):
Keyo += struct.pack('B',(Key[i]^tem)%256)
tem += Keyo[i]3
tem = tem % 256
return(Coding(Keyo))
if __name__ == '__main__':
#获得输入文件
if len(sys.argv)==1:
filename = input('源文件: ')
else:
filename = sys.argv[1]
try:
fin = open(filename,'rb')
except:
print('打开文件失败!')
input()
sys.exit()
print(filename)
#打开输出文件
if filename[-4:]=='.RC4':
eID = 1
key=input('输入解密密钥: ').encode()
ofilename = filename[:-4]
else:
eID = 2
key=input('输入加密密钥: ').encode()
ofilename = filename+'.RC4'
key = Coding(CreatKey(key))
key = UpdataKey(key)
#处理重名
while os.path.exists(ofilename):
ofilename = os.path.dirname(ofilename)+ '\\副本 '+ os.path.basename(ofilename)
fout = open(ofilename,'wb')
print(ofilename)
#解密
if eID==1:
#读文件长度
filelen = struct.unpack('I',fin.read(4))[0]
print('FlieLen =',filelen,'\n......')
while 1:
#读块大小
ps= fin.read(2)
if not ps:
#文件结束
break
packsize = struct.unpack('H',ps)[0]
#读数据
dd=fin.read(packsize)
#解密
dd=Coding(dd)
x = RC4(key,len(key),dd,len(dd))
key = UpdataKey(key)
#crc
crc = struct.unpack('I',fin.read(4))[0]
if binascii.crc32(x)!=crc:
print('CRC32校验错误!',crc,binascii.crc32(x))
input()
sys.exit()
fout.write(x)
#裁剪末尾填充位
fout.truncate(filelen)
#加密
elif eID==2:
#获得文件长度
fin.seek(0,2)
filelen = fin.tell()
print('FlieLen =',filelen,'\n......')
fin.seek(0,0)
fout.write(struct.pack('I',filelen))
while 1:
#读数据
dd=fin.read(65534)
if not dd:
#文件结束
break
#末尾填充
srl = len(dd)
if srl%2:
srl+=1;
dd+=b'\0'
#crc
crc = struct.pack('I',binascii.crc32(dd))
#加密数据
dd=Coding(dd)
x = RC4(key,len(key),dd,len(dd))
key = UpdataKey(key)
#写入文件
fout.write(struct.pack('H',srl))
fout.write(x)
fout.write(crc)
fin.close()
fout.close()
print('OK!')
input()
希望本文所述对大家的Python程序设计有所帮助。
标签:
RC4,文件加密,python
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“RC4文件加密的python实现方法”评论...
更新动态
2025年10月29日
2025年10月29日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]