重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
本文实例为大家分享了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。
import string,os def vigenereEncrypt(msg,key): size = len(key) result = [] cnt = 0 for i in msg: if i.upper() in string.uppercase: #offset相当于是 ki offset = string.uppercase.find(key[cnt%size]) t = string.uppercase[(string.uppercase.find(i.upper())+offset)%26] #这里相当于是c1 = (mi+ki)(mod 26) ,t = c1 if i.isupper(): result.append(t) else: result.append(t.lower()) cnt+=1 else: result.append(i) return "".join(result) def main(): msg = "Common sense is not so common" cipher = vigenereEncrypt(msg,"PIZZA")#key = "PIZZA: print cipher if __name__=="__main__": main()