python密码学周期置换密码学习
作者:Jarrycow 发布时间:2021-09-21 16:45:39
标签:python,密码学,周期置换密码
周期置换密码
参考教材:《现代密码学教程》P47 3.1.2
加密解密过程
周期置换密码是将明文p串按固定长度m分组.然后对每组中的子串按1,2…,m的某个置换重新排列位置从而得到密文,其中密钥σ包含分组长度信息。
解密时同样对密文c按长度m分组,并按σ的逆置换σ-1把每组子串重新排列位置从而得到明文p。
以例3.3为例
和上次提及的列置换密码类似
代码
import re
class timeCode:
__key=[] # 密钥
__apaMsg="" # 明文
__secMsg="" #密文
__lenKey=0 #密钥长度 周期值
def getKey(self,s): # 密钥形成函数
Key={}
antiKey={}
s=re.split(r'[()]',s) #以()分界
while '' in s: # 消除''
s.remove('')
temp=[]
for i in range(len(s)):
for j in range(len(s[i])-1):
Key[int(s[i][j])]=int(s[i][j+1]) #密钥字典
antiKey[int(s[i][j+1])]=int(s[i][j]) #反密钥字典
temp.append(int(s[i][j])) #钥匙收录
Key[int(s[i][-1])]=int(s[i][0]) #解决最后一个的问题
antiKey[int(s[i][0])]=int(s[i][-1])
temp.append(int(s[i][-1]))
maxtemp=max(temp) #密钥长度
self.__lenKey=maxtemp
lenKey={i+1 for i in range(maxtemp)}
sameKey=lenKey-set(temp) #找到没有变化的密钥
for i in sameKey:
Key[i]=i
antiKey[i]=i
self.__key.append(Key)
self.__key.append(antiKey)
def enCode(self,p): #加密函数
self.__apaMsg=p
Key=self.__key[0]
time=self.__lenKey
p=p.replace(' ','') #去除空格
if len(p)%time != 0:
p+=' '*(time-len(p)%time) #末尾补齐
n=len(p)//time
M=[p[i*time:(i+1)*time] for i in range(n)] #分组生成
M=[M[i][Key[j+1]-1] for i in range(n) for j in range(time)] #矩阵转换
M=''.join(M) #列表转换为字符串
self.__secMsg=M
return M
def deCode(self,q):
self.__apaMsg=p
m=self.__lenKey
n=len(q)//m
Key=self.__key[1]
M=[q[i*m:(i+1)*m] for i in range(n)]
M=[M[i][Key[j+1]-1] for i in range(n) for j in range(m)]
M=''.join(M)
self.__secMsg=M
return M
def Print(self):
print(self.__key,self.__apaMsg,self.__secMsg,self.__lenKey)
s='(15623)'
p='State Key Laboratory of Networking and Switching'
a=timeCode()
a.getKey(s)
q=a.enCode(p)
a.deCode(q)
a.Print()
来源:https://blog.csdn.net/Jarrycow/article/details/105575517
0
投稿
猜你喜欢
- 大家好,我们的git专题已经更新结束了,所以开始继续给大家写一点设计模式的内容。今天给大家介绍的设计模式非常简单,叫做iterator,也就
- 从Keras转换成PB模型请注意,如果直接使用Keras2ONNX进行模型转换大概率会出现报错,这里笔者曾经进行过不同的尝试,最后都失败了。
- 需 求 分 析 1、读取指定目录下的所有文件2、读取指定文件,输出文件内容3、创建一个文件并保存到指定目录实 现 过 程Python写代码简
- 先来看一个例子:>>> def foo(*args, **kwargs): print
- Python 截取字符串使用 变量[头下标:尾下标],就可以截取相应的字符串,其中下标是从0开始算起,可以是正数或负数,下标可以为空表示取到
- 一、禁止计算局部梯度torch.autogard.no_grad: 禁用梯度计算的上下文管理器。当确定不会调用Tensor.backward
- 函数内省(function introspection)除了__doc__属性, 函数对象还有很多属性,对于下面的函数,可以使用dir()查
- 是时候了—— 在大部分情况下当用户输入密码时把它们用清晰的文字显示出来。一直以来,提供反馈、把系统状态形象化是最基本的可用性原则,当用户输入
- 本文实例为大家分享了python实现银行系统的具体代码,供大家参考,具体内容如下1、admin.py 定义管理员信息和主界面显示#!/usr
- 本文实例讲述了Python多进程multiprocessing、进程池用法。分享给大家供大家参考,具体如下:内容相关:multiproces
- 本文python代码实现的是最小二乘法线性拟合,并且包含自己造的轮子与别人造的轮子的结果比较。问题:对直线附近的带有噪声的数据进行线性拟合,
- 本文范例是书写两个日志:错误日志(ERROR级别)和运行日志(DEBUG级别),其中运行日志每日凌晨进行分割import logging,d
- 方法1:使用Python中自带的print输出带有颜色或者背景的字符串书写语法print(\033[显示方式;前景色;背景色m输出内容\03
- 由于工作中涉及到生日编辑资料编辑,然后自己改了一下代码:<html><head> <meta charset=
- 你是否曾经想在数据库中存储一个日期而没有时间部分,或者想存储一个时间值希望有更高的精度?在SQL Server 2008的介绍中,微软介绍了
- Python os 模块os是“operating system”的缩写,os模块提供各种 Pyth
- 介绍本篇将介绍Python3中的迭代器与生成器,描述可迭代与迭代器关系,并实现自定义类的迭代器模式。迭代的概念上一次输出的结果为下一次输入的
- 本文实例讲述了Python下载指定页面上图片的方法。分享给大家供大家参考,具体如下:#!/usr/bin/python #coding:ut
- 一起画图吧为什么突然想搞这个画图软件呢不瞒各位,是因为最近接到了一个很小很小很小小得不能再小的小项目就是基于Tkinter,做一个简易的画图
- 使用Python的pillow模块 random 模块随机生成验证码图片,并应用到Django项目中安装pillow$ pip3 insta