python playfair
#########################Playfair密码#########################
#约定1:若明文字母数量为奇数,在明文末尾添加一个'Z'
#约定2:'I'作为'J'来处理
#字母表
letter_list='ABCDEFGHJKLMNOPQRSTUVWXYZ'
#密码表
T_letter=['','','','','']
#根据密钥建立密码表
def Create_Matrix(key):
key=Remove_Duplicates(key) #移除密钥中的重复字母
key=key.replace(' ','') #去除密钥中的空格
for ch in letter_list: #根据密钥获取新组合的字母表
if ch not in key:
key+=ch
j=0
for i in range(len(key)): #将新的字母表里的字母逐个填入密码表中,组成5*5的矩阵
T_letter[j]+=key[i] #j用来定位字母表的行
if 0==(i+1)%5:
j+=1
#移除字符串中重复的字母
def Remove_Duplicates(key):
key=key.upper() #转成大写字母组成的字符串
_key=''
for ch in key:
if ch=='I':
ch='J'
if ch in _key:
continue
else:
_key+=ch
return _key
#获取字符在密码表中的位置
def Get_MatrixIndex(ch):
for i in range(len(T_letter)):
for j in range(len(T_letter)):
if ch==T_letter[i][j]:
return i,j #i为行,j为列
#加密
def Encrypt(plaintext,T_letter):
ciphertext=''
if len(plaintext) % 2 !=0: #如果新的明文长度为奇数,在其末尾添上'Z'
plaintext+='Z'
i=0
while i<len(plaintext): #对明文进行遍历
if True==plaintext[i].isalpha(): #如果是明文是字母的话,
j=i+1 #则开始对该字母之后的明文进行遍历,
while j<len(plaintext): #直到遍历到字母,进行加密
if True==plaintext[j].isalpha():
if 'I'==plaintext[i].upper(): #
x=Get_MatrixIndex('J') #
else: #
x=Get_MatrixIndex(plaintext[i].upper()) #对字符在密码表中的坐标
if 'I'==plaintext[j].upper(): #进行定位,同时将'I'作为
y=Get_MatrixIndex('J') #'J'来处理
else: #
y=Get_MatrixIndex(plaintext[j].upper()) #
if x[0]==y[0]: #如果在同一行
ciphertext+=T_letter[x[0]][(x[1]+1)%5]+T_letter[y[0]][(y[1]+1)%5]
elif x[1]==y[1]: #如果在同一列
ciphertext+=T_letter[(x[1]+1)%5][x[0]]+T_letter[(y[1]+1)%5][y[0]]
else: #如果不同行不同列
ciphertext+=T_letter[x[0]][y[1]]+T_letter[y[0]][x[1]]
break; #每组明文对加密完成后,结束本次对明文的遍历
j+=1
i=j+1 #每次对明文的遍历是从加密过后的明文的后一个明文开始的,结束本次循环
continue
else:
ciphertext+=plaintext[i] #如果明文不是字母,直接加到密文上
i+=1
return ciphertext
#解密
def Decrypt(ciphertext,T_letter):
plaintext=''
if len(ciphertext) % 2 !=0: #如果新的密文长度为奇数,在其末尾添上'Z'
ciphertext+='Z'
i=0
while i<len(ciphertext): #对密文进行遍历
if True==ciphertext[i].isalpha(): #如果是密文是字母的话,
j=i+1 #则开始对该字母之后的密文进行遍历,
while j<len(ciphertext): #直到遍历到字母,进行解密
if True==ciphertext[j].isalpha():
if 'I'==ciphertext[i].upper(): #
x=Get_MatrixIndex('J') #
else: #
x=Get_MatrixIndex(ciphertext[i].upper()) #对字符在密码表中的坐标
if 'I'==ciphertext[j].upper(): #进行定位,同时将'I'作为
y=Get_MatrixIndex('J') #'J'来处理
else: #
y=Get_MatrixIndex(ciphertext[j].upper()) #
if x[0]==y[0]: #如果在同一行
plaintext+=T_letter[x[0]][(x[1]-1)%5]+T_letter[y[0]][(y[1]-1)%5]
elif x[1]==y[1]: #如果在同一列
plaintext+=T_letter[(x[1]-1)%5][x[0]]+T_letter[(y[1]-1)%5][y[0]]
else: #如果不同行不同列
plaintext+=T_letter[x[0]][y[1]]+T_letter[y[0]][x[1]]
break; #每组密文对解密完成后,结束本次对密文的遍历
j+=1
i=j+1 #每次对密文的遍历是从解密过后的密文的后一个密文开始的,结束本次循环
continue
else:
plaintext+=ciphertext[i] #如果密文不是字母,直接加到明文上
i+=1
return plaintext
#主函数
if __name__=='__main__':
print("加密请按D,解密请按E:")
user_input=input();
while(user_input!='D' and user_input!='E'):#输入合法性检测
print("输入有误!请重新输入:")
user_input=input()
print('请输入密钥,密钥由英文字母组成:')
key=input()
Create_Matrix(key) #建立密码表
if user_input=='D': #加密
print('请输入明文:')
plaintext=input()
print("密文为:\n%s" % Encrypt(plaintext,T_letter))
else: #解密
print('请输入密文:')
ciphertext=input()
print('明文为:\n%s' % Decrypt(ciphertext,T_letter))
python playfair的更多相关文章
- 信息安全-1:python之playfair密码算法详解[原创]
转发注明出处: http://www.cnblogs.com/0zcl/p/6105825.html 一.基本概念 古典密码是基于字符替换的密码.加密技术有:Caesar(恺撒)密码.Vigenere ...
- Playfair加密
前面讲的不管是单码加密还是多码加密都属于单图加密,什么是单图加密和多图加密呢,简单来说单图加密就是一个字母加密一个字母,而多图加密就是一个字符组加密一个字符组.比如双图加密就是两个字母加密两个字母,这 ...
- Python中的多进程与多线程(一)
一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...
- Python高手之路【六】python基础之字符串格式化
Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...
- Python 小而美的函数
python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况 any any(iterable) ...
- JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议
软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...
- 可爱的豆子——使用Beans思想让Python代码更易维护
title: 可爱的豆子--使用Beans思想让Python代码更易维护 toc: false comments: true date: 2016-06-19 21:43:33 tags: [Pyth ...
- 使用Python保存屏幕截图(不使用PIL)
起因 在极客学院讲授<使用Python编写远程控制程序>的课程中,涉及到查看被控制电脑屏幕截图的功能. 如果使用PIL,这个需求只需要三行代码: from PIL import Image ...
- Python编码记录
字节流和字符串 当使用Python定义一个字符串时,实际会存储一个字节串: "abc"--[97][98][99] python2.x默认会把所有的字符串当做ASCII码来对待,但 ...
随机推荐
- [模仿][JS]新浪财经7*24直播
使用新浪财经7*24直播的数据 简单的做一个山寨品 在线地址:[痛苦啊,有GFW,却没有vpn,往heroku上传浪费了好多时间...] http://wangxinsheng.herokuapp.c ...
- Android-将RGB彩色图转换为灰度图
package com.example.yanlei.wifi; import android.graphics.Bitmap; import android.graphics.BitmapFacto ...
- SharePoint 2013 开启访问请求
1.通常,我们进入SharePoint 2013站点,如果没权限会提示该站点未被共享,而没有切换账号或者申请访问,实在是很流氓:其实,SharePoint为我们提供了访问请求页面,但是可能需要手动开启 ...
- Cent OS 6.4安装mysql
Cent OS6.4 RPM安装mysql 一.卸载掉原有mysql 因为目前主流Linux系统版本基本上都集成了mysql数据库在里面 如下命令来查看我们的操作系统上是否已经安装了mysql数据库 ...
- mod_slotmem mod_manager mod_proxy_cluster mod_advertise Permission denied
restorecon /etc/httpd/modules/mod_slotmem.so
- android media server 解析1-media player service 结构部分
下面为media server注册的四个服务之一:MediaPlayerService的结构图 1.图中没有MediaPlayerService的代理对象BpMediaPlayerService部分, ...
- SVN Can't open file 'xxx':Premission denied
换了一台电脑,重新搭建本地svn服务器的时候,服务器搭起来了,但是用Cornerstone往服务器上传工程的时候报错 报错有以上两种,都是因为文件权限的限制 解决方法 第一种报错 1.在Finder里 ...
- 在Myeclipse中配置Maven
第一步:下载maven安装包,配置环境变量M2_HOME;变量值为maven的解压目录. 第二步:在eclipse4.0之前的版本需要安装maven插件,方法即:将maven插件包复制到eclipse ...
- Linux安装SmartSVN及破解
转载自:linux 下svn图形客户端smartsvn 安装 一.准备 smartsvn需要java支持,首先请确认机器上有没有安装java 另外还请确认环境变量里有没有JAVA_HO ...
- Eclipse编译去除svn文件夹
使用Eclipse编译文件后,classes文件中总是有.svn的文件夹,这些文件没有什么用,而且影响build的速度 "Project->Properties->Java Bu ...