RC4文件加密的python實(shí)現(xiàn)方法
本文實(shí)例講述了RC4文件加密的python實(shí)現(xiàn)方法。分享給大家供大家參考。具體分析如下:
基于RC4流加密算法,使用擴(kuò)展的16*16的S盒,32字節(jié)密鑰。
目前應(yīng)該是比較安全的。
剛學(xué)習(xí)python,好不容易調(diào)通了。
而且在VC和python下各實(shí)現(xiàn)了一遍,兩個(gè)平臺(tái)能夠互相加解密,很有成就感的說。
下面是python3.0中的實(shí)現(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: #讀文件長(zhǎng)度 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校驗(yàn)錯(cuò)誤!',crc,binascii.crc32(x)) input() sys.exit() fout.write(x) #裁剪末尾填充位 fout.truncate(filelen) #加密 elif eID==2: #獲得文件長(zhǎng)度 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()
希望本文所述對(duì)大家的Python程序設(shè)計(jì)有所幫助。
- Python DES加密實(shí)現(xiàn)原理及實(shí)例解析
- 如何使用Cython對(duì)python代碼進(jìn)行加密
- Python實(shí)現(xiàn)常見的幾種加密算法(MD5,SHA-1,HMAC,DES/AES,RSA和ECC)
- python加密解密庫cryptography使用openSSL生成的密匙加密解密
- Python3加密解密庫Crypto的RSA加解密和簽名/驗(yàn)簽實(shí)現(xiàn)方法實(shí)例
- Python 實(shí)現(xiàn)加密過的PDF文件轉(zhuǎn)WORD格式
- 基于python實(shí)現(xiàn)文件加密功能
- python破解zip加密文件的方法
- python文件的md5加密方法
- 如何用Python 加密文件
相關(guān)文章
基于Python實(shí)現(xiàn)批量讀取大量nc格式文件并導(dǎo)出全部時(shí)間信息
這篇文章主要為大家詳細(xì)介紹了如何基于Python語言,逐一讀取大量.nc格式的多時(shí)相柵格文件并導(dǎo)出其中所具有的全部時(shí)間信息的方法,需要的可以參考下2024-01-01Python壓縮包處理模塊zipfile和py7zr操作代碼
目前對(duì)文件的壓縮和解壓縮比較常用的格式就是zip格式和7z格式,這篇文章主要介紹了Python壓縮包處理模塊zipfile和py7zr,需要的朋友可以參考下2022-06-06在flask中使用python-dotenv+flask-cli自定義命令(推薦)
這篇文章主要介紹了在flask中使用python-dotenv+flask-cli自定義命令的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01python 基本數(shù)據(jù)類型占用內(nèi)存空間大小的實(shí)例
今天小編就為大家分享一篇python 基本數(shù)據(jù)類型占用內(nèi)存空間大小的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-06-06PyTorch中torch.manual_seed()的用法實(shí)例詳解
在Pytorch中可以通過相關(guān)隨機(jī)數(shù)來生成張量,并且可以指定生成隨機(jī)數(shù)的分布函數(shù)等,下面這篇文章主要給大家介紹了關(guān)于PyTorch中torch.manual_seed()用法的相關(guān)資料,需要的朋友可以參考下2022-06-06K-means聚類算法介紹與利用python實(shí)現(xiàn)的代碼示例
K-means聚類算法(事先數(shù)據(jù)并沒有類別之分!所有的數(shù)據(jù)都是一樣的)是我們大家應(yīng)該都聽過的一種算法,下面這篇文章主要給大家介紹了關(guān)于K-means聚類算法的基礎(chǔ)知識(shí)與利用python如何實(shí)現(xiàn)該算法的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-11-11