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 的特点:
-
密钥长度: 3DES 使用三个 56 位的密钥,总共 168 位。这是 DES 的三倍密钥长度。实际上,密钥长度可以分别设置,如使用两个相同的密钥也是一种形式的3DES。
-
运算模式: 3DES 可以采用不同的运算模式,如 ECB(Electronic Codebook)、CBC(Cipher Block Chaining)等,以满足不同的需求。
-
加密过程: 3DES 的加密过程可以简单描述为 E(K1, D(E(K2, E(K3, plaintext)))),其中 K1、K2、K3 是三个密钥,E 表示加密,D 表示解密。这样的嵌套结构提高了加密的安全性。
3DES 加密的步骤:
-
初始置换(Initial Permutation): 明文经过初始置换,位被重新排列。
-
分组和迭代: 明文被分成块,然后经过一系列的迭代。每个迭代都包括替代、置换和异或等运算。
-
密钥扩展: 初始密钥被扩展成三个子密钥。
-
加密/解密: 使用三个子密钥对明文进行加密,或者使用三个子密钥对密文进行解密。
-
最终置换(Final Permutation): 最后,通过最终置换将得到的密文重新排列,形成最终结果。
3DES 的应用场景:
-
数据传输安全: 3DES 可以用于保护敏感数据在网络上的传输,确保数据的机密性。
-
金融领域: 在金融领域,特别是在支付系统中,3DES 被广泛应用以确保交易的安全性。
-
加密通信: 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 的加密流程:
-
初始置换: 明文经过初始置换,位被重新排列。
-
分组和迭代: 明文被分成块,然后经过一系列的迭代。每个迭代包括替代、置换和异或等运算。
-
密钥扩展: 初始密钥被扩展成三个子密钥。
-
加密/解密: 使用三个子密钥对明文进行加密,或者使用三个子密钥对密文进行解密。
-
最终置换: 通过最终置换将得到的密文重新排列,形成最终结果。
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 的特点:3DES 加密的步骤:3DES 的应用场景: 二、3DES原理1. DES 原理回顾:2. 3DES 原理:3. 3DES 的加密流程: 三、openssl 3DES开发实例 一、3DES介绍 3DES(Triple …...

遵循开源软件安全路线图
毫无疑问,开源软件对于满足联邦任务所需的开发和创新至关重要,因此其安全性至关重要。 OSS(运营支持系统) 支持联邦政府内的每个关键基础设施部门。 联邦政府认识到这一点,并正在采取措施优先考虑 OSS 安全ÿ…...
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)
系列文章目录 什么是计算机网络? 什么是网络协议? 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能(1)——速率、带宽、延迟 计算机网络性能(2)…...

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

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论文阅读 - 基于卷积和注意力机制的小样本目标检测
来源:知网 标题:基于卷积和注意力机制的小样本目标检测 作者:郭永红,牛海涛,史超,郭铖 郭永红,牛海涛,史超,郭铖.基于卷积和注意力机制的小样本目标检测 [J/OL].兵工学报. https://…...

Windows系统中搭建docker (ubuntu,Docker-desktop)
一、docker安装前的准备工作 1. 开启CPU虚拟化,新电脑该默认是开启的,如果没开启可以根据自己电脑型号品牌搜索如克开启CPU虚拟化。当开启成功后可在设备管理器中看到。 2.开通Hyper-V 通过 Windows 控制面板 --> 程序和功能 -->启用或关闭…...
使用记录-MongoDB
find常用方法 在 MongoDB 的 find 方法中,可以使用各种查询操作符来执行不同类型的查询。其中之一是 $in 操作符,它用于在一个字段中匹配多个值。 $eq 操作符: 用于匹配字段值等于指定值的文档。 // 查询 age 字段等于 25 的文档 db.colle…...

用归并排序算法merge_sort( )求解 逆序对的数量 降低时间复杂度为 nlogn
题目简述 给定一个序列有n个数,求n个数中逆序对的个数,逆序对的定义:i < j && a[i] > a[j]。 输入格式 第一行包含一个整数n。 第二行包含 n 个整数(所有整数均在1~1e9范围内),表示整数数…...

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

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

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

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

Go 使用Viper处理Go应用程序的配置
在开发Go应用程序时,处理配置是一个常见的需求。配置可能来自于配置文件、环境变量、命令行参数等等。Viper是一个强大的库,可以帮助我们处理这些配置。 什么是Viper? Viper是一个应用程序配置解决方案,用于Go应用程序。它支持JS…...
hadoop安装网址
Hadoop是什么 1)Hadoop是一个有Apache基金会所开发的分布式系统基础架构。 2)主要解决海量数据的存储和海量数据的分析计算问题。 3)广义上来说,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中是一种非常重要的数据类型,用于表示3D空间中的旋转。Quaternion可以表示任何旋转,无论是在哪个轴上旋转多少度&#…...

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
【磁盘】每天掌握一个Linux命令 - iostat
目录 【磁盘】每天掌握一个Linux命令 - iostat工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景 注意事项 【磁盘】每天掌握一个Linux命令 - iostat 工具概述 iostat(I/O Statistics)是Linux系统下用于监视系统输入输出设备和CPU使…...
电脑插入多块移动硬盘后经常出现卡顿和蓝屏
当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时,可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案: 1. 检查电源供电问题 问题原因:多块移动硬盘同时运行可能导致USB接口供电不足&#x…...

【项目实战】通过多模态+LangGraph实现PPT生成助手
PPT自动生成系统 基于LangGraph的PPT自动生成系统,可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析:自动解析Markdown文档结构PPT模板分析:分析PPT模板的布局和风格智能布局决策:匹配内容与合适的PPT布局自动…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

ardupilot 开发环境eclipse 中import 缺少C++
目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...
CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云
目前已有本地上传、阿里云OSS上传、腾讯云COS上传、七牛云上传扩展 扩展入口文件 文件目录 crmeb\services\upload\Upload.php namespace crmeb\services\upload;use crmeb\basic\BaseManager; use think\facade\Config;/*** Class Upload* package crmeb\services\upload* …...

深度学习习题2
1.如果增加神经网络的宽度,精确度会增加到一个特定阈值后,便开始降低。造成这一现象的可能原因是什么? A、即使增加卷积核的数量,只有少部分的核会被用作预测 B、当卷积核数量增加时,神经网络的预测能力会降低 C、当卷…...
探索Selenium:自动化测试的神奇钥匙
目录 一、Selenium 是什么1.1 定义与概念1.2 发展历程1.3 功能概述 二、Selenium 工作原理剖析2.1 架构组成2.2 工作流程2.3 通信机制 三、Selenium 的优势3.1 跨浏览器与平台支持3.2 丰富的语言支持3.3 强大的社区支持 四、Selenium 的应用场景4.1 Web 应用自动化测试4.2 数据…...
从面试角度回答Android中ContentProvider启动原理
Android中ContentProvider原理的面试角度解析,分为已启动和未启动两种场景: 一、ContentProvider已启动的情况 1. 核心流程 触发条件:当其他组件(如Activity、Service)通过ContentR…...