密码库LibTomCrypt学习记录——(2.3)分组密码算法的工作模式——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状态

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

猜你喜欢

转载自blog.csdn.net/samsho2/article/details/84870621
今日推荐