当前位置: 首页 > news >正文

openssl + 3DES开发实例(linux)

文章目录

  • 一、3DES介绍
      • 3DES 的特点:
      • 3DES 加密的步骤:
      • 3DES 的应用场景:
  • 二、3DES原理
      • 1. DES 原理回顾:
      • 2. 3DES 原理:
      • 3. 3DES 的加密流程:
  • 三、openssl + 3DES开发实例

一、3DES介绍

3DES(Triple DES)是对称密钥加密算法,也被称为DESede(DES加强版)。它是对DES(Data Encryption Standard)的一种改进和加强,旨在提高 DES 的安全性。

3DES 的特点:

  1. 密钥长度: 3DES 使用三个 56 位的密钥,总共 168 位。这是 DES 的三倍密钥长度。实际上,密钥长度可以分别设置,如使用两个相同的密钥也是一种形式的3DES。

  2. 运算模式: 3DES 可以采用不同的运算模式,如 ECB(Electronic Codebook)、CBC(Cipher Block Chaining)等,以满足不同的需求。

  3. 加密过程: 3DES 的加密过程可以简单描述为 E(K1, D(E(K2, E(K3, plaintext)))),其中 K1、K2、K3 是三个密钥,E 表示加密,D 表示解密。这样的嵌套结构提高了加密的安全性。

3DES 加密的步骤:

  1. 初始置换(Initial Permutation): 明文经过初始置换,位被重新排列。

  2. 分组和迭代: 明文被分成块,然后经过一系列的迭代。每个迭代都包括替代、置换和异或等运算。

  3. 密钥扩展: 初始密钥被扩展成三个子密钥。

  4. 加密/解密: 使用三个子密钥对明文进行加密,或者使用三个子密钥对密文进行解密。

  5. 最终置换(Final Permutation): 最后,通过最终置换将得到的密文重新排列,形成最终结果。

3DES 的应用场景:

  1. 数据传输安全: 3DES 可以用于保护敏感数据在网络上的传输,确保数据的机密性。

  2. 金融领域: 在金融领域,特别是在支付系统中,3DES 被广泛应用以确保交易的安全性。

  3. 加密通信: 3DES 可以用于保护通信渠道中的敏感信息,如虚拟私人网络(VPN)等。

尽管3DES提供了一定程度的安全性,但由于其计算量大、效率低,而且密钥长度相对较短,因此在现代应用中,更常见的是使用更先进的对称加密算法,例如 AES(Advanced Encryption Standard)。

二、3DES原理

Triple DES(3DES)是对称密钥加密算法,它基于 DES 加密算法的一种改进。下面是 3DES 的基本原理:

1. DES 原理回顾:

  • DES 使用一个 64 位的明文块和一个 56 位的密钥。首先,明文经过初始置换(Initial Permutation),然后被分成左半部分(L0)和右半部分(R0)。

  • DES 使用 Feistel 置换结构,在每一轮中,右半部分经过一系列的替代、置换和异或运算,然后与左半部分进行异或。这产生新的右半部分和新的左半部分。

  • 迭代过程重复16轮,最后通过最终置换(Final Permutation)将左右两部分重新排列,形成加密结果。

2. 3DES 原理:

  • 3DES 使用三个 56 位的密钥,通常称为 K1、K2、K3。它可以采用不同的模式,其中最常见的是 EDE 模式(Encrypt-Decrypt-Encrypt)。

  • 在 EDE 模式中,明文经过第一次加密(E1),然后解密(D2),最后再加密(E3)。这个过程可以简单表示为:Ciphertext = E3(D2(E1(Plaintext)))。

  • 3DES 的迭代过程类似于 DES,但是有更多的密钥和更复杂的操作。

  • 在 EDE 模式下,如果 K1、K2、K3 是相同的,那么它等同于 DES。如果 K1、K2 不同,但 K3 = K1,那么它提供了两次 DES 加密的安全性。如果 K1、K2、K3 都不同,那么它提供了更高的安全性。

3. 3DES 的加密流程:

  1. 初始置换: 明文经过初始置换,位被重新排列。

  2. 分组和迭代: 明文被分成块,然后经过一系列的迭代。每个迭代包括替代、置换和异或等运算。

  3. 密钥扩展: 初始密钥被扩展成三个子密钥。

  4. 加密/解密: 使用三个子密钥对明文进行加密,或者使用三个子密钥对密文进行解密。

  5. 最终置换: 通过最终置换将得到的密文重新排列,形成最终结果。

3DES 的安全性主要来自密钥的长度和迭代的次数,使得密码分析者需要耗费更多的计算资源来破解密码。尽管 3DES 提供了一定程度的安全性,但由于计算量大和效率低,现代应用更倾向于使用先进的加密算法,如 AES。

三、openssl + 3DES开发实例

使用 OpenSSL 进行 3DES(Triple DES,也称为 DESede)加密和解密的实例与 DES 类似,只是需要设置更长的密钥。以下是一个简单的 C++ 示例代码,假设你已经安装了 OpenSSL 库:

#include <iostream>
#include <openssl/des.h>void des3_encrypt(const unsigned char *input, unsigned char *output, const DES_key_schedule &ks1, const DES_key_schedule &ks2, const DES_key_schedule &ks3) {DES_ecb3_encrypt(input, output, &ks1, &ks2, &ks3, DES_ENCRYPT);
}void des3_decrypt(const unsigned char *input, unsigned char *output, const DES_key_schedule &ks1, const DES_key_schedule &ks2, const DES_key_schedule &ks3) {DES_ecb3_encrypt(input, output, &ks1, &ks2, &ks3, DES_DECRYPT);
}int main() {// 设置密钥const char *key_str = "0123456789abcdef0123456789abcdef0123456789abcdef";DES_cblock key1, key2, key3;DES_key_schedule ks1, ks2, ks3;memcpy(key1, key_str, 8);memcpy(key2, key_str + 8, 8);memcpy(key3, key_str + 16, 8);DES_set_key_unchecked(&key1, &ks1);DES_set_key_unchecked(&key2, &ks2);DES_set_key_unchecked(&key3, &ks3);// 待加密的数据const unsigned char plaintext[8] = "12345678";unsigned char ciphertext[8];unsigned char decryptedtext[8];// 加密des3_encrypt(plaintext, ciphertext, ks1, ks2, ks3);std::cout << "Ciphertext: ";for (int i = 0; i < 8; ++i) {std::cout << std::hex << (int)ciphertext[i];}std::cout << std::endl;// 解密des3_decrypt(ciphertext, decryptedtext, ks1, ks2, ks3);std::cout << "Decrypted text: " << decryptedtext << std::endl;return 0;
}

这个例子中,我们使用了 24 字节的密钥,分为三个 8 字节的子密钥。密钥的设置和使用方式与 DES 类似。编译时需要链接 OpenSSL 库,命令类似于之前的例子。

请注意,与 DES 相比,3DES 提供了更高的安全性,但由于其复杂性和较慢的运算速度,现代应用中更常使用 AES 等算法。

相关文章:

openssl + 3DES开发实例(linux)

文章目录 一、3DES介绍3DES 的特点&#xff1a;3DES 加密的步骤&#xff1a;3DES 的应用场景&#xff1a; 二、3DES原理1. DES 原理回顾&#xff1a;2. 3DES 原理&#xff1a;3. 3DES 的加密流程&#xff1a; 三、openssl 3DES开发实例 一、3DES介绍 3DES&#xff08;Triple …...

遵循开源软件安全路线图

毫无疑问&#xff0c;开源软件对于满足联邦任务所需的开发和创新至关重要&#xff0c;因此其安全性至关重要。 OSS&#xff08;运营支持系统&#xff09; 支持联邦政府内的每个关键基础设施部门。 联邦政府认识到这一点&#xff0c;并正在采取措施优先考虑 OSS 安全&#xff…...

294_C++_

1、全部大致解析: struct alarminfo_t {unsigned int alarmid;INTF_ALARM_INFO_S pAlarm; };typedef enum{INTF_IO_ALARM_E= 0, //I/O探头告警开始INTF_MOTION_ALARM_E, //移动侦测告警开始INTF_AI_ALARM_E,...

【计算机网络笔记】网络地址转换(NAT)

系列文章目录 什么是计算机网络&#xff1f; 什么是网络协议&#xff1f; 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能&#xff08;1&#xff09;——速率、带宽、延迟 计算机网络性能&#xff08;2&#xff09;…...

【flink理论】动态表:关系查询处理流的思路:连续查询、状态维护;表转换为流需要编码编码

文章目录 一. 使用关系查询处理流的讨论二. 动态表 & 连续查询(Continuous Query)三. 在流上定义表1. 连续查询2. 查询限制2.1. 维护状态2.2. 计算更新 四. 表到流的转换1. Append-only 流2. Retract 流3. Upsert 流 本文主要讨论了&#xff1a; 讨论通过关系查询处理无界流…...

2023年09月 Python(六级)真题解析#中国电子学会#全国青少年软件编程等级考试

Python等级考试(1~6级)全部真题・点这里 一、单选题(共25题,每题2分,共50分) 第1题 以下选项中,不是tkinter变量类型的是?( ) A: IntVar() B: StringVar() C: DoubleVar() D: FloatVar() 答案:D tkinter 无 FloatVar()变量类型。 第2题 关于tkinter,以下说…...

Ubuntu16.04上安装Docker

Ubuntu16.04上安装Docker 更新 apt 包索引: sudo apt-get update安装依赖包,以便使用 HTTPS 仓库 sudo apt-get install apt-transport-https ca-certificates curl software-properties-common添加 Docker GPG 密钥 curl -fsSL https://download.docker.com/linux/ubuntu…...

FSOD论文阅读 - 基于卷积和注意力机制的小样本目标检测

来源:知网 标题:基于卷积和注意力机制的小样本目标检测 作者:郭永红&#xff0c;牛海涛&#xff0c;史超&#xff0c;郭铖 郭永红&#xff0c;牛海涛&#xff0c;史超&#xff0c;郭铖&#xff0e;基于卷积和注意力机制的小样本目标检测 [J/OL]&#xff0e;兵工学报. https://…...

Windows系统中搭建docker (ubuntu,Docker-desktop)

一、docker安装前的准备工作 1. 开启CPU虚拟化&#xff0c;新电脑该默认是开启的&#xff0c;如果没开启可以根据自己电脑型号品牌搜索如克开启CPU虚拟化。当开启成功后可在设备管理器中看到。 2.开通Hyper-V 通过 Windows 控制面板 --> 程序和功能 -->启用或关闭…...

使用记录-MongoDB

find常用方法 在 MongoDB 的 find 方法中&#xff0c;可以使用各种查询操作符来执行不同类型的查询。其中之一是 $in 操作符&#xff0c;它用于在一个字段中匹配多个值。 $eq 操作符&#xff1a; 用于匹配字段值等于指定值的文档。 // 查询 age 字段等于 25 的文档 db.colle…...

用归并排序算法merge_sort( )求解 逆序对的数量 降低时间复杂度为 nlogn

题目简述 给定一个序列有n个数&#xff0c;求n个数中逆序对的个数&#xff0c;逆序对的定义&#xff1a;i < j && a[i] > a[j]。 输入格式 第一行包含一个整数n。 第二行包含 n 个整数&#xff08;所有整数均在1~1e9范围内&#xff09;&#xff0c;表示整数数…...

大功率电源芯片WD5030L

电源管理芯片作为现代电子设备中最关键的元件之一&#xff0c;直接影响着设备的性能和效率。而大功率电源芯片作为电源管理芯片中的一种&#xff0c;其性能和应用领域更加广泛。本文将介绍一款具有宽VIN输入范围、高效率和多种优良性能的大功率电源芯片WD5030L&#xff0c;并探…...

Spring Boot使用EhCache完成一个缓存集群

在上一篇在SpringBoot中使用EhCache缓存&#xff0c;我们完成了在Spring Boot中完成了对EhCaChe的使用&#xff0c;这篇&#xff0c;我们将对EhCache的进一步了解&#xff0c;也就是搭建一个EhCache的缓存集群。 集群 在搭建一个EhCache的时候&#xff0c;我们需要先了解&…...

yolov5模型代码怎么修改

yaml配置文件 深度乘积因子 宽度乘积因子 所有版本只有这两个参数的不同&#xff0c;s m l x逐渐加宽加深 各种类型层参数对照 backbone里的各层&#xff0c;在这里解析&#xff0c;只需要改.yaml里的各层参数就能控制网络结构 修改网络结构 第一步&#xff1a;把新加的模块…...

VIM去掉utf-8 bom头

Windows系统的txt文件在使用utf-8编码保存时会默认在文件开头插入三个不可见的字符&#xff08;0xEF 0xBB 0xBF&#xff09;称为BOM头 BOM头文件 0.加上BOM标记&#xff1a; :set bomb 1.查询当前UTF-8编码的文件是否有BOM标记&#xff1a; :set bomb? :set bomb? 2.BOM头:文…...

Go 使用Viper处理Go应用程序的配置

在开发Go应用程序时&#xff0c;处理配置是一个常见的需求。配置可能来自于配置文件、环境变量、命令行参数等等。Viper是一个强大的库&#xff0c;可以帮助我们处理这些配置。 什么是Viper&#xff1f; Viper是一个应用程序配置解决方案&#xff0c;用于Go应用程序。它支持JS…...

hadoop安装网址

Hadoop是什么 1&#xff09;Hadoop是一个有Apache基金会所开发的分布式系统基础架构。 2&#xff09;主要解决海量数据的存储和海量数据的分析计算问题。 3&#xff09;广义上来说&#xff0c;Hadoop通常是指一个更广泛的概念---Hadoop生态圈。 Hadoop发行版本 Hadoop发行的…...

JavaMail邮件发送服务

记录一次使用基于SpringBoot来设置发送邮件的服务 导入依赖 <!--邮件发送--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-mail</artifactId><version>${springboot.version}</ve…...

【918.环形子数组的最大和】

目录 一、题目描述二、算法原理三、代码实现 一、题目描述 二、算法原理 三、代码实现 class Solution { public:int maxSubarraySumCircular(vector<int>& nums) {int sum0;for(auto x:nums) sumx;vector<int> f(nums.size());vector<int> g(nums.size…...

Unity Quaternion接口API的常用方法解析_unity基础开发教程

Quaternion接口的常用方法 Quaternion.Euler()Quaternion.Lerp()Quaternion.Inverse()Quaternion.RotateTowards() Quaternion在Unity中是一种非常重要的数据类型&#xff0c;用于表示3D空间中的旋转。Quaternion可以表示任何旋转&#xff0c;无论是在哪个轴上旋转多少度&#…...

label-studio的使用教程(导入本地路径)

文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…...

shell脚本--常见案例

1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件&#xff1a; 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...

centos 7 部署awstats 网站访问检测

一、基础环境准备&#xff08;两种安装方式都要做&#xff09; bash # 安装必要依赖 yum install -y httpd perl mod_perl perl-Time-HiRes perl-DateTime systemctl enable httpd # 设置 Apache 开机自启 systemctl start httpd # 启动 Apache二、安装 AWStats&#xff0…...

DeepSeek 技术赋能无人农场协同作业:用 AI 重构农田管理 “神经网”

目录 一、引言二、DeepSeek 技术大揭秘2.1 核心架构解析2.2 关键技术剖析 三、智能农业无人农场协同作业现状3.1 发展现状概述3.2 协同作业模式介绍 四、DeepSeek 的 “农场奇妙游”4.1 数据处理与分析4.2 作物生长监测与预测4.3 病虫害防治4.4 农机协同作业调度 五、实际案例大…...

回溯算法学习

一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...

Docker 本地安装 mysql 数据库

Docker: Accelerated Container Application Development 下载对应操作系统版本的 docker &#xff1b;并安装。 基础操作不再赘述。 打开 macOS 终端&#xff0c;开始 docker 安装mysql之旅 第一步 docker search mysql 》〉docker search mysql NAME DE…...

Linux 内存管理实战精讲:核心原理与面试常考点全解析

Linux 内存管理实战精讲&#xff1a;核心原理与面试常考点全解析 Linux 内核内存管理是系统设计中最复杂但也最核心的模块之一。它不仅支撑着虚拟内存机制、物理内存分配、进程隔离与资源复用&#xff0c;还直接决定系统运行的性能与稳定性。无论你是嵌入式开发者、内核调试工…...

elementUI点击浏览table所选行数据查看文档

项目场景&#xff1a; table按照要求特定的数据变成按钮可以点击 解决方案&#xff1a; <el-table-columnprop"mlname"label"名称"align"center"width"180"><template slot-scope"scope"><el-buttonv-if&qu…...

vue3 daterange正则踩坑

<el-form-item label"空置时间" prop"vacantTime"> <el-date-picker v-model"form.vacantTime" type"daterange" start-placeholder"开始日期" end-placeholder"结束日期" clearable :editable"fal…...

工厂方法模式和抽象工厂方法模式的battle

1.案例直接上手 在这个案例里面&#xff0c;我们会实现这个普通的工厂方法&#xff0c;并且对比这个普通工厂方法和我们直接创建对象的差别在哪里&#xff0c;为什么需要一个工厂&#xff1a; 下面的这个是我们的这个案例里面涉及到的接口和对应的实现类&#xff1a; 两个发…...