文章目录
- 前言
- 一、Cryptopp是什么?
- 1. Cryptopp(CRYPTO++)官方文档wiki
- 二、下载Cryptopp
- 2. Crypto++下载地址
- 3. 下载PEM包
- 三、在VS2022中使用Cryptopp库
- 4. 处理crypto++源文件
- 5. 在VS2022项目中使用crypto++库
- 四、运行代码后一些关于c++的错误总结
前言
- Cryptopp是什么?
- 如何下载Cryptopp?
- 如何在VS中使用Crypto++?
一、Cryptopp是什么?
免费C++库,用于密码方案,最初由Wei Dai编写,包括密码,消息认证代码,单向哈希函数,公钥密码系统,密钥协议方案和压缩压缩。
PEM包:消息加密的部分实现,允许您读取和写入 PEM 编码的密钥和参数,包括加密的私钥。其他文件包括对 RSA、DSA、EC、ECDSA 密钥和 Diffie-Hellman 参数的支持。该包包括五个额外的源文件,一个使用OpenSSL创建测试密钥的脚本,一个用于测试读取和写入密钥的C++程序,以及一个用于验证使用OpenSSL编写的Crypto++编写的密钥的脚本。
1. Cryptopp(CRYPTO++)官方文档wiki
https://cryptopp.com/wiki/Main_Page
二、下载Cryptopp
2. Crypto++下载地址
- 官网地址:https://www.cryptopp.com/#download
- github地址(8.7.0版本):https://github.com/weidai11/cryptopp/releases/tag/CRYPTOPP_8_7_0
有四个选项,请下载源码(如图所示)
3. 下载PEM包
- pem包官方地址:https://cryptopp.com/wiki/PEM_Pack
滑动页面至底部,下载(如图所示)
三、在VS2022中使用Cryptopp库
4. 处理crypto++源文件
- 打开下载并解压好的crypto++文件和pem包,将pem包中包含的全部文件复制粘贴到crypto++包中:
图1是解压后的pem包
图2为pem包中包含的所有文件
- 将图2中所有文件粘贴到图3所示解压后的crypto++文件中,双击打开crypto++文件中的cryptest.sln:
- 在VS2022中可以看到四个子工程(如图所示):
- cryptdll - 生成cryptopp.dll动态库
- dlltest - 用来测试cryptopp.dll,依赖cryptdll工程
- cryptlib - 生成cryptlib.lib静态库
- cryptest - 用来测试cryptopp,依赖cryptlib工程
- 往crypto++源文件中加入pem包:
右击“Header Files”->添加->现有项:
- pem.h
- pem_common.h
右击“Source Files”->添加->现有项:
- pem_common.cpp
- pem_read.cpp
- pem_write.cpp
5. build子工程cryptlib,生成lib文件
分别在Release和debug两个情况下,调整设备型号(本机是x64),右击子工程cryptlib点击“生成”。输出显示成功后即为完成。
此时,crypto++源文件夹下会多出一个名称为x64的文件夹,该文件夹下有三个子文件夹,其中一个名为Output,Output文件夹下有两个子文件夹,如图所示。Debug和Release文件夹下都有lib文件,这两个lib文件就是我们后面要使用的lib库。
- 处理crypto++文件:
新建文件夹,命名为cryptopp(或其他名称),文件夹下创建两个文件夹,分别命名为include,lib。
- 将crypto++源文件中所有头文件(.h结尾的文件)复制到新文件夹下的include文件夹下。
- 将上述Output文件夹复制粘贴到新建文件夹下的lib文件中。
至此,我们需要用到crypto++库整理完成。简而言之,从官网上下载下来的整个crypto++源码,我们只需要用到include和lib两个库文件。
5. 在VS2022项目中使用crypto++库
-
打开VS2022,文件->新建->项目->控制台应用
-
将新创建的项目中原本的hello world代码换成以下代码(该代码为crypto++官网给出的AES加密代码)作为测试代码:
#include "cryptlib.h"
#include "rijndael.h"
#include "modes.h"
#include "files.h"
#include "osrng.h"
#include "hex.h"
#include <iostream>
#include <string>
int main(int argc, char* argv[])
{
using namespace CryptoPP;
AutoSeededRandomPool prng;
HexEncoder encoder(new FileSink(std::cout));
SecByteBlock key(AES::DEFAULT_KEYLENGTH);
SecByteBlock iv(AES::BLOCKSIZE);
prng.GenerateBlock(key, key.size());
prng.GenerateBlock(iv, iv.size());
std::string plain = "CBC Mode Test:Hello!";
std::string cipher, recovered;
std::cout << "plain text: " << plain << std::endl;
/*********************************\
\*********************************/
try
{
CBC_Mode< AES >::Encryption e;
e.SetKeyWithIV(key, key.size(), iv);
StringSource s(plain, true,
new StreamTransformationFilter(e,
new StringSink(cipher)
) // StreamTransformationFilter
); // StringSource
}
catch (const Exception& e)
{
std::cerr << e.what() << std::endl;
exit(1);
}
/*********************************\
\*********************************/
std::cout << "key: ";
encoder.Put(key, key.size());
encoder.MessageEnd();
std::cout << std::endl;
std::cout << "iv: ";
encoder.Put(iv, iv.size());
encoder.MessageEnd();
std::cout << std::endl;
std::cout << "cipher text: ";
encoder.Put((const byte*)&cipher[0], cipher.size());
encoder.MessageEnd();
std::cout << std::endl;
/*********************************\
\*********************************/
try
{
CBC_Mode< AES >::Decryption d;
d.SetKeyWithIV(key, key.size(), iv);
StringSource s(cipher, true,
new StreamTransformationFilter(d,
new StringSink(recovered)
) // StreamTransformationFilter
); // StringSource
std::cout << "recovered text: " << recovered << std::endl;
}
catch (const Exception& e)
{
std::cerr << e.what() << std::endl;
exit(1);
}
return 0;
}
- 项目->属性
跟着图片进行修改选项:
a. 此处修改为我们新建的文件夹下的include文件路径。
b.留心你现在的模式是Release还是Debug。Release对应的运行库是/MT
,Debug对应的是/MTd
。
c.此处修改为我们新建的文件夹下的lib文件下路径。查看自己的配置,Debug对应的是Debug文件下的路径;Release对应的是Release文件下的路径。
- 运行测试代码,出现结果图则为crypto++配置成功。
四、运行代码后一些关于c++的错误总结
- 关于VS中多个源文件如何分开运行的解决方法
参考博文:https://blog.csdn.net/m0_62638970/article/details/121794983 - c++中setw()与setfill()的用法详情:https://blog.csdn.net/chen_zan_yu_/article/details/86663579
- C++ - “std” has no member “string”:https://blog.csdn.net/cedian0443/article/details/104930355
最后,由于crypto++的官方文档wiki资料不全面,非常感谢以下博文的贡献:
- VS2019下Crypto++安装与调用
- Crypto++的安装及使用
- Crypto++安装和简单使用RSA加密解密
- 视频教学(youtube):https://www.youtube.com/watch?v=5XE4zEN-WKg