利用crypto++库实现AES加密算法

jopen 10年前

利用crypto++库实现AES加/解密字符串,文件

MyAES.h:

/*   * MyAES.h   *   *  Created on: 2013-3-6   *      Author: hust   */    #ifndef MYAES_H_  #define MYAES_H_    #include <cryptopp/aes.h>  #include <cryptopp/default.h>  #include <cryptopp/filters.h>  #include <cryptopp/files.h>  #include <cryptopp/osrng.h>    #include <stdlib.h>  #include <string>  #include <iostream>    using namespace CryptoPP;  using namespace std;    class MyAES  {  public:   byte * key;   byte * iv;   int key_length;     MyAES();   MyAES(byte * key, byte *iv, int length);   ~MyAES();     //use the key to encrypt the plainText and return the cipher   string Encrypt(const string &plainText);   //use the same key to decrypt the cipher and return the recover   string Decrypt(const string &cipher);   //use the key to encrypt the file   bool EncryptFile(const string & inFilename, const string & outFilename);   //use the key to decyrpt the file   bool DecryptFile(const string & DecFilename,     const string & recoverFilename);   void GenerateKey();   void SetKey(byte * key, byte * iv, int length);  };    #endif /* MYAES_H_ */

MyAES.cpp:

//============================================================================  // Name        : MyAES.cpp  // Author      : hust  // Version     :  // Copyright   : 1.0  // Description : 本类将AES的加密,解密函数封装,直接调用即可对string进行加密or解密  //     另外,构造MyAES类的时候,传入参数key, iv, key_length  //     待解决:编写一个生成密钥的函数,即需要 KeyGenerate(Random random);  // reference   : http://www.codeproject.com/Articles/21877/Applied-Crypto-Block-Ciphers  //============================================================================    #include "MyAES.h"  #include <time.h>  MyAES::MyAES()  {    }    MyAES::MyAES(byte * key1, byte * iv1, int key_length1)  {   SetKey(key1, iv1, key_length1);  }    MyAES::~MyAES()  {    }    void MyAES::GenerateKey()  {   AutoSeededRandomPool rnd;   byte key1[AES::DEFAULT_KEYLENGTH];   rnd.GenerateBlock(key1, AES::DEFAULT_KEYLENGTH);     // Generate a random IV   byte iv1[AES::BLOCKSIZE];   rnd.GenerateBlock(iv1, AES::BLOCKSIZE);     SetKey(key1, iv1, 16);  }    void MyAES::SetKey(byte * key1, byte * iv1, int length1)  {   this->key = key1;   this->iv = iv1;   this->key_length = length1;  }    /*   * Description: use key to encrypt 'plainText', return the cipher   * Input:   *  plainText: the string need to be encrypted   * OutPUt:   *  return the cipher   */  string MyAES::Encrypt(const string &plainText)  {   string cipher;   CBC_Mode<AES>::Encryption aesEncryptor(key, key_length, iv);  // AESEncryption aesEncryptor; //加密器  // aesEncryptor.SetKey( key, key_length );  //设定加密密钥   StringSource(plainText, true,     new StreamTransformationFilter(aesEncryptor,       new StringSink(cipher)));   return cipher;  }    /*   * Description: use the same key to decrypt "cipher" and return the plainText   * Input:   *  cipher: the string to be decrypted   * Output:   *  return the recover   */  string MyAES::Decrypt(const string & cipher)  {   string recover;   CBC_Mode<AES>::Decryption aesDecryptor(key, key_length, iv);   //AESDecryption aesDecryptor; //解密器   //aesDecryptor.SetKey( key, key_length );  //设定加密密钥   StringSource(cipher, true,     new StreamTransformationFilter(aesDecryptor,       new StringSink(recover)));   return recover;  }    /*   * Description: use the key to encrypt the 'inFilename' and store the cipher in 'outFilname'   * Input:   *  inFilename: the file need to be encrypted!   *  outFilename: the encrypted file   * OutPut:   *  if encrypt success, return true, or return false   * Others: the function should delete the file : 'inFilename', however I note it   */  bool MyAES::EncryptFile(const string & inFilename, const string & outFilename)  {   // check if the file 'inFilename' exists.   if (access(inFilename.c_str(), 0) == -1)   {    cout << "The file " << inFilename << " is not exist! " << endl;    return false;   }   // file exists, the encrypt the file   CBC_Mode<AES>::Encryption aesEncryptor(key, key_length, iv);     FileSource(inFilename.c_str(), true,     new StreamTransformationFilter(aesEncryptor,       new FileSink(outFilename.c_str())));   // remove the file 'inFilename'   // if(remove(inFilename) == 0) cout << "remove file succeed! " << endl;   //   else cout << "fail to remove the file " << inFilname << endl;   // use function remove(), you have to add #include <cstdio> in the .h file   return true;  }    /*   * Description: use the same key to decrypt the 'decFilename' and create recoverFile   * Input:   *  decFilename: the encrypted file name   *  recoverFilename: the decrypted file name   * OutPut:   *  if decrypted the file successful, return true, else return false   * Others: we should also delete the file 'decFilename'   */  bool MyAES::DecryptFile(const string & decFilename,    const string & recoverFilename)  {   // check if the file 'decFilename' exists!   if (access(decFilename.c_str(), 0) == -1)   {    cout << "The file " << decFilename << " is not exist! " << endl;    return false;   }   // exist , then decrypt the file   CBC_Mode<AES>::Decryption aesDecryptor(key, key_length, iv);   FileSource(decFilename.c_str(), true,     new StreamTransformationFilter(aesDecryptor,       new FileSink(recoverFilename.c_str())));   return true;  }         int main() {      // byte key[] = {0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08, 0x01,0x02, 0x03,0x04,0x05,0x06,0x07,0x08};    // //AES::DEFAULT_KEYLENGTH    // byte iv[] = {0x01,0x02,0x03,0x03,0x03,0x03,0x03,0x03, 0x03,0x03, 0x01,0x02,0x03,0x03,0x03,0x03};    // int keysize = 16;        // generate the key    AutoSeededRandomPool rnd;    byte key[AES::DEFAULT_KEYLENGTH];    rnd.GenerateBlock( key, AES::DEFAULT_KEYLENGTH);      // Generate a random IV    byte iv[AES::BLOCKSIZE];    rnd.GenerateBlock(iv, AES::BLOCKSIZE);      int keysize = 16;      string plainText = "Hello World!";      clock_t start , finish;    double duration;    start = clock();      MyAES aes(key, iv, keysize);      cout << "AES parameters: " << endl;    cout << "The algorithm name is : " << AES::StaticAlgorithmName() << endl;    cout << "The iv is : " << aes.iv << endl;    cout << "The key is : " << aes.key << endl;    cout << "The key length is : " << aes.key_length << endl;      string cipher = aes.Encrypt(plainText);    cout << "The cipher is : " << cipher << endl;      string recover = aes.Decrypt(cipher);    cout << "The recover is : " << recover << endl;      cout << "=====================" << endl;      // encrypt the file and decrypt it    string inFilename = "aesTest";    string outFilename = "aesEncrypt";    string recoverFilename = "aesRecover";      if(aes.EncryptFile(inFilename, outFilename)){    cout << "*__*" << endl << "Encrypt succeed!" << endl;    if(aes.DecryptFile(outFilename, recoverFilename)){    cout << "*__*" << endl << "Recover succeed!" << endl;    } else    cout << ")__(" << endl << "Recover failed!" << endl;    } else    cout << ")__(" << endl << "Encrypt failed!" << endl;          finish = clock();    duration = (double)(finish - start) / CLOCKS_PER_SEC;    cout << "the cost is : " << duration << endl;      return 0;   }

在linux系统中编译命令为:

g++ MyAES.cpp -o test -lpthread -lcryptopp