Ubuntu环境下,使用clion编译器,使用开源opensll的对称AES算法对于文件进行加密,C++代码

前提准备条件

  • 需要安装openssl
  • 需要安装openssl-dev
  • 需要配置CMakeLists.txt文件
  • 集体内容可以参考我提供的相关参考链接

AES_file.h

#include <openssl/aes.h>
#include <iostream>
#include <fstream>
#include <cstring>#define RELEASE_ARRAY(P) if (P)  \
{                                \delete[] P;                  \P = NULL;                    \
}class AES{
public:// AES文件加密函数 ///int TestAesEncryptFile(std::string original_backup_file_path, std::string backup_dir_path, std::string &password){int encrypt_chunk_size = 16;std::ifstream original_backup_file(original_backup_file_path.c_str(), std::ios::binary);std::ofstream backup_dir(backup_dir_path, std::ios::binary);if (!original_backup_file){std::cout << "Can not open original_backup_file file." << std::endl;return 1;}if (!backup_dir){std::cout << "Can not open backup_dir_path file." << std::endl;return 1;}//用指定密钥对一段内存进行加密,结果放在outbuffer中unsigned char aes_keybuf[32];memset(aes_keybuf, 0, sizeof(aes_keybuf));strcpy((char *)aes_keybuf, password.c_str());AES_KEY aeskey;AES_set_encrypt_key(aes_keybuf, 256, &aeskey);char *in_data = new char[encrypt_chunk_size + 1];char *out_data = new char[encrypt_chunk_size + 1];while (!original_backup_file.eof()){original_backup_file.read(in_data, encrypt_chunk_size);if (original_backup_file.gcount() < encrypt_chunk_size){backup_dir.write(in_data, original_backup_file.gcount());}else{AES_encrypt((const unsigned char *)in_data, (unsigned char *)out_data, &aeskey);backup_dir.write(out_data, original_backup_file.gcount());}};backup_dir.close();original_backup_file.close();RELEASE_ARRAY(in_data);RELEASE_ARRAY(out_data);return 0;}// AES文件解密函数 //int TestAesDecryptFile(std::string in_file_path, std::string out_file_path, std::string &password){int encrypt_chunk_size = 16;std::ifstream original_backup_file(in_file_path.c_str(), std::ios::binary);std::ofstream backup_dir(out_file_path, std::ios::binary);if (!original_backup_file){std::cout << "Can not open original_backup_file file." << std::endl;return 1;}if (!backup_dir){std::cout << "Can not open backup_dir file." << std::endl;return 1;}//用指定密钥对一段内存进行加密,结果放在outbuffer中unsigned char aes_keybuf[32];memset(aes_keybuf, 0, sizeof(aes_keybuf));strcpy((char *)aes_keybuf, password.c_str());AES_KEY aeskey;AES_set_decrypt_key(aes_keybuf, 256, &aeskey);char *in_data = new char[encrypt_chunk_size + 1];char *out_data = new char[encrypt_chunk_size + 1];while (!original_backup_file.eof()){original_backup_file.read(in_data, encrypt_chunk_size);if (original_backup_file.gcount() < encrypt_chunk_size){backup_dir.write(in_data, original_backup_file.gcount());}else{AES_decrypt((unsigned char *)in_data, (unsigned char *)out_data, &aeskey);backup_dir.write(out_data, original_backup_file.gcount());}};backup_dir.close();original_backup_file.close();RELEASE_ARRAY(in_data);RELEASE_ARRAY(out_data);return 0;}
};

main.cpp

#include <iostream>
#include "load_or_save_db.h"
#include "include/AES_file.h"int main() {time_t t1, t2, t3, t4;t1 = time(nullptr);printf("加解密起始时间: %s\n", ctime(&t1));std::string password = "xcdf123456";AES aes;// 数据开始加密aes.TestAesEncryptFile("/home/gsc/Projects/1.txt", "/home/gsc/Projects/2.txt", password);t2 = time(nullptr);printf("AES256加密成功!\n");printf("加密用时: %ld秒\n", (t2 - t1));t3 = time(NULL);// 数据开始解密aes.TestAesDecryptFile("/home/gsc/Projects/2.txt", "/home/gsc/Projects/3.txt", password);t4 = time(NULL);printf("AES256解密成功!\n");printf("解密用时: %lld秒\n", (t4 - t3));return 0;
}

参考链接

  • C++: 基于OpenSSL的AES256加解密测试
  • clion中链接openssl库

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/446964.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java提高篇 —— Java关键字之static的四种用法

一、前言 在java的关键字中&#xff0c;static和final是两个我们必须掌握的关键字。不同于其他关键字&#xff0c;他们都有多种用法&#xff0c;而且在一定环境下使用&#xff0c;可以提高程序的运行性能&#xff0c;优化程序的结构。下面我们先来了解一下static关键字及其用法…

C++ 使用move来删除用户指定的文件

代码 #include <iostream>bool remove_file(std::string path){if (remove(path.c_str())0){std::cout << "success!" << std::endl;}else{std::cout << "False!" << std::endl;} } int main() {std::string path "/…

Java提高篇 —— Java关键字之final的几种用法

一、前言 在java的关键字中&#xff0c;static和final是两个我们必须掌握的关键字。不同于其他关键字&#xff0c;他们都有多种用法&#xff0c;而且在一定环境下使用&#xff0c;可以提高程序的运行性能&#xff0c;优化程序的结构。下面我们来了解一下final关键字及其用法。 …

使用C++的方式实现AES算法

aes_file.h #include <iostream> #include <fstream> #include <bitset> #include <string> using namespace std; typedef bitset<8> byte; typedef bitset<32> word;const int Nr 10; // AES-128需要 10 轮加密 const int Nk 4; /…

Java提高篇 —— Java三大特性之封装

一、封装 封装从字面上来理解就是包装的意思&#xff0c;专业点就是信息隐藏&#xff0c;是指利用抽象数据类型将数据和基于数据的操作封装在一起&#xff0c;使其构成一个不可分割的独立实体&#xff0c;数据被保护在抽象数据类型的内部&#xff0c;尽可能地隐藏内部的细节&am…

sqlite3的backup和restore函数的使用

参考代码 第一段这个亲测可以使用 #include <sqlite3.h> #include <iostream> /* ** Perform an online backup of database pDb to the database file named ** by zFilename. This function copies 5 database pages from pDb to ** zFilename, then unlocks pD…

Java提高篇 —— Java三大特性之继承

一、前言 在《Think in java》中有这样一句话&#xff1a;复用代码是Java众多引人注目的功能之一。但要想成为极具革命性的语言&#xff0c;仅仅能够复制代码并对加以改变是不够的&#xff0c;它还必须能够做更多的事情。在这句话中最引人注目的是“复用代码”,尽可能的复用代码…

Java提高篇 —— Java三大特性之多态

一、前言 面向对象编程有三大特性&#xff1a;封装、继承、多态。 封装&#xff1a;隐藏了类的内部实现机制&#xff0c;可以在不影响使用的情况下改变类的内部结构&#xff0c;同时也保护了数据。对外界而已它的内部细节是隐藏的&#xff0c;暴露给外界的只是它的访问方法。 继…

光盘刻录制作Ubuntu等操作系统的启动盘

前提条件 软媒刻录 空白光盘&#xff08;至少4.7G&#xff09;电脑&#xff08;最好使用外置的光驱&#xff09;系统镜像&#xff08;ISO格式&#xff09; 具体操作 打开软媒魔方选择光盘刻录按照标红的进行选择选择镜像->选择或者拖拽都可以选择刻录机->如果使用外部刻…

Java提高篇 —— 抽象类与接口

一、前言 接口和内部类为我们提供了一种将接口与实现分离的更加结构化的方法。 抽象类与接口是java语言中对抽象概念进行定义的两种机制&#xff0c;正是由于他们的存在才赋予java强大的面向对象的能力。他们两者之间对抽象概念的支持有很大的相似&#xff0c;甚至可以互换&…

C++ const相关内容学习

const 作用 修饰变量&#xff0c;说明变量不可以被修改修饰指针&#xff0c;分为指向常量的指针&#xff08;pointer to const&#xff09;和自身是常量的指针&#xff08;常量指针&#xff0c;const pointer&#xff09;修饰引用&#xff0c;指向常量的引用&#xff08;refe…

Java提高篇 —— Java浅拷贝和深拷贝

一、前言 我们知道在Java中存在这个接口Cloneable&#xff0c;实现该接口的类都会具备被拷贝的能力&#xff0c;同时拷贝是在内存中进行&#xff0c;在性能方面比我们直接通过new生成对象来的快&#xff0c;特别是在大对象的生成上&#xff0c;使得性能的提升非常明显。然而我们…

openssl里面AES算法主要函数的参数的介绍

注意事项 使用API的时候&#xff0c;需要特别小心数据长度&#xff0c;一般没有指定长度的参数&#xff0c;默认都是16&#xff08;AES_BLOCK_SIZE&#xff09;个字节。输出数据的长度一般都是16字节的倍数&#xff0c;否则会出现数组越界访问。以下API中&#xff0c;encrypt表…

Java提高篇 —— Java内部类详解

一、简介 内部类是一个非常有用的特性但又比较难理解使用的特性。 内部类我们从外面看是非常容易理解的&#xff0c;无非就是在一个类的内部在定义一个类。 public class OuterClass {private String name ;private int age;public String getName() {return name;}public voi…

Ubuntu修改界面的大小

命令 xrandr 就会显示ubuntu支持的屏幕比例使用命令 xrandr --size 1680x1050 切换屏幕大小

Java提高篇 —— String缓冲池

一、String缓冲池 首先我们要明确&#xff0c;String并不是基本数据类型&#xff0c;而是一个对象&#xff0c;并且是不可变的对象。查看源码就会发现String类为final型的&#xff08;当然也不可被继承&#xff09;&#xff0c;而且通过查看JDK文档会发现几乎每一个修改String对…

C++最新使用开源openssl实现输入是文件,输出是文件的AES加解密的代码

AES.h头文件 #include <cstring> #include <fstream> #include <iostream> #include <openssl/aes.h>//AES文件加密函数 int aes_encrypt_file(const std::string &original_backup_file_path,const std::string &encrypted_file_path,const …

Java基础 —— JVM内存模型与垃圾回收

目录一、概述二、运行时数据区方法区运行时常量池堆栈本地方法栈程序计数器三、对象访问四、垃圾回收如何定义垃圾1、引用计数法2、可达性分析垃圾回收方法1、Mark-Sweep标记-清除算法2、Copying复制算法3、Mark-Compact标记-整理算法4、Generational Collection 分代收集垃圾收…

Report Design

ERP_ENT_STD-CSDN博客

规范化流程化提交自己代码到远程gitlab服务器

流程 进入到build目录使用make命令进行编译 make -j 6&#xff0c;前提是cmake命令已经执行../format.py rungit add .. 添加文件git checkout -b xxx 创建xxx分支&#xff0c;其中xxx是分支名字git branch 查看分支git commit -m "[chy/backup] modify parameters for…