查看“︁凱撒密碼”︁的源代码
←
凱撒密碼
跳转到导航
跳转到搜索
因为以下原因,您没有权限编辑该页面:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
{{Refimprove|time=2022-03-27T12:21:31+00:00}} {{noteTA | 1 = zh-cn:通过; zh-tw:透過; zh-hk:通過 }} {{区块加解密方块 | name = 凯撒密码 | image = [[File:Caesar3.svg|320px]] | caption = 当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。 <!-- General --> | designers = | publish date = | series = | derived from = | derived to = | related to = | certification = <!-- Cipher detail --> | key size = | security claim = | block size = | structure = [[替换式密码]] | rounds = | cryptanalysis = 易受[[频率分析]]和暴力破解的攻击。 }} '''凯撒密码'''({{lang-en|Caesar cipher}}),或稱'''凯撒加密'''、'''凯撒变换'''、'''变换加密''',是一种最简单且最广为人知的加密技术。凯撒密码是一种[[替换式密码|替换加密]]技术,[[明文]]中的所有字母都在[[字母表]]上向後(或向前)按照一个固定数目进行偏移後被替换成[[密文]]。例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。这个加密方法是以[[羅馬共和]]時期[[凱撒]]的名字命名的,據稱当年凱撒曾用此方法与其将军们进行联系。 凯撒密码通常被作为其他更复杂的加密方法中的一个步骤,例如[[维吉尼亚密码]]。凯撒密码还在现代的[[ROT13]]系统中被应用。但是和所有的利用字母表进行替换的加密技术一样,凯撒密码非常容易被破解,而且在实际应用中也无法保证通信安全。 == 例子 == 凯撒密码的替换方法是通过排列明文和密文字母表,密文字母表示通过将明文字母表向左或向右移动一个固定数目的位置。例如,当偏移量是左移3的时候(解密时的密钥就是3): 明文字母表:ABCDEFGHIJKLMNOPQRSTUVWXYZ 密文字母表:DEFGHIJKLMNOPQRSTUVWXYZABC 使用时,加密者查找明文字母表中需要加密的消息中的每一个字母所在位置,并且写下密文字母表中对应的字母。需要解密的人则根据事先已知的密钥反过来操作,得到原来的明文。例如: 明文:THE QUICK BROWN FOX JUMPS OVER THE LAZY DOG 密文:WKH TXLFN EURZQ IRA MXPSV RYHU WKH ODCB GRJ 凯撒密码的加密、解密方法还能够通过[[同余]]的数学方法进行计算。首先将字母用数字代替,A=0,B=1,...,Z=25。此时偏移量为n的加密方法即为: :<math>E_{n}(x) = (x + n) \mod 26</math> 解密就是: :<math>D_{n}(x) = (x - n) \mod 26</math> == 历史和用途 == [[File:Gaius_Julius_Caesar_(100-44_BC).JPG|180px|thumb|right|凱撒曾经使用这种密码与其将军们联系]] 根据[[苏维托尼乌斯]]的记载,凯撒曾用此方法对重要的军事信息进行加密: {{cquote|如果需要保密,信中便用暗号,也即是改变字母顺序,使局外人无法组成一个单词。如果想要读懂和理解它们的意思,得用第4个字母置换第一个字母,即以D代A,余此类推。|[[苏维托尼乌斯]]|罗马十二帝王传<ref>{{cite book|isbn=7100022029|publisher=商务印书馆|year=1996|title=罗马十二帝王传|chapter=第一卷 神圣的朱里乌斯传 第56节|pages=30|author=[[苏埃托尼乌斯|苏维托尼乌斯]]|others=张竹明 王乃新 蒋平译|language=zh}}</ref>}} 同样,[[奥古斯都]]也使用过类似方式,只不过他是把字母向右移动一位,而且末尾不折回。 {{cquote|每当他用密语写作时,他都用B代表A,C代表B,其余的字母也依同样的规则;他用AA代表Z。|[[苏维托尼乌斯]]|罗马十二帝王传<ref>{{cite book|isbn=7100022029|publisher=商务印书馆|year=1996|title=罗马十二帝王传|chapter=第二卷 神圣的奥古斯都传 第88节|pages=99|author=[[苏埃托尼乌斯|苏维托尼乌斯]]|others=张竹明 王乃新 蒋平译|language=zh}}</ref>}} 另外,有证据表明<ref>{{cite journal |last=Reinke |first=Edgar C. |title=Classical Cryptography |journal=The Classical Journal |volume=58 |issue=3 |pages=114 |language=en|date=December 1992}}</ref>,凯撒曾经使用过更为复杂的密码系统: {{cquote|文法学家普罗布斯曾经写过一份独具创新的手稿,研究凯撒书信中包含有秘密信息的字母。|[[格利乌斯]]|阿提卡之夜}} 现在已经无法弄清凯撒密码在当时有多大的效果,但是有理由相信它是安全的。因为凯撒大部分敌人都是目不识丁的,而其余的则可能将这些消息当作是某个未知的外语<ref>{{cite book |title=Fundamentals of Computer Security |url=https://archive.org/details/fundamentalscomp00piep_208 |last=Pieprzyk |first=Josef |coauthors=Thomas Hardjono, Jennifer Seberry |year=2003 |publisher=Springer |isbn=3540431012 |pages=[https://archive.org/details/fundamentalscomp00piep_208/page/n15 6] |language=en}}</ref>。即使有某个敌人获取了凯撒的加密信息,根据现有的记载,当时也没有任何技术能够解决这一最基本、最简单的替换密码。现存最早的破解方法记载在公元9世纪[[阿拉伯帝国|阿拉伯]]的[[阿尔·肯迪]]的有关发现[[频率分析]]的著作中<ref>{{cite book|isbn=0385495323|publisher=Anchor|year=2000|title=The Code Book|pages=14–20|author=[[西蒙·辛格]]|language=en}}</ref>。 === 特定凯撒密码名称 === 根据偏移量的不同,还存在若干特定的凯撒密码名称: * 偏移量为10:Avocat(A→K) * 偏移量为13:[[ROT13]] * 偏移量为-5:Cassis (K 6) * 偏移量为-6:Cassette (K 7) == 密码破解 == 即使使用[[唯密文攻击]],凯撒密码也是一种非常容易破解的加密方式。可能有两种情况需要考虑: # 攻击者知道(或者猜测)密码中使用了某个简单的替换加密方式,但是不确定是凯撒密码; # 攻击者知道(或者猜测)使用了凯撒密码,但是不知道其偏移量。 对于第一种情况,攻击者可以通过使用诸如频率分析或者样式单词分析的方法<ref name="Book_Cryptology">{{cite book |title=Cryptology |url=https://archive.org/details/cryptologyintrod0000beut |last=Beutelspacher |first=Albrecht |authorlink=:en:Albrecht Beutelspacher |year=1994 |publisher=Mathematical Association of America |isbn=0-88385-504-6 |pages=[https://archive.org/details/cryptologyintrod0000beut/page/8 8]–11 |language=en}}</ref>,马上就能从分析结果中看出规律,得出加密者使用的是凯撒密码。 {| class="wikitable" align="right" style="margin: 0 0 1em 1em" | align="center" | 偏移量 | align="center" | 候选明文 |- align="center" | 0 | exxegoexsrgi |- align="center" | 1 | dwwdfndwrqfh |- align="center" | 2 | cvvcemcvqpeg |- align="center" | 3 | buubdlbupodf |- align="center" | bgcolor="#ffebad" | 4 | bgcolor="#ffebad" | attackatonce |- align="center" | 5 | zsszbjzsnmbd |- align="center" | 6 | yrryaiyrmlac |- align="center" | colspan="2" | … |- align="center" | 23 | haahjrhavujl |- align="center" | 24 | gzzgiqgzutik |- align="center" | 25 | fyyfhpfytshj |} 对于第二种情况,解决方法更加简单。由于使用凯撒密码进行加密的语言一般都是[[拼音文字|字母文字]]系统,因此密码中可能是使用的偏移量也是有限的,例如使用26个字母的[[英语]],它的偏移量最多就是25(偏移量26等同于偏移量0,即明文;偏移量超过26,等同于偏移量1-25)。因此可以通过[[蛮力攻击|穷举法]],很轻易地进行破解<ref name="Book_Cryptology"/>。其中一种方法是在表格中写下密文中的某个小片段使用所有可能的偏移量解密后的内容——称为候选明文,然后分析表格中的候选明文是否具有实际含义,得出正确的偏移量,解密整个密文。例如,被选择出的密文片段是"EXXEGOEXSRGI",可以从右表中的候选明文里很快看出其正确的偏移量是4。也可以通过在每一个密文单词的每一个字母下面,纵向写下整个字母表其他字母,然后可以通过分析,得出其中的某一行便是明文。 另外一种攻击方法是通过频率分析。当密文长度足够大的情况下,可以先分析密文中每个字母出现的频率,然后将这一频率与正常情况下的该语言字母表中所有字母的出现频率做比较。例如在英语中,正常明文中字母E和T出现的频率特别高,而字母Q和Z出现的频率特别低,而在[[法语]]中出现频率最高的字母是E,最低的是K和W。可以通过这一特点,分析密文字母出现的频率,可以估计出正确的偏移量。此外,有时还可以将频率分析从字母推广到单词,例如英语中,出现频率最高的单词是<ref name="ftn2">{{cite web|url=http://www.duboislc.org/EducationWatch/First100Words.html|title=The First 100 Most Commonly Used English Words|language=en|access-date=2009-01-02|archive-url=https://web.archive.org/web/20130616200847/http://www.duboislc.org/EducationWatch/First100Words.html|archive-date=2013-06-16|dead-url=yes}}</ref>:the, of, and, a, to, in...。通过将最常见的单词的所有可能的25组密文,编组成字典,进行分析。比如QEB可能是the,MPQY可能是单词know(当然也可能是aden)。但是频率分析也有其局限性,它对于较短或故意省略元音字母或者其他缩写方式写成的明文加密出来的密文进行解密并不适用。 另外,通过多次使用凯撒密码来加密并不能获得更大的安全性,因为使用偏移量A加密得到的结果再用偏移量B加密,等同于使用A+B的偏移量进行加密的结果。 [[File:English-slf.png|left|300px|thumbnail|用典型的英语书写的文字样本中各字母出现频率]] [[File:Histogramme_fréquence_texte_francais.png|none|300px|thumbnail|用典型的法语书写的文字样本中各字母出现频率]] {{clear}} == 參見 == * [[密码学]] * [[替换式密码]] * [[字母频率]] == 参考资料 == <references/> ==外部链接== *[https://www.khanacademy.org/math/applied-math/cryptography/crypt/v/caesar-cipher 可汗學院裡的凱撒密碼影片]{{Wayback|url=https://www.khanacademy.org/math/applied-math/cryptography/crypt/v/caesar-cipher |date=20130408210537 }} *[http://www.khanacademy.org/cs/caesar-cipher/1357701720 凱撒密碼的互動] {{Cryptography navbox | classical}} [[Category:愷撒]] [[Category:古典密码]] [[Category:群论]]
该页面使用的模板:
Template:Cite book
(
查看源代码
)
Template:Cite journal
(
查看源代码
)
Template:Cite web
(
查看源代码
)
Template:Clear
(
查看源代码
)
Template:Cquote
(
查看源代码
)
Template:Cryptography navbox
(
查看源代码
)
Template:Lang-en
(
查看源代码
)
Template:NoteTA
(
查看源代码
)
Template:Refimprove
(
查看源代码
)
Template:Wayback
(
查看源代码
)
Template:区块加解密方块
(
查看源代码
)
返回
凱撒密碼
。
导航菜单
个人工具
登录
命名空间
页面
讨论
不转换
查看
阅读
查看源代码
查看历史
更多
搜索
导航
首页
最近更改
随机页面
MediaWiki帮助
特殊页面
工具
链入页面
相关更改
页面信息