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

2023-10-28 18:48

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

OFB是一种加密模式。CFB和OFC工作模式中,密码算法象流密码一样生产出密钥流供异或名密文用。

参考文献

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

OFB 加密

I1 = IV;

Ij = Oj -1       for j = 2 … n;

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

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

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

OFB 解密

I1 = IV;

Ij = Oj -1       for j = 2 … n;

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

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

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

OFB模式

  1. LibTomCrypt与OFB

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

typedef struct {

int cipher;

int blocklen;

int padlen;

unsigned char IV[MAXBLOCKSIZE];

symmetric_key key;

} symmetric_OFB;

int ofb_start(int cipher, const unsigned char *IV, const unsigned char *key, int keylen, int num_rounds, symmetric_OFB *ofb);

int ofb_encrypt(const unsigned char *pt, unsigned char *ct, unsigned long len, symmetric_OFB *ofb);

int ofb_decrypt(const unsigned char *ct, unsigned char *pt, unsigned long len, symmetric_OFB *ofb);

int ofb_getiv(unsigned char *IV, unsigned long *len, symmetric_OFB *ofb);

int ofb_setiv(const unsigned char *IV, unsigned long len, symmetric_OFB *ofb);

int ofb_done(symmetric_OFB *ofb);

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

int ofb_start(int cipher, const unsigned char *IV, const unsigned char *key, int keylen, int num_rounds, symmetric_OFB *ofb);

// [功能]   初始化

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

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

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

int ofb_encrypt(const unsigned char *pt, unsigned char *ct, unsigned long len, symmetric_OFB *ofb);

// [功能]   CBC加密

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

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

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

int ofb_decrypt(const unsigned char *ct, unsigned char *pt, unsigned long len, symmetric_OFB *ofb);

// [功能]   CBC解密

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

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

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

int ofb_getiv(unsigned char *IV, unsigned long *len, symmetric_OFB *ofb);

// [功能]   获取IV值

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

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

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

int ofb_setiv(const unsigned char *IV, unsigned long len, symmetric_OFB *ofb);

// [功能]   设置IV值

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

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

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

int ofb_done(symmetric_OFB *ofb);

// [功能]   完成OFB

  1. ofb          // [输入/输出] OFB状态

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

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



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

相关文章

电脑密码怎么设置? 一文读懂电脑密码的详细指南

《电脑密码怎么设置?一文读懂电脑密码的详细指南》为了保护个人隐私和数据安全,设置电脑密码显得尤为重要,那么,如何在电脑上设置密码呢?详细请看下文介绍... 设置电脑密码是保护个人隐私、数据安全以及系统安全的重要措施,下面以Windows 11系统为例,跟大家分享一下设置电脑密码的具体办php法。Windo

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

使用C#如何创建人名或其他物体随机分组

《使用C#如何创建人名或其他物体随机分组》文章描述了一个随机分配人员到多个团队的代码示例,包括将人员列表随机化并根据组数分配到不同组,最后按组号排序显示结果... 目录C#创建人名或其他物体随机分组此示例使用以下代码将人员分配到组代码首先将lstPeople ListBox总结C#创建人名或其他物体随机分组