本文主要是介绍密码库LibTomCrypt学习记录——(2.6)分组密码算法的工作模式——CFB模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
CFB是一种加密模式。密文被反馈当寄存器中为下一个块服务。CFB和OFC工作模式中,密码算法象流密码一样生产出密钥流供异或名密文用。
参考文献
- NIST SP 800-38A
- CFB加解密
记:
- b为分组的比特大小,比如AES时b=128;
- s为寄存器中保留上P一个密文的比特长度,1<=s<=b;s通常为1、8、64、128。
- 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模式
- 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)
// [功能] 初始化
- IV // [输入] 初始化向量
- key // [输入] 密钥
- keylen // [输入] 密钥长度
- num_rounds // [输入] 轮数(建议设置为0以便让系统使用默认值)
- cfb // [输入/输出] CFB状态
──────────────────────────────────────
──────────────────────────────────────
int cfb_encrypt(const unsigned char *pt, unsigned char *ct, unsigned long len, symmetric_CFB *cfb)
// [功能] CBC加密
- pt // [输入] 明文
- ct // [输出] 密文
- len // [输入] 明文密文长度
- cfb // [输入/输出] CFB状态
──────────────────────────────────────
──────────────────────────────────────
int cfb_decrypt(const unsigned char *ct, unsigned char *pt, unsigned long len, symmetric_CFB *cfb);
// [功能] CBC解密
- ct // [输入] 密文
- pt // [输出] 明文
- len // [输入] 明文密文长度
- cfb // [输入/输出] CFB状态
──────────────────────────────────────
──────────────────────────────────────
int cfb_getiv(unsigned char *IV, unsigned long *len, symmetric_CFB *cfb);
// [功能] 获取IV值
- IV // [输出] IV值
- len // [输出] IV值长度
- cfb // [输入/输出] CFB状态
──────────────────────────────────────
──────────────────────────────────────
int cfb_setiv(const unsigned char *IV, unsigned long len, symmetric_CFB *cfb);
// [功能] 设置IV值
- IV // [输入] IV值
- len // [输入] IV值长度
- cfb // [输入/输出] CFB状态
──────────────────────────────────────
──────────────────────────────────────
int cfb_done(symmetric_CFB *cfb);
// [功能] 完成CBC
- cfb // [输入/输出] CFB状态
──────────────────────────────────────
这篇关于密码库LibTomCrypt学习记录——(2.6)分组密码算法的工作模式——CFB模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!