标签:python self mn list 密码 range kv 维吉尼亚
就当为CSDN这方面的python开源做点贡献哈哈哈
维吉尼亚密码
- 算法原理
- python代码
#维吉尼亚密码
class VigenereCipher:
def __init__(self,k:str):
v=''.join(chr(i) for i in range(97,123))
d=dict(zip(v,range(0,26)))
self.k=k#密钥k,字符串形式
k=k.lower()
self.kn=len(k)
kv=[]#储存密钥K对应的数字串
for i in k:kv.append(d[i])
self.kv=kv
def encrypt(self,m:str):
m=m.replace(' ','')
m=m.lower()
#明文m,以字符串形式输入
mn=[]#储存明文对应的数字串
for mv in m:mn.append(d[mv])
for i in range(0,len(mn)):mn[i]=(mn[i]+self.kv[i%self.kn])%26#加密运算
s=''
for i in mn:s+=list(d.keys())[list(d.values()).index(i)]
print('The ciphertext is:',s.upper())
def decrypt(self,m:str):
#密文m,以字符串形式输入
m=m.lower()
mn=[]
for mv in m:mn.append(d[mv])
for i in range(0,len(mn)):mn[i]=(mn[i]-self.kv[i%self.kn])%26#解密运算
s=''
for i in mn:s+=list(d.keys())[list(d.values()).index(i)]
print('The plaintext is:',s)
- 实现过程
①生成密码器
以‘rehpyc’密钥生成维吉尼亚密码器:
②加密
对‘informationsecurityandcryptography’加密:
③解密
对得到的密文解密:
④例题的加解密
标签:python,self,mn,list,密码,range,kv,维吉尼亚 来源: https://blog.csdn.net/weixin_45181522/article/details/111869568
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。