RC4文件加密的python實現(xiàn)方法
本文實例講述了RC4文件加密的python實現(xiàn)方法。分享給大家供大家參考。具體分析如下:
基于RC4流加密算法,使用擴展的16*16的S盒,32字節(jié)密鑰。
目前應該是比較安全的。
剛學習python,好不容易調(diào)通了。
而且在VC和python下各實現(xiàn)了一遍,兩個平臺能夠互相加解密,很有成就感的說。
下面是python3.0中的實現(xiàn),在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)
#產(chǎn)生32字節(jié)密鑰
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)
#循環(huán)左移
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:
#文件結(jié)束
break
packsize = struct.unpack('H',ps)[0]
#讀數(shù)據(jù)
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:
#讀數(shù)據(jù)
dd=fin.read(65534)
if not dd:
#文件結(jié)束
break
#末尾填充
srl = len(dd)
if srl%2:
srl+=1;
dd+=b'\0'
#crc
crc = struct.pack('I',binascii.crc32(dd))
#加密數(shù)據(jù)
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程序設(shè)計有所幫助。
相關(guān)文章
基于Python實現(xiàn)批量讀取大量nc格式文件并導出全部時間信息
這篇文章主要為大家詳細介紹了如何基于Python語言,逐一讀取大量.nc格式的多時相柵格文件并導出其中所具有的全部時間信息的方法,需要的可以參考下2024-01-01
Python壓縮包處理模塊zipfile和py7zr操作代碼
目前對文件的壓縮和解壓縮比較常用的格式就是zip格式和7z格式,這篇文章主要介紹了Python壓縮包處理模塊zipfile和py7zr,需要的朋友可以參考下2022-06-06
在flask中使用python-dotenv+flask-cli自定義命令(推薦)
這篇文章主要介紹了在flask中使用python-dotenv+flask-cli自定義命令的相關(guān)知識,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
python 基本數(shù)據(jù)類型占用內(nèi)存空間大小的實例
今天小編就為大家分享一篇python 基本數(shù)據(jù)類型占用內(nèi)存空間大小的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
PyTorch中torch.manual_seed()的用法實例詳解
在Pytorch中可以通過相關(guān)隨機數(shù)來生成張量,并且可以指定生成隨機數(shù)的分布函數(shù)等,下面這篇文章主要給大家介紹了關(guān)于PyTorch中torch.manual_seed()用法的相關(guān)資料,需要的朋友可以參考下2022-06-06
K-means聚類算法介紹與利用python實現(xiàn)的代碼示例
K-means聚類算法(事先數(shù)據(jù)并沒有類別之分!所有的數(shù)據(jù)都是一樣的)是我們大家應該都聽過的一種算法,下面這篇文章主要給大家介紹了關(guān)于K-means聚類算法的基礎(chǔ)知識與利用python如何實現(xiàn)該算法的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-11-11

