1 AES加密算法

Crypto++/CryptoPP加解密库官网:https://www.cryptopp.com/

在写桌面程序的时候一些自定义的数据文件不可避免的需要放在本地,通常这种数据文件保存了一些敏感信息,所以必须想办法对其进行加密。然后在程序中对这种数据文件进行解密然后读取正确的内容。

目前加密分为非对称加密和对称加密。对称加密算法中,加密和解密使用的是同一把钥匙,即:使用相同的密匙对同一密码进行加密和解密;非对称加密是使用不同的密钥进行加密和解密,非对称加密有两个钥匙,及公钥(Public Key)和私钥(Private Key)。公钥和私钥是成对的存在,如果对原文使用公钥加密,则只能使用对应的私钥才能解密。关于对称加密与非对称加密的区别,可参考:https://zhuanlan.zhihu.com/p/49494990

对于本地加解密数据文件,会采用对称加密方法。而目前对称加密中破解难度最高的就是AES加密算法。其中AES加密算法可参考:https://zhuanlan.zhihu.com/p/78913397。AES加密也是具有奇高的破解难度,破解难度可参考:

2 Crypto++/CryptoPP加解密库

Crypto++/CryptoPP官网:https://www.cryptopp.com/

Crypto++是一个跨平台免费开源的C++加解密库,支持大部分的加解密算法,比如AES,MD5,base64,RSA等目前常用的加密算法。

2.1 下载

库下载链接:https://www.cryptopp.com/#download

下载最新版本即可:

C++ – 使用Crypto++/CryptoPP加解密库对字符串或者文件进行AES256加密-StubbornHuang Blog

2.2 Windows下编译

下载完成之后,解压缩包,在文件夹下可以找到cryptest.sln的VS项目文件,使用VS2019打开即可。

该解决方案包括四个项目文件:

  • cryptdll:cryptdll为动态库方案,在其他项目应用cryptopp的时候,编译时链接静态库,运行时需要链接动态库库
  • dlltest:测试cryptdll编译的dll
  • cryptlib:cryptlib为静态库方案,在其他项目应用cryptopp的时候,只需在编译时链接静态库即可,不需要在运行时链接动态库
  • cryptest:各种使用示例。

编译时需要注意cryptdll和cryptlib项目下C/C++-代码生成-运行库是/MT还是/MD,此种方式需要与使用Crypto++库的项目需要保持一致,不然在编译时会出错。

3 使用Crypto++/CryptoPP加解密库对字符串或者文件进行AES256加密

基于Crypto++对其AES256加密算法进行了封装,使其变得更加好用。封装类为CryptoAES类,提供了使用AES256加密字符串,解密字符串,直接加密数据文件,直接解密数据文件,间接从文件内容加密文件,间接从文件内容解密文件。目前使用的Crypto++/CryptoPP的版本为8.6.0。

针对CryptoAES.cpp文件中CryptoAES构造函数中的std::string message,可使用AES密码在线生成:https://www.imaegoo.com/2020/aes-key-generator/

关于Cryptopp官方的AES加密的例子可查看:https://www.cryptopp.com/wiki/Advanced_Encryption_Standard

3.1 CryptoAES.h 头文件

#ifndef CRYPTO_AES_H
#define CRYPTO_AES_H

#include "aes.h"
#include "files.h"
#include "filters.h"
#include "osrng.h"
#include "default.h"
#include "hex.h"
#include "base64.h"

class CryptoAES
{
public:
    CryptoAES();
    CryptoAES(const std::string& aes_key);
    virtual~CryptoAES();

public:

    std::string EncryptString(const std::string& plain_str);
    std::string DecryptString(const std::string& cipher_str);

    bool EncryptFileDirect(const std::string& src_file_path, const std::string& target_file_path);
    bool DecryptFileDirect(const std::string& src_file_path, const std::string& target_file_path);

    bool EncryptFileUseIO(const std::string& src_file_path, const std::string& target_file_path);
    std::string DecryptFileUseIO(const std::string& src_file_path);
    void DecryptFileUseIOSaveToFile(const std::string& src_file_path,const std::string& target_file_path);

private:
    CryptoPP::SecByteBlock m_Key;
    CryptoPP::SecByteBlock m_IV;
};

#endif // !CRYPTO_AES_H

此文章剩余56%被隐藏需要付费查看,内容查看价格3饼子立即购买,VIP免费
支付前请仔细阅读以下说明,如支付代表您了解并同意了以下说明(资源虽好,但请理性捐赠本站):
(1)请购买正版资源,支持原作者和出版社;
(2)资源收集自互联网,仅供自我学习,请在下载后24小时内删除该资源,如下载者将此资源用于其他非法用途,本站不承担任何法律责任;如有侵权,请立即联系我,马上删除!
(3)此捐赠下载方式无需注册+登录账号,当然如果您喜欢本站也可注册账号;
(4)所支付的款项为捐赠本站款项,而并非付费下载所付款项,本站会在您捐赠本站后显示隐藏内容,请知悉,先非常感谢您对本站的捐赠;
(5)本站支付使用Payjs,该第三方支付方式为微信官方授权的服务商,无支付风险,详情请查看:https://payjs.cn
(6)请尽量不要使用手机浏览器以及电脑浏览器的无痕模式进行支付操作,以免造成支付成功但未显示隐藏内容。
(7)点击立即购买按钮后弹出选择支付方式页面,选择任意支付方式点击后会跳转到新的二维码支付页面,支付成功后会弹出支付成功的提示框,点击提示框会自动刷新页面显示隐藏内容;另外请不要重复支付,避免财产损失;
(8)在2021年7月27日前,本站采用注册+登录+评论的免费下载模式,旨在节省大家寻找宝贵资源的时间,为大家带来珍贵的知识来源,但是从2021年7月27日起,因遭受注册轰炸和恶意爬虫造成网站负载过大导致宕机,被迫无奈,为减少网站运营时间成本,对部分资源进行捐赠下载,添加支付是反爬虫的最好方式,在此对未享受到免费下载福利的访客表示歉意;
(9)如遇支付页面未弹出、支付成功但未显示隐藏内容、资源链接失效或者提取码出错等情况请发送邮件到stubbornhuang@qq.com或者直接联系QQ:623256052,会尽快为您解决!加我时请备注原因,谢谢!或者点击按钮点击反馈进入反馈页面进行问题反馈
(10)由以上捐赠下载带来的不便请您谅解,如出现重复付费的情况,请联系我,我会尽快返回您的退款!