91av视频/亚洲h视频/操亚洲美女/外国一级黄色毛片 - 国产三级三级三级三级

  • 大小: 1.83MB
    文件類型: .rar
    金幣: 2
    下載: 0 次
    發布日期: 2023-08-16
  • 語言: 其他
  • 標簽:

資源簡介

利用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個文件信息

評論

共有 條評論

相關資源