时间:2021-05-22
本文实例为大家分享了python实现维吉尼亚加密法的具体代码,供大家参考,具体内容如下
Vigenere加密/解密时,把英文字母映射为0-25的数字再进行运算,并按n个字母为一组进行变换.算法定义如下:
设密钥 k =(k1,k2,k3…,kn),明文 m = (m1,m2,….mn),则加密算法为:
Ek(m) = (c1,c2,…cn)
其中:c1 = (mi+ki)(mod 26),i=1,2,3…..n
解密算法为:
mi = (ci - ki)(mod 26), i = 1,2,…..n。
小编再为大家分享一段Vigenere密码Python实现代码:
##########Vigenere密码############ letter_list='ABCDEFGHIJKLMNOPQRSTUVWXYZ' #字母表 #根据输入的key生成key列表def Get_KeyList(key): key_list=[] for ch in key: key_list.append(ord(ch.upper())-65) return key_list #加密函数def Encrypt(plaintext,key_list): ciphertext="" i=0 for ch in plaintext: #遍历明文 if 0==i%len(key_list): i=0 if ch.isalpha(): #明文是否为字母,如果是,则判断大小写,分别进行加密 if ch.isupper(): ciphertext+=letter_list[(ord(ch)-65+key_list[i]) % 26] i+=1 else: ciphertext+=letter_list[(ord(ch)-97+key_list[i]) % 26].lower() i+=1 else: #如果密文不为字母,直接添加到密文字符串里 ciphertext+=ch return ciphertext #解密函数def Decrypt(ciphertext,key): plaintext="" i=0 for ch in ciphertext: #遍历密文 if 0==i%len(key_list): i=0 if ch.isalpha(): #密文为否为字母,如果是,则判断大小写,分别进行解密 if ch.isupper(): plaintext+=letter_list[(ord(ch)-65-key_list[i]) % 26] i+=1 else: plaintext+=letter_list[(ord(ch)-97-key_list[i]) % 26].lower() i+=1 else: #如果密文不为字母,直接添加到明文字符串里 plaintext+=ch 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() while(False==key.isalpha()):#输入合法性判断 print("输入有误!密钥为字母,请重新输入:") key=input() key_list=Get_KeyList(key) if user_input=='D': #加密 print("请输入明文:") plaintext=input() ciphertext=Encrypt(plaintext,key_list) print("密文为:\n%s" % ciphertext) else: #解密 print("请输入密文:") ciphertext=input() plaintext=Decrypt(ciphertext,key_list) print("明文为:\n%s" % plaintext)以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
高级加密标准(英语:AdvancedEncryptionStandard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密
高级加密标准(英语:AdvancedEncryptionStandard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密
本文实例为大家分享了python实现AES加密和解密的具体代码,供大家参考,具体内容如下参考:python实现AES加密和解密AES加密算法是一种对称加密算法,
据美国《世界日报》报道,在绝大多数大学毕业生还在为寻找第一份工作发愁时,美国维吉尼亚大学(UniversityofVirginia)二年级华裔女生蕾蕾(Leil
一、简介1.aes加密简单来说,在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全