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

利用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

 

你可能感兴趣的:(AES加密,cyrpto++)