• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    python实现凯撒密码

    在密码学中,凯撒密码(或称恺撒加密、恺撒变换、变换加密)是一种最简单且最广为人知的加密技术。它是一种替换加密的技术。这个加密方法是以恺撒的名字命名的,当年恺撒曾用此方法与其将军们进行联系。恺撒密码通常被作为其他更复杂的加密方法中的一个步骤,例如维吉尼亚密码。恺撒密码还在现代的ROT13系统中被应用。但是和所有的利用字母表进行替换的加密技术一样,恺撒密码非常容易被破解,而且在实际应用中也无法保证通信安全。

    尽管是最简单的加密技术,但那该怎么在python中如何现实呢?

    代码如下:

    def ask():
     while True:
      print("Welcome to you coming!")
      print("you can choose mode : encrypt(e) or decrypt(d)")  #有解密和加密模式
      print("If you choose encrypt ,you can lock the message!") #加密提示
      print("If you choose decrypt ,you can unlock the message!") #解密提示
      print("If you wanna exit , input 'q'!!")     #退出提示
      mode = input("choose:").lower()        #将输入的模式进行变换(从大写变小写,小写部分不变)
      if mode in 'encrypt e decrypt d q'.split():     #当模式是被要求的encrypt e(加密模式)decrypt d(解密模式) q(退出)时进行下一步操作
       #print(mode)           #打印输入的模式
       return mode            #将mode的值作为返回值
      else:
       print('Please input right option!!')     #输出提示
    
    
    def getKey(mode):
     key = 0               #设置默认的key
     while key = 0 or key >= 26:         #限制key的范围在(1-25以内的数)
      try:              #这里进行异常处理,将非整数类型的输入进行错误提示打印
       key = int(input("Please input your key:(1-26)"))
      except:
       print("Please input correct number!!")
     #对解密的密匙进行变换
     if mode == 'd' or mode == 'decrypt':
      key = -key
     return key
    
    def getMessage(key):
     #输入信息
     while True:
      informetion = input("Please input message!!")    #输入要解密或者加密的信息
      if informetion.isalpha():         #判断输入的字符串是否为纯字母
       break
      else:
       print("Please input continuous character!!!")   #输错提示
     message = ''             #设置输出的初始值
     for x in informetion:           #将输入信息里的进行逐一字母加密/解密
      num = ord(x)            #将单一字符通过ascii表进行转换,将字母转换为数字
      num += key             #加上key的值进行下列运算
      if x.isupper():            #判断是否是大写字母
       if num > ord('Z'):          #对超出ascii对应数值的范围进行处理
        num -=26
        print(message)
       elif num  ord('A'):
        num +=26
        print(message)
      elif x.islower():           #判断是否小写字母
       if num > ord('z'):
        num -=26
       elif num  ord('a'):
        num +=26
      message += chr(num)           #将单一字符通过ascii表进行转换,将数字转换为字母
     return message             #返回message的值
      
    if __name__=="__main__":           #主程序
     mode = ask()             #将ask()返回值存于mode变量中
     if mode == 'q':             #进行退出判断
      print('welcome!!')
     else:
      key = getKey(mode)            #将mode变量的值带入getKey函数中运行,运行后将key的值存入到key变量中
      last = getMessage(key)          #将key变量的值带入到getMessage函数中,运行后将message的值存入到last变量中
      print(last) 

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

    您可能感兴趣的文章:
    • python 密码学示例——凯撒密码的实现
    • Python实现的凯撒密码算法示例
    • python实现凯撒密码、凯撒加解密算法
    • 利用python实现凯撒密码加解密功能
    • Python编程实现凯撒密码加密示例
    上一篇:人脸识别具体案例(李智恩)
    下一篇:python爬虫之教你如何爬取地理数据
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    python实现凯撒密码 python,实现,凯撒,密码,python,