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)
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- None Found