


版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、#include<>#include<>#include<>#include<>#include<>#defineNb4intRcon255=(0x8d,0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80,0x1b,0x36,0x6c,0xd8,0xab,0x4d,0x9a,0x2f,0x5e,0xbc,0x63,0xc6,0x97,0x35,0x6a,0xd4,0xb3,0x7d,0xfa,0xef,0xc5,0x91,0x39,0x72,0xe4,0xd3,0xbd,0x61,0xc2,0x9f,0x2
2、5,0x4a,0x94,0x33,0x66,0xcc,0x83,0x1d,0x3a,0x74,0xe8,0xcb,0x8d,0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80,0x1b,0x36,0x6c,0xd8,0xab,0x4d,0x9a,0x2f,0x5e,0xbc,0x63,0xc6,0x97,0x35,0x6a,0xd4,0xb3,0x7d,0xfa,0xef,0xc5,0x91,0x39,0x72,0xe4,0xd3,0xbd,0x61,0xc2,0x9f,0x25,0x4a,0x94,0x33,0x66,0xcc,0x83,0x1d,0x3a,0x7
3、4,0xe8,0xcb,0x8d,0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80,0x1b,0x36,0x6c,0xd8,0xab,0x4d,0x9a,0x2f,0x5e,0xbc,0x63,0xc6,0x97,0x35,0x6a,0xd4,0xb3,0x7d,0xfa,0xef,0xc5,0x91,0x39,0x72,0xe4,0xd3,0xbd,0x61,0xc2,0x9f,0x25,0x4a,0x94,0x33,0x66,0xcc,0x83,0x1d,0x3a,0x74,0xe8,0xcb,0x8d,0x01,0x02,0x04,0x08,0x10,0x2
4、0,0x40,0x80,0x1b,0x36,0x6c,0xd8,0xab,0x4d,0x9a,0x2f,0x5e,0xbc,0x63,0xc6,0x97,0x35,0x6a,0xd4,0xb3,0x7d,0xfa,0xef,0xc5,0x91,0x39,0x72,0xe4,0xd3,0xbd,0x61,0xc2,0x9f,0x25,0x4a,0x94,0x33,0x66,0xcc,0x83,0x1d,0x3a,0x74,0xe8,0xcb,0x8d,0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80,0x1b,0x36,0x6c,0xd8,0xab,0x4d,0x9
5、a,0x2f,0x5e,0xbc,0x63,0xc6,0x97,0x35,0x6a,0xd4,0xb3,0x7d,0xfa,0xef,0xc5,0x91,0x39,0x72,0xe4,0xd3,0xbd,0x61,0xc2,0x9f,0x25,0x4a,0x94,0x33,0x66,0xcc,0x83,0x1d,0x3a,0x74,0xe8,0xcb;(temp0=getSBoxValue(temp0);temp1=getSBoxValue(temp1);temp2=getSBoxValue(temp2);temp3=getSBoxValue(temp3);temp0=temp0ARconi/
6、Nk;elseif(Nk>6&&i%Nk=4)(temp0=getSBoxValue(temp0);temp1=getSBoxValue(temp1);temp2=getSBoxValue(temp2);temp3=getSBoxValue(temp3);RoundKeyi*4+0=RoundKey(i-Nk)*4+0Atemp0;RoundKeyi*4+1=RoundKey(i-Nk)*4+1atemp1;RoundKeyi*4+2=RoundKey(i-Nk)*4+2atemp2;RoundKeyi*4+3=RoundKey(i-Nk)*4+3atemp3;i+;vo
7、idAddRoundKey(intround)(inti,j;for(i=0;i<4;i+)(for(j=0;j<4;j+)(statejia=RoundKeyround*Nb*4+i*Nb+j;voidInvSubBytes()inti,j;for(i=0;i<4;i+)(for(j=0;j<4;j+)(stateij=getSBoxInvert(stateij);Sothefirstrowisnotshifted.voidInvShiftRows()(unsignedchartemp;voidInvMixColumns()(inti;unsignedchara,b,
8、c,d;for(i=0;i<4;i+)(a=state0i;b=state1i;c=state2i;d=state3i;state0i=Multiply(a,0x0e)AMultiply(b,0x0b)AMultiply(c,0x0d)Multiply(d,0x09);state1i=Multiply(a,0x09)AMultiply(b,0x0e)AMultiply(c,0x0b)Multiply(d,0x0d);state2i=Multiply(a,0x0d)aMultiply(b,0x09)aMultiply(c,0x0e)Multiply(d,0x0b);state3i=Mult
9、iply(a,0x0b)aMultiply(b,0x0d)aMultiply(c,0x09)Multiply(d,0x0e);voidInvCipher()(inti,j,round=0;for(i=0;i<4;i+)(for(j=0;j<4;j+)(stateji=ini*4+j;AddRoundKey(Nr);for(round=Nr-1;round>0;round-)(InvShiftRows();InvSubBytes();AddRoundKey(round);InvMixColumns();InvShiftRows();InvSubBytes();AddRoundK
10、ey(0);for(i=0;i<4;i+)for(j=0;j<4;j+)outi*4+j=stateji;voidSubBytes()inti,j;for(i=0;i<4;i+)for(j=0;j<4;j+)stateij=getSBoxValue(stateij);Sothefirstrowisnotshifted.voidShiftRows()(unsignedchartemp;voidCipher()(inti,j,round=0;for(i=0;i<4;i+)(for(j=0;j<4;j+)(stateji=ini*4+j;AddRoundKey(0
11、);for(round=1;round<Nr;round+)(SubBytes();ShiftRows();MixColumns();AddRoundKey(round);SubBytes();ShiftRows();AddRoundKey(Nr);for(i=0;i<4;i+)(for(j=0;j<4;j+)(outi*4+j=stateji;char*encrypt(char*str,char*key)(inti,j,Nl;doublelen;char*newstr;Nk=Nc/32;Nr=Nk+6;len=strlen(str);Nl=(int)ceil(len/16)
12、;/printf("Nl:%dn”,Nl);newstr=(char*)malloc(Nl*32);memset(newstr,0,sizeof(newstr);for(i=0;i<Nl;i+)for(j=0;j<Nk*4;j+)(Keyj=keyj;inj=stri*16+j;KeyExpansion();Cipher();memcpy(&newstri*32,out,32);returnnewstr;char*decrypt(char*str,char*key)(inti,j,len,Nl;char*newstr;Nk=Nc/32;Nr=Nk+6;len=st
13、rlen(str);Nl=(int)ceil(len/16);newstr=(char*)malloc(16*Nl);memset(newstr,0,sizeof(newstr);for(i=0;i<Nl;i+)(for(j=0;j<Nk*4;j+)(Keyj=keyj;inj=stri*16+j;KeyExpansion();InvCipher();memcpy(&newstri*32,out,32);returnnewstr;intmain()(charstr_1128;/存明文charstr_2128;/存加密密鑰charstr_3128;/存解密密鑰char*str;char*str2;printf("請輸入明文:n");scanf("%s”,str_1);printf("請輸入加密密鑰:n&qu
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024福建福州市可持續(xù)發(fā)展城市有限公司招聘3人筆試參考題庫附帶答案詳解
- 浙江國企招聘2025中移鐵通嘉興海鹽分公司招聘10人筆試參考題庫附帶答案詳解
- MySQL教程(新體系-綜合應(yīng)用實例視頻)(第4版) 第05章-答案
- 2025年度智能機器人產(chǎn)業(yè)員工聘用合同
- 二零二五農(nóng)村宅基地買賣與農(nóng)村土地流轉(zhuǎn)收益分配與管理合同
- 2025年度購物中心店鋪轉(zhuǎn)租及品牌入駐合作協(xié)議
- 二零二五年度商業(yè)街區(qū)月停車位車庫租賃合同樣本
- 2025年度航空航天投資戰(zhàn)略合作框架協(xié)議書
- 2025年度電商平臺返點積分兌換協(xié)議書
- 二零二五年度智能電網(wǎng)建設(shè)工期調(diào)整補充協(xié)議
- 面館合作伙伴合同協(xié)議書
- 2024年中考數(shù)學(xué)《二次函數(shù)的實際應(yīng)用》真題含解析版
- GB 30254-2024高壓三相籠型異步電動機能效限定值及能效等級
- 醫(yī)學(xué)課件胸腔穿刺術(shù)3
- DB31T 1488-2024 重大活動特種設(shè)備安全保障技術(shù)服務(wù)導(dǎo)則
- 教科版科學(xué)三年級下冊《 各種各樣的運動 》課件
- 部編版《道德與法治》六年級下冊第6課《探訪古代文明》精美課件(第1課時)
- (正式版)CB∕T 4548-2024 船舶行業(yè)企業(yè)相關(guān)方安全管理要求
- 部編版八年級物理(上冊)期末試卷(帶答案)
- 《衡水內(nèi)畫》課程標(biāo)準(zhǔn)
- 20S515 鋼筋混凝土及磚砌排水檢查井
評論
0/150
提交評論