温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

python如何实现凯撒密码

发布时间:2021-04-16 10:33:13 来源:亿速云 阅读:652 作者:小新 栏目:开发技术

小编给大家分享一下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如何实现凯撒密码”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI