python实现维吉尼亚加密法-创新互联

本文实例为大家分享了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()



当前题目:python实现维吉尼亚加密法-创新互联
URL链接:http://bzwzjz.com/article/ceeeoc.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 营销型网站建设 高端网站设计 成都网站设计公司 企业网站设计 成都网站制作公司 成都网站设计 网站建设 网站设计公司 成都h5网站建设 重庆外贸网站建设 成都网站建设公司 成都网站建设 阿坝网站设计 梓潼网站设计 成都企业网站制作 成都网站设计制作公司 企业网站设计 定制网站设计 成都网站设计 成都网站设计 品牌网站建设 成都网站制作