异或

5.1 概述

异或(XOR)是一种逻辑二元操作,当两个输入中有且仅有一个为真时,结果为真。

另一种思考异或的方式是把当作一种“可编程的监视器”,一个输入的比特决定是否需要翻转另一个比特,还是直接保持其不变。

我们用下面的符号来表示异或操作:

image-20210121153027852.png

通常i是索引,Pi指的是原文中的一个比特,ki指的是密钥中的一个比特,Ci指的是加密后的密文比特。

5.2 异或的一些特性

  1. 结合律 a⊕(b⊕c)=(a⊕b)⊕c
  2. 交换律a⊕b=b⊕a
  3. 任何比特异或自身是0,a⊕a=0
  4. 任何比特异或0是它自身a⊕0=a

所以a⊕b⊕a=a⊕a⊕b=0⊕b=b

5.3 按位异或操作

通常编程语言会提供异或的操作,例如Python中的^可以进行整数的按位异或,首先将两个整数转化为二进制,然后按位进行异或操作。

例如73⊕87=0b1001001⊕0b1010111

​ 1 0 0 1 0 0 1

​ = ⊕ ⊕ ⊕ ⊕ ⊕ ⊕ ⊕

​ 1 0 1 0 1 1 1

​ = 0 0 1 1 1 1 0

​ = 30

5.4 一次性密码本

一次性密码本就是用一串随机的比特和原文进行异或操作得到密文。其安全性取决于密码本只使用一次。

image-20210121160054807.png

5.5 针对一次性密码本的攻击

一次性密码本的安全性

  • 密码本包含的是完全随机的内容
  • 密码本只使用一次

不使用真随机的数据

重复使用密码本

对于两段密文c1和c2

c1⊕c2=(p1⊕k)⊕(p2⊕k)=p1⊕p2⊕k⊕k=p1⊕p2

虽然依然得不到p1和p2,但是却掌握了p1和p2的某种关系。

例如下图

image.png

crib-dragging

对于复用密码本的情况,假设我们有一些用同一个密钥K生成的密文Ci。如果我们能正确的猜出其中一个Cj密文对应的明文Pj,就可以求出共享密钥K。

image.png

不幸的是我们并不能猜出整个密文,但是可以猜出其中一小部分密文(hard work)。

假设我们猜出了部分明文bit位Pi

k=Ci ⊕ Pi

所有密文处在同一个偏移位置的密钥都是k,求出同一偏移位置的所有明文:

Pi = Ci⊕ k。

猜中一部分明文文本要比猜中所有明文文本要简单的多,假设我们的明文文本是英文,下面是找一组常见的英文单词。 通常来说,the, to, of,and,a 这样的单词出现的频率非常高,因此,以它们作为突破口。如果我们更了解加密的文本就可以进行更靠谱的猜测,例如,HTML,要猜Content-Type等等。

那怎么知道我们猜的是正确的呢?如果我们的猜测是正确的,那么看密文在同一偏移位置解密出来的明文是否有意义。

对于每一条明文的同一个位置的内容,假定明文内容是空格,可以得到密钥可能是(密文)XOR(0x20),然后用这个可能的密钥去解其它的密文。假如解出来的明文都是字母,数字,标点或空格的话,则说明这个密钥很可能就是真正的密钥。用程序可以迅速对此作出判断。

假设成功猜出了5个字母 ␣the␣ ,在另一个文本中解出了对应 t␣thr ,可以查字典查找以thr开始的单词,例如through。重复过程。

  • 我们会获取到更多可窃取的位置
  • 每次成功的猜测可以获取到更多的明文字符,这样就更容易猜测出其他位置。
  • 对于同一位置来说,越多的密文,越方便猜测。两个密文异或后得到的是明文的异或,可以通过猜测,枚举等各种方式去探索明文的情况。

有了自然语言分析之后,这件事情已经变得越来越高效。

5.6 遗留问题

一次性密码本很少被用到,因为它是不可实现的,密钥长度至少和信息一样长。并且需要不断地变换。同时还面临着密钥交换的问题。

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

推荐阅读更多精彩内容

  • 在当前h5各种活动漫天轰炸的时代,大量的访问量给h5带来了机遇,同时也带来了一些安全隐患,如何能对数据进行一些合理...
    O蚂蚁O阅读 2,651评论 0 12
  • 1、为何要做数据加密 做过客户端的开发者应该知道,客户端数据的安全对公司来说绝对是头等重要的事情,毕竟数据是公司最...
    萧雾宇阅读 2,582评论 3 1
  • 原文链接源码见文末 异或简介 异或,二元运算; 符号^; 口诀:相同为0,不相同为1; 举例10011101^10...
    阶前梧叶阅读 8,056评论 4 13
  • 1. 异或运算 在数字逻辑中,逻辑算符互斥(exclusive or)是对两个运算元的一种逻辑分析类型,符号为XO...
    zhuke阅读 7,418评论 0 1
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 7,478评论 16 22