RC5加密算法

[本人baidu博客全部搬家到csdn,baidu博客地址:http://hi.baidu.com/new/miracleconf]

以下是RC5加密解密算法的C++基本實現,僅供參考

// RC5.cpp : Defines the entry point for the console application.
#include "stdafx.h"
#include<iostream.h>
#include <stdlib.h>
#include <stdio.h>
 
#define UINT32 unsigned int
#define INT32  int
#define UINT16 unsigned short
#define INT16  short
#define UINT8  unsigned char
#define INT8   char
 
unsigned int subKey[25];
void generateSubKey()
{
   UINT8 i;
 
   for(i=0;i<25;i++)
   subKey[i] = i;
}
 
 
void encrypt(UINT32 *PText,UINT32 *CText)
{//進行加密
UINT32 PData[1];
UINT32 CData[1];
UINT32 tempData1,tempData2,temp;
UINT8  i;
 
PData[0] = *PText;
PText++;
PData[1] = *PText;
    CData[0] = *CText;
    CText++;
    CData[1] = *CText;
    tempData1 = PData[0] + subKey[0];
    tempData2 = PData[1] + subKey[1];
for(i=1;i<=12;i++)
{
       temp = tempData1;
 
       tempData1 ^= tempData2;
  _rotl(tempData1,tempData2);
       tempData1 += subKey[2*i];
 
       tempData2 ^= temp;
  _rotl(tempData2,temp);
       tempData2 += subKey[2*i + 1];
  
}
 
    CData[0] = tempData1;
    CData[1] = tempData2;
}
 
void decrypt(UINT32 *PText,UINT32 *CText)
{//進行解密
 
UINT32 PData[1];
UINT32 CData[1];
UINT32 tempData1,tempData2,temp1,temp2;
UINT8  i;
 
//PData = PText;
//     CData = CText;
PData[0] = *PText;
PText++;
PData[1] = *PText;
    CData[0] = *CText;
    CText++;
    CData[1] = *CText;
tempData1 = CData[0];
tempData2 = CData[1];
for(i=12;i<=1;i--)
{
       temp1 = tempData1;
       temp2 = tempData2;
 
       tempData1 = CData[0] - subKey[2*i];
       tempData2 = CData[1] - subKey[2*i + 1];
 
  _rotr(tempData2,temp1);
       tempData2 ^= temp1;
 
  _rotr(tempData1,temp2);
       tempData1 ^= temp2;
  
}
 
    PData[0] = tempData1 - subKey[1];
    PData[1] = tempData2 - subKey[0];
 
}
 
int main()
{
UINT32 PlainText[1];
UINT32 CipherText[1];
    
    generateSubKey();
cout<<"Hello!!\n\n";
/*cout<<"請輸入你要被加密的數據(HEX,32位)\n";
cout<<"\t\t數據1:";
cin>>PlainText[0];
cout<<"\t\t數據2:";
cin>>PlainText[1];
 */
PlainText[0] = 0x5a5a5a5a;
PlainText[1] = 0x12345678;
 
  cout<<"加密前的數據爲:"<<PlainText[0]<<","<<PlainText[1]<<"\n";   
 
encrypt(PlainText,CipherText);
 
  cout<<"加密後的數據爲:"<<CipherText[0]<<","<<CipherText[1]<<"\n";   
 
decrypt(PlainText,CipherText);
 
  cout<<"解密後的數據爲:"<<PlainText[0]<<","<<PlainText[1]<<"\n"; 
 
return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章