資源簡介
qt可以使用的AES加密的類

代碼片段和文件信息
#include?“TAesClass.h“
Aes::~Aes()
{
}
Aes::Aes()
{
}
////////////////////////////////////////////////////////////////////////////////////////////////
//構造函數
Aes::Aes(int?keysizeunsigned?char*?keyBytes)
{
SetNbNkNr(keysize);?????????????????????????//設置密鑰塊數,輪數?
memcpy(keykeyByteskeysize); //字符串拷貝函數,把keyBytes的keysize個字符復制到key中
KeyExpansion(); //密鑰擴展,必須提前做的初始化
}
////////////////////////////////////////////////////////////////////////////////////////////////
void?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;
}
}
////////////////////////////////////////////////////////////////////////////////////////////////
void?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(int?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++)????????????????????????//這里是先寫列后寫行的,即輸入是一列一列的進來的
{
State[i%4][i/4]=i
?屬性????????????大小?????日期????時間???名稱
-----------?---------??----------?-----??----
?????文件???????13779??2012-03-28?15:53??aes\TAesClass.cpp
?????文件????????6350??2012-03-28?15:53??aes\TAesClass.h
?????目錄???????????0??2016-12-21?08:44??aes\
- 上一篇:哈夫曼樹的構造、編碼、譯碼實現
- 下一篇:MSP430例程
評論
共有 條評論