分组密码与模式

什么是分组密码和模式

前面我们讲过了DES和AES算法,他们每次都只能加密固定长度的明文,这样的密码算法叫做分组密码。

如果需要加密更长的明文则需要对分组密码进行迭代。而分组密码的迭代方法就称为分组密码的模式。

本文我们会讲如下几种模式:

  • ECB模式:电子密码本模式
  • CBC模式: 密码分组链接模式
  • CFB模式: 密文反馈模式
  • OFB模式: 输出反馈模式
  • CTR模式: 计数器模式

ECB模式

ECB模式的全称是Electronic CodeBook模式,ECB模式是将明文分组(分组密码算法中作为加密对象的明文)加密之后的结果直接成为密文分组(使用分组加密算法将明文分组加密之后所生成的密文)。

下图为ECB模式的加密:

下图为ECB模式的解密:

ECB模式的特点

ECB模式是最简单的模式,在其中明文和密文是一一对应的,相同的明文会被加密为相同的密文,这样可以通过观察密文得到明文中重复的组合,并以此为线索来破解密码。

ECB模式的攻击

ECB模式中,每个明文对应着相应的密文。 那么攻击者并不需要进行解密,他可以伪造密文的顺序,从而改变了解密出来的明文顺序。

比如 A 转账给B C元。如果A,B,C是明文分组,其对应的密文分组是a,b,c, 则攻击者只需要改变密文的顺序为:b,a,c, 那么被解密出来的明文含义就是 B转账给A C元。

CBC模式

CBC模式的全称是Cipher Block Chaining模式。

CBC模式是将前一个密文分组与当前的明文分组的内容混合起来进行加密的模式。这样可以避免ECB模式的弱点。

CBC模式的加密:

CBC模式的解密:

CBC模式的特点

和ECB模式相比,ECB只是进行了加密,而CBC则是在加密之前做了一次XOR。

并且CBC要与前面一个密文分组进行XOR运算,这样相同的明文分组也会生成不同的密文。ECB的缺陷就不存在了。

这样其实也是CBC的缺点,它是一个链式结构,如果要生成密文分组3,则必须先加密明文分组1,2 。 不能并行进行。

另外我们观察CBC的解密过程可以看到,如果一个密文分组损坏,只要密文长度不变,则只会影响其相关联的两个明文分组的解密。

SSL/TLS 协议就是使用CBC模式来保证通信的机密性的。

CBC模式的攻击

CBC模式可以操纵解密过程的初始化向量,从而对解密后的明文进行攻击。具体来说就是对初始化向量进行反转,从而导致XOR之后的明文分组1也被反转了。

另外还有一种攻击叫做填充提示攻击,如果在分组密码中,明文长度不是分组长度的整数倍时候,需要在最后一个分组填充一些数据让其凑够一个分组长度。在填充提示攻击中,攻击者会反复发送一段密文,每次发送都修改填充的数据,从而根据解密的错误信息来推断一部分明文相关的信息。

CFB模式

CFB模式的全称是 Cipher FeedBack模式(密文反馈模式)。在CFB模式中,前一个密文分组会首先进行加密,然后再与明文分组进行XOR运算,最后得到密文分组。

如下图所示CFB模式的加密:


下面是CFB模式的解密:

CFB模式的攻击

我们观察在CFB解密阶段,是通过密文加密之后和密文进行XOR操作得到明文的。

这样就有可能进行重放攻击。比如用户可以将上一次发送过来的密文保存起来,将下一次发送过来的密文进行替换,从而达到修改新明文的目的。

OFB模式

OFB模式的全称是Output-FeedBack模式(输出反馈模式)。在OFB模式中,密码的输出会反馈到密码算法的输入中。

OFB模式是通过将明文分组和密码算法的输出进行XOR运算来产生密文分组的。

OFB模式的加密过程:


OFB模式的解密:


我们可以看到,OFB是将初始化向量不断的加密从而得到后续的加密输入。

他和CFB模式的区别也就在这里。CFB是将密文分组当做加密输入。

因为OFB模式中加密输入跟要加密的数据无关,所以我们可以提前计算出来所有要用到的加密输入,从而提高效率。

CTR模式

CTR模式的全称是Counter模式(计数器模式)。CTR模式是一种将计数器不断累加,然后进行加密从而生成密钥流的流密码。

下面是CTR模式的加密:

CTR模式的解密:

CTR模式的特点

CTR的加密和解密使用了完全相同的结构,所以在程序设计上比较容易实现。

CTR 可以任意顺序对分组进行加密和解密,从而支持并行计算。

更多教程请参考 flydean的博客

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容