python实现维吉尼亚加密法


Posted in Python onMarch 20, 2019

本文实例为大家分享了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实现维吉尼亚加密法

小编再为大家分享一段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)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
跟老齐学Python之永远强大的函数
Sep 14 Python
Python使用MySQLdb for Python操作数据库教程
Oct 11 Python
浅谈pyhton学习中出现的各种问题(新手必看)
May 17 Python
[原创]教女朋友学Python3(二)简单的输入输出及内置函数查看
Nov 30 Python
解决Python中list里的中文输出到html模板里的问题
Dec 17 Python
Flask框架模板继承实现方法分析
Jul 31 Python
对Django 中request.get和request.post的区别详解
Aug 12 Python
centos+nginx+uwsgi+Django实现IP+port访问服务器
Nov 15 Python
浅谈多卡服务器下隐藏部分 GPU 和 TensorFlow 的显存使用设置
Jun 30 Python
Django多数据库联用实现方法解析
Nov 12 Python
Python列表的深复制和浅复制示例详解
Feb 12 Python
如何用Matlab和Python读取Netcdf文件
Feb 19 Python
Python multiprocess pool模块报错pickling error问题解决方法分析
Mar 20 #Python
python实现对输入的密文加密
Mar 20 #Python
python实现字符串加密成纯数字
Mar 19 #Python
python实现简单加密解密机制
Mar 19 #Python
python使用adbapi实现MySQL数据库的异步存储
Mar 19 #Python
python异步存储数据详解
Mar 19 #Python
利用Python半自动化生成Nessus报告的方法
Mar 19 #Python
You might like
《星际争霸重制版》兵种对比图鉴
2020/03/02 星际争霸
将数组写入txt文件 var_export
2009/04/21 PHP
一个PHP针对数字的加密解密类
2014/03/20 PHP
php准确计算复活节日期的方法
2015/04/18 PHP
详解PHP的Laravel框架中Eloquent对象关系映射使用
2016/02/26 PHP
PHP7安装Redis扩展教程【Linux与Windows平台】
2016/09/30 PHP
Laravel 模型使用软删除-左连接查询-表起别名示例
2019/10/24 PHP
php+websocket 实现的聊天室功能详解
2020/05/27 PHP
javascript new后的constructor属性
2010/08/05 Javascript
jquery下拉select控件操作方法分享(jquery操作select)
2014/03/25 Javascript
js实现特定位取反原理及示例
2014/06/30 Javascript
JavaScript设计模式之工厂模式和构造器模式
2015/02/11 Javascript
jQuery的几个我们必须了解的特点
2015/05/03 Javascript
详细解读AngularJS中的表单验证编程
2015/06/19 Javascript
JavaScript事件类型中焦点、鼠标和滚轮事件详解
2016/01/25 Javascript
JavaScript获取图片像素颜色并转换为box-shadow显示
2016/03/11 Javascript
JavaScript仿微信打飞机游戏
2020/07/05 Javascript
JS返回顶部实例代码
2020/08/09 Javascript
利用Javascript实现一套自定义事件机制
2017/12/14 Javascript
详解swipe使用及竖屏页面滚动方法
2018/06/28 Javascript
vue+axios+element ui 实现全局loading加载示例
2018/09/11 Javascript
JS中FormData类实现文件上传
2020/03/27 Javascript
vue脚手架项目创建步骤详解
2021/03/02 Vue.js
js面向对象方式实现拖拽效果
2021/03/03 Javascript
Python的ORM框架SQLAlchemy入门教程
2014/04/28 Python
在Ubuntu系统下安装使用Python的GUI工具wxPython
2016/02/18 Python
解决运行django程序出错问题 'str'object has no attribute'_meta'
2020/07/15 Python
Python 如何测试文件是否存在
2020/07/31 Python
Python使用Turtle模块绘制国旗的方法示例
2021/02/28 Python
美国南部最大的家族百货公司:Belk
2017/01/30 全球购物
英国户外玩具儿童游乐设备网站:TP Toys(蹦床、攀爬框架、秋千、滑梯和游戏屋)
2018/04/09 全球购物
英国独特礼物想法和个性化礼物网站:notonthehighstreet.com
2018/04/16 全球购物
美国家庭鞋店:Shoe Sensation
2019/09/27 全球购物
我未来的职业规划范文
2014/01/11 职场文书
工作失误检讨书范文大全
2014/01/13 职场文书
运动会入场解说词300字
2014/01/25 职场文书