我正在尝试在 MS Visual Studio 中使用 Crypto++ 实现 AES 256 算法。操作系统是Windows 7(64位)。
我需要以十六进制字符串形式提供密钥,以字符串形式提供密码,最后我希望加密的字符串也是十六进制字符串。
这是我正在尝试做的事情:
我的加密方法:
std::string encrypt(const std::string &password)
{
std::string plain = password;
std::string ciphertext;
char * decodedKey= "729308A8E815F6A46EB3A8AE6D5463CA7B64A0E2E11BC26A68106FC7697E727E37011";
byte key[ CryptoPP::AES::MAX_KEYLENGTH ], iv[ CryptoPP::AES::BLOCKSIZE ];
CryptoPP::StringSource( reinterpret_cast<const char *>(decodedKey), true,
new CryptoPP::HashFilter(*(new CryptoPP::SHA256), new CryptoPP::ArraySink(key, CryptoPP::AES::MAX_KEYLENGTH)) );
memset( iv, 0x00, CryptoPP::AES::BLOCKSIZE );
CryptoPP::CBC_Mode<CryptoPP::AES>::Encryption Encryptor( key, sizeof(key), iv );
CryptoPP::StringSource( plain, true, new CryptoPP::StreamTransformationFilter( Encryptor,
new CryptoPP::HexEncoder(new CryptoPP::StringSink( ciphertext ) ) ) );
std::cout<<"Ciphertext:" << ciphertext;
return ciphertext;
}
来自主方法
int main(int argc, char* argv[]) {
encrypt("test");
return 0;
}
目前我对密钥进行硬编码只是为了调试目的。我的密钥是十六进制字符串,如下所示。我需要将输出加密字符串作为十六进制字符串。