密码库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

相关文章

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Java中的stream流分组示例详解

《Java中的stream流分组示例详解》Java8StreamAPI以函数式风格处理集合数据,支持分组、统计等操作,可按单/多字段分组,使用String、Map.Entry或Java16record... 目录什么是stream流1、根据某个字段分组2、按多个字段分组(组合分组)1、方法一:使用 Stri

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于