密码库LibTomCrypt学习记录——(2.6)分组密码算法的工作模式——CFB模式

2023-10-28 18:48

本文主要是介绍密码库LibTomCrypt学习记录——(2.6)分组密码算法的工作模式——CFB模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CFB是一种加密模式。密文被反馈当寄存器中为下一个块服务。CFB和OFC工作模式中,密码算法象流密码一样生产出密钥流供异或名密文用。

参考文献

  1. NIST SP 800-38A
  1. CFB加解密

记:

  1. b为分组的比特大小,比如AES时b=128;
  2. s为寄存器中保留上P一个密文的比特长度,1<=s<=b;s通常为1、8、64、128。
  3. P#j ,C#j是明文和密文的一个片段,长s比特。

CFB 加密

I1 = IV;

Ij = LSBb-s(Ij –1) || C#j -1      for j = 2 … n;

Oj = CIPHK(Ij)              for j = 1, 2 … n;

C#j = P#j ⊕ MSBs(Oj)         for j = 1, 2 … n.

CFB 解密

I1 = IV;

Ij = LSBb-s(Ij –1) || C#j -1      for j = 2 … n;

Oj = CIPHK(Ij)              for j = 1, 2 … n;

P#j = C#j ⊕ MSBs(Oj)         for j = 1, 2 … n.

CFB模式

  1. LibTomCrypt与CFB

LibTomCrypt中与CFB相关的信息如下:

typedef struct {

int cipher;

int blocklen;

int padlen;

unsigned char IV[MAXBLOCKSIZE];

unsigned char pad[MAXBLOCKSIZE];

symmetric_key key;// 扩展密钥

} symmetric_CFB;

int cfb_start(int cipher, const unsigned char *IV, const unsigned char *key, int keylen, int num_rounds, symmetric_CFB *cfb);

int cfb_encrypt(const unsigned char *pt, unsigned char *ct, unsigned long len, symmetric_CFB *cfb);

int cfb_decrypt(const unsigned char *ct, unsigned char *pt, unsigned long len, symmetric_CFB *cfb);

int cfb_getiv(unsigned char *IV, unsigned long *len, symmetric_CFB *cfb);

int cfb_setiv(const unsigned char *IV, unsigned long len, symmetric_CFB *cfb);

int cfb_done(symmetric_CFB *cfb);

──────────────────────────────────────

int cfb_start(int cipher, const unsigned char *IV, const unsigned char *key, int keylen, int num_rounds, symmetric_CFB *cfb)

// [功能]   初始化

  1. IV           // [输入] 初始化向量
  2. key              // [输入] 密钥
  3. keylen     // [输入] 密钥长度
  4. num_rounds  // [输入] 轮数(建议设置为0以便让系统使用默认值)
  5. cfb          // [输入/输出] CFB状态

──────────────────────────────────────

──────────────────────────────────────

int cfb_encrypt(const unsigned char *pt, unsigned char *ct, unsigned long len, symmetric_CFB *cfb)

// [功能]   CBC加密

  1. pt           // [输入] 明文
  2. ct            // [输出] 密文
  3. len          // [输入] 明文密文长度
  4. cfb          // [输入/输出] CFB状态

──────────────────────────────────────

──────────────────────────────────────

int cfb_decrypt(const unsigned char *ct, unsigned char *pt, unsigned long len, symmetric_CFB *cfb);

// [功能]   CBC解密

  1. ct            // [输入] 密文
  2. pt           // [输出] 明文
  3. len          // [输入] 明文密文长度
  4. cfb          // [输入/输出] CFB状态

──────────────────────────────────────

──────────────────────────────────────

int cfb_getiv(unsigned char *IV, unsigned long *len, symmetric_CFB *cfb);

// [功能]   获取IV值

  1. IV           // [输出] IV值
  2. len          // [输出] IV值长度
  3. cfb          // [输入/输出] CFB状态

──────────────────────────────────────

──────────────────────────────────────

int cfb_setiv(const unsigned char *IV, unsigned long len, symmetric_CFB *cfb);

// [功能]   设置IV值

  1. IV           // [输入] IV值
  2. len          // [输入] IV值长度
  3. cfb          // [输入/输出] CFB状态

──────────────────────────────────────

──────────────────────────────────────

int cfb_done(symmetric_CFB *cfb);

// [功能]   完成CBC

  1. cfb          // [输入/输出] CFB状态

──────────────────────────────────────

这篇关于密码库LibTomCrypt学习记录——(2.6)分组密码算法的工作模式——CFB模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/295213

相关文章

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

PostgreSQL数据库密码被遗忘时的操作步骤

《PostgreSQL数据库密码被遗忘时的操作步骤》密码遗忘是常见的用户问题,因此提供一种安全的遗忘密码找回机制是十分必要的,:本文主要介绍PostgreSQL数据库密码被遗忘时的操作步骤的相关资... 目录前言一、背景知识二、Windows环境下的解决步骤1. 找到PostgreSQL安装目录2. 修改p

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项