資源簡介
利用VC對AES對稱加密算法進行了實現,希望對大家有所幫助

代碼片段和文件信息
#include?“StdAfx.h“????//注意在此?#include?“Aes.h“不可以放在前面,否則出錯,
#include?“Aes.h“
Aes::~Aes()
{
}
Aes::Aes()
{
}
////////////////////////////////////////////////////////////////////////////////////////////////
//構造函數
Aes::Aes(int?keysizeunsigned?char*?keyBytes)
{
SetNbNkNr(keysize);?????????????????????????//設置密鑰塊數,輪數?
memcpy(keykeyByteskeysize); //字符串拷貝函數,把keyBytes的keysize個字符復制到key中
KeyExpansion(); //密鑰擴展,必須提前做的初始化
}
////////////////////////////////////////////////////////////////////////////////////////////////
Aes::SetNbNkNr(int?keySize)
{
Nb=4;
if(keySize=Bits128)
{
Nk=4;????//4*4字節,128位密鑰,10輪加密
Nr=10;
}
else?if(keySize=Bits192)
{
Nk=6;????//6*4字節,192位密鑰,12輪加密
Nr=12;
}
else?if(keySize=Bits256)
{
Nk=8;????//8*4字節,256位密鑰,14輪加密
Nr=14;
}
}
////////////////////////////////////////////////////////////////////////////////////////////////
Aes::KeyExpansion()
{
memset(w016*15);
for(int?row=0;row {
w[4*row+0]?=??key[4*row];
w[4*row+1]?=??key[4*row+1];
w[4*row+2]?=??key[4*row+2];
w[4*row+3]?=??key[4*row+3];
}
byte*?temp?=?new?byte[4];
for(row=Nk;row<4*(Nr+1);row++)
{
temp[0]=w[4*row-4];?????//當前列的前一列??
temp[1]=w[4*row-3];
temp[2]=w[4*row-2];
temp[3]=w[4*row-1];
if(row%Nk==0)???????????//逢nk時,對當前列的前一列作特殊處理
{
temp=SubWord(RotWord(temp));???//先移位,再代換,最后和輪常量異或
temp[0]?=?(byte)(?(int)temp[0]?^?(int)?AesRcon[4*(row/Nk)+0]?);???
temp[1]?=?(byte)(?(int)temp[1]?^?(int)?AesRcon[4*(row/Nk)+1]?);
temp[2]?=?(byte)(?(int)temp[2]?^?(int)?AesRcon[4*(row/Nk)+2]?);
temp[3]?=?(byte)(?(int)temp[3]?^?(int)?AesRcon[4*(row/Nk)+3]?);
????????}
else?if?(?Nk?>?6?&&?(row?%?Nk?==?4)?)??//這個還沒有搞清楚
????????{
temp?=?SubWord(temp);
????????}
????????
????????//?w[row]?=?w[row-Nk]?xor?temp
????????w[4*row+0]?=?(byte)?(?(int)?w[4*(row-Nk)+0]?^?(int)temp[0]?);
w[4*row+1]?=?(byte)?(?(int)?w[4*(row-Nk)+1]?^?(int)temp[1]?);
w[4*row+2]?=?(byte)?(?(int)?w[4*(row-Nk)+2]?^?(int)temp[2]?);
w[4*row+3]?=?(byte)?(?(int)?w[4*(row-Nk)+3]?^?(int)temp[3]?);
}??//?for?loop
}
////////////////////////////////////////////////////////////////////////////////////////////////
//密鑰移位函數
unsigned?char*?Aes::RotWord(unsigned?char*?word)
{
byte*?temp?=?new?byte[4];
temp[0]?=?word[1];
temp[1]?=?word[2];
temp[2]?=?word[3];
temp[3]?=?word[0];
return?temp;
}
////////////////////////////////////////////////////////////////////////////////////////////////
//密鑰字代換函數
unsigned?char*?Aes::SubWord(unsigned?char*?word)
{
byte*?temp?=?new?byte[4];
for(int?j=0;j<4;j++)
{
temp[j]?=?AesSbox[16*(word[j]?>>?4)+(word[j]?&?0x0f)];??//實際上也可以寫成AesSbox[[j]];因為兩者相等
}
return?temp;
}
////////////////////////////////////////////////////////////////////////////////////////////////
//Aes加密函數
void?Aes::Cipher(unsigned?char*?input?unsigned?char*?output)
{
memset(&State[0][0]016);
for(int?i=0;i<4*Nb;i
?屬性????????????大小?????日期????時間???名稱
-----------?---------??----------?-----??----
?????文件???????9982??2007-06-07?23:58??AesCode\Aes.cpp
?????文件???????5655??2007-05-23?22:34??AesCode\Aes.h
?????文件??????21416??2009-10-14?19:32??AesCode\AesCode.aps
?????文件???????1449??2009-10-14?19:33??AesCode\AesCode.clw
?????文件???????1906??2007-05-24?11:44??AesCode\AesCode.cpp
?????文件???????4295??2007-05-23?14:52??AesCode\AesCode.dsp
?????文件????????539??2007-05-23?14:25??AesCode\AesCode.dsw
?????文件???????1335??2007-05-23?14:25??AesCode\AesCode.h
?????文件??????99328??2009-10-14?19:33??AesCode\AesCode.ncb
?????文件??????55808??2009-10-14?19:33??AesCode\AesCode.opt
?????文件????????248??2009-10-14?19:33??AesCode\AesCode.plg
?????文件???????5898??2007-11-20?20:10??AesCode\AesCode.rc
?????文件???????9648??2007-05-24?13:42??AesCode\AesCodeDlg.cpp
?????文件???????1506??2007-05-24?12:30??AesCode\AesCodeDlg.h
?????文件??????21223??2009-10-14?19:32??AesCode\Debug\Aes.obj
?????文件?????118848??2009-10-14?19:32??AesCode\Debug\AesCode.exe
?????文件?????220196??2009-10-14?19:32??AesCode\Debug\AesCode.ilk
?????文件??????14096??2009-10-14?19:32??AesCode\Debug\AesCode.obj
?????文件????5498024??2009-10-14?19:32??AesCode\Debug\AesCode.pch
?????文件?????295936??2009-10-14?19:32??AesCode\Debug\AesCode.pdb
?????文件???????2976??2009-10-14?19:32??AesCode\Debug\AesCode.res
?????文件??????43836??2009-10-14?19:32??AesCode\Debug\AesCodeDlg.obj
?????文件?????105696??2009-10-14?19:32??AesCode\Debug\StdAfx.obj
?????文件?????205824??2009-10-14?19:33??AesCode\Debug\vc60.idb
?????文件?????364544??2009-10-14?19:32??AesCode\Debug\vc60.pdb
?????文件???????3597??2007-05-23?14:25??AesCode\ReadMe.txt
?????文件???????1078??2007-05-23?14:25??AesCode\res\AesCode.ico
?????文件????????399??2007-05-23?14:25??AesCode\res\AesCode.rc2
????..A.SH.??????3072??2007-05-24?23:50??AesCode\res\Thumbs.db
?????文件???????1053??2007-05-24?12:18??AesCode\Resource.h
............此處省略8個文件信息
- 上一篇:cvsd pcm 編解碼算法實現
- 下一篇:moxa串口驅動軟件
評論
共有 條評論