《Python密码学编程》——1.7 另一个加密法工具:St. Cyr滑条

1.7 另一个加密法工具:St. Cyr滑条

还有一个纸质工具可以用来做加密和解密,这个纸质工具叫做St. Cyr滑条。它很像密钥索引轮盘,但它是直的。

复印本页的St. Cyr滑条图片(或者从http://invpy.com/stcyrslide打印),剪下三条纸带,如图1-11所示。

连接两条字母表纸带,把黑框A粘在另一条纸带上的白框Z旁边。割开主滑框两边的裂缝,使连接起来的纸条可以穿过它。最后看起来应该是如图1-12所示。

当黑框A在字母H(数字7)下面时,如果要加密,就在长纸带上找出明文字母的位置,然后把它替换成在它上面的字母。如果要解密,就在上面那行字母里找出密文字母,然后把它替换成下面的长纸带上的字母。

大框两边的裂缝会隐藏其他的字母,这样,对于任何密钥,滑条上的每个字母你只会看到一个。

St. Cyr滑条的好处是更容易找到你要找的字母,因为它们都在同一条直线上,不像加密轮盘那样有时候会倒转过来。

虚拟的可打印的St. Cyr滑条可以在http://invpy.com/stcyrslide 找到。

时间: 2024-07-30 19:20:13

《Python密码学编程》——1.7 另一个加密法工具:St. Cyr滑条的相关文章

《Python密码学编程》——1.9 不用纸质工具做加密

1.9 不用纸质工具做加密 在使用凯撒加密法做加密和解密时,加密轮盘和St. Cyr滑条都是很好的工具.但我们只用铅笔和纸也可以实现凯撒加密法. 把字母表的字母从A到Z写下来,在每个字母下面写下数字0到25.在A下面写0,B下面写1,如此类推,直到在Z下面写25(字母表里有26个字母,但我们的数字最多只到25,因为我们从0而不是1开始的).最终看起来像这样: 有了上面这个从字母到数字的代码,我们就可以用数字来表示字母了.这是一个非常强大的概念,因为数学使用数字.现在我们可以在字母上做运算了. 现

《Python密码学编程》——导读

前 言 有很多书教初学者如何使用加密法写秘密消息,有一些书教初学者如何破译加密法.据我所知,还没有书教初学者如何编写程序来破译加密法.这本书填补了这个空缺. 本书适合不懂加密.破译或密码学的初学者.本书的加密法(除了最后一章的RSA加密法)都有数百年历史了,现代计算机的计算能力可以破译使用它们加密的信息,现代组织或个人已经不再使用这些加密法了.有鉴于此,你不会因为本书里的内容而惹麻烦. 本书适合从来没有编过程序的初学者.本书使用Python编程语言讲解基本编程概念.Python非常适合初学者学习

《Python密码学编程》——第1章 制作纸质加密工具 1.1 密码学是什么

第1章 制作纸质加密工具 本章主要内容: 密码学是什么: 代码和加密法: 凯撒加密法: 加密轮盘: St. Cyr滑条: 用纸笔做加密: "双重强度"加密. 我忍不住偷听,可能因为我在窃听. --佚名 1.1 密码学是什么 看看以下两段文字: 左边的文字是秘密消息.这段消息已被加密,或者说被变成了秘密代码.任何不知道如何解密(也就是把它变回普通英语消息)的人都无法阅读.本书将会教你如何加密和解密消息. 右边的消息只是随机乱码,没有包含任何有意义的内容.加密你写下来的消息是对其他人保密的

《Python密码学编程》——2.11 编程和密码学

2.11 编程和密码学 编程和密码学是两个独立的技能,但一起学是很有用的,因为计算机做加密比人更快.比如说,以下是用简单替换密码的方式加密莎士比亚的<罗密欧与朱丽叶>之后的全部文本: 如果你尝试手工加密,每天工作12小时,周末休息,需要大约三周时间才能完成加密.或许你还会犯些错误.然后需要另外的三周时间才能解密这段加密的文本. 你的计算机只需不到两秒就能完全加密或解密整部戏剧. 但你需要知道如何进行计算机编程才能加密.这就是本书的目的了.如果你会计算机编程,你也可以破译别人加密并试图保密的密文

《Python密码学编程》——1.2 代码与加密法

1.2 代码与加密法 19世纪初发明的电报允许通过跨越大陆的电线进行即时通信,这比带着一袋信件骑马派送要快很多.然而,电报不能直接发送写在纸上的字母,它只能发送电子脉冲.短脉冲叫"点",长脉冲叫"线". 为了把这些点和线转成英文字母,需要一个编码(或代码)系统把英语翻译成电子脉冲代码(编码),另一边把电子脉冲翻译成英语(解码).用于电报(后来也用于无线电)的代码叫摩斯代码(Morse Code),由Samuel Morse(见图1-1)和Alfred Vail(见图

《Python密码学编程》——1.12 通过计算机编程进行加密

1.12 通过计算机编程进行加密 几个世纪以来,凯撒加密法或者类似的加密法曾被用于加密信息.图1-13是Albert Myer设计的加密圆盘,这个加密圆盘曾在1863年的美国南北战争中使用. 如果你有一段很长的消息希望加密(如加密一整本书),手工加密需要耗费数日或数周的时间.这正是编程派上用场的地方.计算机可以在一秒之内完成大量文字工作.但是,我们需要学习如何指示(也就是编程)计算机执行我们所做的步骤. 我们要会说一门计算机能懂的语言.幸运的是,学习编程语言不像学习日语或西班牙语等外语那么难.你

《Python密码学编程》——2.10 更多信息链接

2.10 更多信息链接 关于编程和密码学还有很多可以学习的,但你不需要现在就把所有的都学了.有时候,你可能了解这些额外的细节和解释,但如果我把它们都放到这本书里,就会增加很大篇幅.出版这么大的一本书会把大量容易着火的纸聚在一起,使之会变成一个火灾隐患.我在本书里包含了"更多信息"链接,你可以通过它们访问本书的网站.你不需要阅读这些额外的信息来理解本书的任何东西,但这些信息可以帮助你学习.这些链接以http://invpy.com 开头(这是"Invent with Pytho

《Python密码学编程》——第2章 Pygame基础知识 2.1 下载和安装Python

第2章 Pygame基础知识 本章主要内容: 下载和安装Python: 下载Pyperclip模块: 如何启动IDLE: 本书采用的格式: 复制粘贴文本. 开放社会的隐私需要密码学.如果我说了什么,我希望听到的人都是我想让他们听到的.如果我讲话的内容全世界都能知道,那我就没隐私了. --Eric Hughes,<A Cypherpunk's Manifesto>,1993(http://invpy.com/cypherpunk) 本章内容很像Invent Your Own Computer G

《Python密码学编程》——1.3 制作纸质加密轮盘

1.3 制作纸质加密轮盘 在学习通过计算机编程进行加密和解密之前,我们先来了解一下如何使用简单的纸质工具手工完成这项任务.把可理解的英语文字(明文)变成隐藏秘密代码的乱码文字(密文)是很容易的.加密法(cipher)是一组转换明文和密文的规则.这些规则通常使用一个密钥.我们会在本书里学到多种不同的加密法. 我们来学一下凯撒加密法.这种加密法曾在两千年前被凯撒大帝用过.好消息是,它学起来很简单很容易.坏消息是,正因为它简单,密码破译者也很容易破译它.但我们可以把它看做一个简单的练习.Wikiped