?? des.cpp
字號(hào):
len = ((len+7)>>3)<<3;
// 在緩沖區(qū)中解密
Decrypt(databuf,databuf,len);
// 將明文寫入輸出文件
_lwrite(fh_out,databuf,len);
}
// 設(shè)置解密文件長(zhǎng)度
_llseek(fh_out,deshead.TLen,SEEK_SET);
SetEndOfFile((HANDLE)fh_out);
// 結(jié)束等待光標(biāo)
wnd.EndWaitCursor();
return true;
}
/******************************************************************************/
// 名稱:Encrypt
// 功能:加密
// 參數(shù):len—數(shù)據(jù)長(zhǎng)度,必須是8的倍數(shù);KeyStr為0結(jié)尾的密鑰串,長(zhǎng)度<=16,可為任意字符
// KeyStr默認(rèn)值為0,如果你在調(diào)用前設(shè)置過子密鑰,則可省略該參數(shù)。例:
// SetSubKey(KeyStr);Encrypt(data,data,len);或:Encrypt(data,data,len,KeyStr);
// 返回:加密成功返回true,否則返回false
// 備注:當(dāng)密鑰長(zhǎng)度>8時(shí),系統(tǒng)自動(dòng)使用3次DES加密
/******************************************************************************/
bool CDes::Encrypt(char *Out,char *In,UINT len,const char *KeyStr)
{
CHECK( Out && In && !(len&0x7) )
if( KeyStr )
CHECK( SetSubKey(KeyStr) )
if( !Is3DES )
{ // 1次DES
for(int i=0,j=len>>3; i<j; ++i)
{
DES(Out,In,&SubKey[0],ENCRYPT);
Out += 8; In += 8;
}
}
else
{ // 3次DES E-D-E
for(int i=0,j=len>>3; i<j; ++i)
{
DES(Out,In, &SubKey[0],ENCRYPT);
DES(Out,Out,&SubKey[1],DECRYPT);
DES(Out,Out,&SubKey[0],ENCRYPT);
Out += 8; In += 8;
}
}
return true;
}
/******************************************************************************/
// 名稱:Decrypt
// 功能:解密
// 參數(shù):len—數(shù)據(jù)長(zhǎng)度,必須是8的倍數(shù);KeyStr為0結(jié)尾的密鑰串,長(zhǎng)度<=16,可為任意字符
// KeyStr默認(rèn)值為0,如果你在調(diào)用前設(shè)置過子密鑰,則可省略該參數(shù)。例:
// SetSubKey(KeyStr);Decrypt(data,data,len);或:Decrypt(data,data,len,KeyStr);
// 返回:解密成功返回true,否則返回false
// 備注:當(dāng)密鑰長(zhǎng)度>8時(shí),系統(tǒng)自動(dòng)使用3次DES解密
/******************************************************************************/
bool CDes::Decrypt(char *Out,char *In,UINT len,const char *KeyStr)
{
CHECK( Out && In && !(len&0x7) )
if( KeyStr )
CHECK( SetSubKey(KeyStr) )
if( !Is3DES )
{ // 1次DES
for(int i=0,j=len>>3; i<j; ++i)
{
DES(Out,In,&SubKey[0],DECRYPT);
Out += 8; In += 8;
}
}
else
{ // 3次DES D-E-D
for(int i=0,j=len>>3; i<j; ++i)
{
DES(Out,In, &SubKey[0],DECRYPT);
DES(Out,Out,&SubKey[1],ENCRYPT);
DES(Out,Out,&SubKey[0],DECRYPT);
Out += 8; In += 8;
}
}
return true;
}
/******************************************************************************/
// 名稱:SetSubKey
// 功能:由輸入密鑰串設(shè)置子密鑰
// 參數(shù):KeyStr為0結(jié)尾的密鑰串,長(zhǎng)度<=16,可為任意字符
// 返回:設(shè)置成功返回true,否則返回false
// 備注:當(dāng)密鑰長(zhǎng)度>8時(shí),將設(shè)置第2密鑰,且置3次DES標(biāo)志
/******************************************************************************/
bool CDes::SetSubKey(const char *KeyStr)
{
int len;
CHECK_MSG( KeyStr && (len=strlen(KeyStr))<=16 && len>0,
"設(shè)置DES密鑰出錯(cuò):空密鑰,或密鑰太長(zhǎng)!" )
memset(deskey,0,16);
memcpy(deskey,KeyStr,len);
// 設(shè)置第1密鑰
SetSubKey(&SubKey[0],deskey);
Is3DES = false;
if( len>8 )
{ // 置3次DES標(biāo)志
Is3DES = true;
// 設(shè)置第2密鑰
SetSubKey(&SubKey[1],&deskey[8]);
}
return true;
}
/******************************************************************************/
// 名稱:RandKeyStr
// 功能:產(chǎn)生隨機(jī)密鑰串
// 參數(shù):
// 返回:KeyStr地址
// 備注:
/******************************************************************************/
char* CDes::RandKeyStr(char KeyStr[9])
{
CHECK( KeyStr )
srand(GetTickCount());
for(int i=0; i<8; ++i)
{
KeyStr[i] = rand()%256;
}
while( !( KeyStr[7] && 0xf0 ) )
KeyStr[7] = rand()%256;
KeyStr[8] = '\0';
// 這樣可以進(jìn)行連接操作
return KeyStr;
}
/******************************************************************************/
// 名稱:DES
// 功能:加/解密
// 參數(shù):Type—ENCRYPT:加密,DECRYPT:解密
// 返回:
// 備注:私有函數(shù),不用檢查指針是否為空
/******************************************************************************/
void CDes::DES(char Out[8],char In[8],const PSubKey pSubKey,bool Type)
{
static bool M[64],Tmp[32],*Li,*Ri;
// 將輸入字節(jié)組分解成位組
CGfL::ByteToBit(M,In,8);
// 初始變換
CGfL::Transform(M,M,IP_Table,64);
if( Type == ENCRYPT )
Li=&M[0],Ri=&M[32];
else
Li=&M[32],Ri=&M[0];
for(int i=0; i<16; ++i)
{
memcpy(Tmp,Ri,32);
if( Type == ENCRYPT )
F_func(Ri,(*pSubKey)[i]);
else
F_func(Ri,(*pSubKey)[15-i]);
CGfL::Xor(Ri,Li,32);
memcpy(Li,Tmp,32);
}
// 逆初始變換
CGfL::Transform(M,M,IPR_Table,64);
// 將位組合并成輸出字節(jié)組
CGfL::BitToByte(Out,M,64);
}
/******************************************************************************/
// 名稱:SetSubKey
// 功能:由輸入密鑰設(shè)置16圈子密鑰
// 參數(shù):
// 返回:
// 備注:私有函數(shù),不用檢查指針是否為空
/******************************************************************************/
void CDes::SetSubKey(PSubKey pSubKey,const char Key[8])
{
static bool K[64],*KL=&K[0],*KR=&K[28];
// 將密鑰字節(jié)組分解成密鑰位組
CGfL::ByteToBit(K,Key,8);
// 密鑰變換
CGfL::Transform(K,K,PC1_Table,56);
for(int i=0; i<16; ++i)
{ // 循環(huán)左移
CGfL::RotateL((char*)KL,28,LOOP_Table[i]);
CGfL::RotateL((char*)KR,28,LOOP_Table[i]);
// 壓縮變換
CGfL::Transform((*pSubKey)[i],K,PC2_Table,48);
}
}
/******************************************************************************/
// 名稱:F_func
// 功能:f 函數(shù)
// 參數(shù):
// 返回:
// 備注:私有函數(shù),不用檢查指針是否為空
/******************************************************************************/
void CDes::F_func(bool In[32],const bool Ki[48])
{
static bool MR[48];
// 擴(kuò)展變換
CGfL::Transform(MR,In,E_Table,48);
CGfL::Xor(MR,Ki,48);
S_func(In,MR);
// P 變換
CGfL::Transform(In,In,P_Table,32);
}
/******************************************************************************/
// 名稱:S_func
// 功能:S 盒代替
// 參數(shù):
// 返回:
// 備注:私有函數(shù),不用檢查指針是否為空
/******************************************************************************/
void CDes::S_func(bool Out[32],const bool In[48])
{
for(char i=0,j,k; i<8; ++i)
{
j = (In[0]<<1) + In[5];
k = (In[1]<<3) + (In[2]<<2) + (In[3]<<1) + In[4];
CGfL::ByteToBit(Out,&S_Box[i][j][k],1,4);
Out +=4; In += 6;
}
}
///////////////////////////////////////////////////////////////////////////////
// End of Files
///////////////////////////////////////////////////////////////////////////////
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -