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

2023-10-28 18:48

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

CTR是对序列号加密后与明文或者密文异或。这种方式被后面的很多工作模式所采用。

参考文献

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

CTR加密

记每个块用到的计数器为T1,T2,Tn,要求每个计数器值各不相同

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

Cj = Pj ⊕ Oj for j = 1, 2 … n-1;

C*n = P*n ⊕ MSBu(On).

CTR解密

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

Pj = Cj ⊕ Oj for j = 1, 2 … n-1;

P*n = C*n ⊕ MSBu(On).

图 1 CTR模式

  1. LibTomCrypt与CTR

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

typedef struct {

int cipher;                     

int blocklen;

int padlen;

int mode; // 计数器是按大端还是小端存放的,计数器加1时需要

int ctrlen; // 目前让计数器长度和算法的分组大小一样                

unsigned char ctr[MAXBLOCKSIZE],       // 自增计数器                     

unsigned char pad[MAXBLOCKSIZE]; // 计数器对应的被加密后的值

   symmetric_key key;                    // 扩展密钥

} symmetric_CTR;

int ctr_start( int cipher, const unsigned char *IV, const unsigned char *key,  int keylen, int num_rounds, int ctr_mode, symmetric_CTR *ctr);

int ctr_encrypt(const unsigned char *pt, unsigned char *ct, unsigned long len, symmetric_CTR *ctr);

int ctr_decrypt(const unsigned char *ct, unsigned char *pt, unsigned long len, symmetric_CTR *ctr);

int ctr_getiv(unsigned char *IV, unsigned long *len, symmetric_CTR *ctr);

int ctr_setiv(const unsigned char *IV, unsigned long len, symmetric_CTR *ctr);

int ctr_done(symmetric_CTR *ctr);

int ctr_test(void);

注意

按照RFC3686,被加密的Counter Block应该是以下格式

Counter Block(128bit) = Nonce(32bit) || IV(64bit) || BlockCounter(32bit)

BlockCounter为大端表示,从1开始,此后循环累加1。

而程序中为简化操作,采用如下简单格式

Counter Block(128bit) = IV(128bit)

大端或小端均可。Counter Block每次使用前会加1。

详细说明

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

int ctr_start( int cipher, const unsigned char *IV, const unsigned char *key,  int keylen, int num_rounds, int ctr_mode, symmetric_CTR *ctr)

// [功能]   CTR模式初始化

  1. cipher      // [输入] 密码算法索引值
  2. IV           // [输入] 初始化向量(长度为密码算法分组大小)
  3. Key              // [输入] 密钥
  4. keylen      // [输入] 密钥长度(字节)
  5. num_rounds  // [输入] 密码算法轮数(建议设置为0,以使用算法默认轮数)
  6. ctr_mode // [输入] CTR模式(IV大端还是小端表示,是否采用RFC3686)
  7. ctr           // [输出] CTR状态,含扩展密钥及相关信息

// [步骤]

1. 调用密码算法的setup()做密码扩展

2. 调用密码算法的ecb_encrypt()对计数器ctr进行加密

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

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

int ctr_encrypt(const unsigned char *pt, unsigned char *ct, unsigned long len, symmetric_CTR *ctr);

// [功能]   CTR加密

  1. pt           // [输入] 明文
  2. ct            // [输出] 密文
  3. len          // [输入] 明文密文长度
  4. ctr           // [输出] CTR状态,含扩展密钥及相关信息

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

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

int ctr_decrypt(const unsigned char *ct, unsigned char *pt, unsigned long len, symmetric_CTR *ctr);

// [功能]   CTR解密(CTR解密即加密)

  1. ct            // [输出] 密文
  2. pt           // [输入] 明文
  3. len          // [输入] 明文密文长度
  4. ctr           // [输出] CTR状态,含扩展密钥及相关信息

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

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

int ctr_done(symmetric_CTR *ctr);

// [功能]   反初始化(最好能销毁敏感信息)

  1. ctr           // [输入/输出] CTR状态,含扩展密钥及相关信息

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

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

int ctr_test(void);

// [功能]   测试函数

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

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

int ctr_getiv(unsigned char *IV, unsigned long *len, symmetric_CTR *ctr);

// [功能]   获取IV

  1. IV           // [输出] 初始化向量
  2. len          // [输出] 初始化向量长度
  3. ctr           // [输入] CTR状态,含扩展密钥及相关信息

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

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

int ctr_setiv(const unsigned char *IV, unsigned long len, symmetric_CTR *ctr);

// [功能]   设置IV

  1. IV           // [输出] 初始化向量
  2. len          // [输出] 初始化向量长度
  3. ctr           // [输入] CTR状态,含扩展密钥及相关信息

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

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



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

相关文章

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 类(用于

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底

setsid 命令工作原理和使用案例介绍

《setsid命令工作原理和使用案例介绍》setsid命令在Linux中创建独立会话,使进程脱离终端运行,适用于守护进程和后台任务,通过重定向输出和确保权限,可有效管理长时间运行的进程,本文给大家介... 目录setsid 命令介绍和使用案例基本介绍基本语法主要特点命令参数使用案例1. 在后台运行命令2.

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程