Go?語(yǔ)言簡(jiǎn)單實(shí)現(xiàn)Vigenere加密算法
Vigenere 加密算法
該密碼由意大利密碼學(xué)家 Giovan Battista Bellaso 于 1553 年發(fā)明,但幾個(gè)世紀(jì)以來(lái)一直歸功于 16 世紀(jì)的法國(guó)密碼學(xué)家 Blaise de Vigenère,他在 1586 年設(shè)計(jì)了類(lèi)似的密碼。
Vigenere Cipher 是一種加密字母文本的方法。它使用一種簡(jiǎn)單的多字母表替換形式。多字母密碼是基于替換的任何密碼,使用多個(gè)替換字母表。原始文本的加密是使用 Vigenère square 或 Vigenère table 完成的。
該表由在不同行中寫(xiě)出 26 次的字母組成,與前一個(gè)字母相比,每個(gè)字母循環(huán)向左移動(dòng),對(duì)應(yīng)于 26 種可能的凱撒密碼。
在最簡(jiǎn)單的 Vigenère 類(lèi)型系統(tǒng)中,密鑰是一個(gè)單詞或短語(yǔ),它可以根據(jù)需要重復(fù)多次以加密消息。如果密鑰是欺騙性的,并且消息是我們被發(fā)現(xiàn)了,請(qǐng)自救,那么生成的密碼將是
在加密過(guò)程的不同點(diǎn),密碼使用與其中一行不同的字母表。每個(gè)點(diǎn)使用的字母取決于重復(fù)的關(guān)鍵字。
又例如:
Input : Plaintext : GEEKSFORGEEKS Keyword : AYUSH Output : Ciphertext : GCYCZFMLYLEIM For generating key, the given keyword is repeated in a circular manner until it matches the length of the plain text. The keyword "AYUSH" generates the key "AYUSHAYUSHAYU" The plain text is then encrypted using the process explained below.
加密:
明文的第一個(gè)字母 G 與密鑰的第一個(gè)字母 A 配對(duì)。所以使用 Vigenère 正方形的 G 行和 A 列,即 G。同理,對(duì)于明文的第二個(gè)字母,使用密鑰的第二個(gè)字母,E 行的字母,Y 列的字母是 C。明文以類(lèi)似的方式加密。
解密的方法是到表中與密鑰對(duì)應(yīng)的行,找到該行中密文字母的位置,然后將該列的標(biāo)簽作為明文。例如,在 A 行(來(lái)自 AYUSH)中,密文 G 出現(xiàn)在 G 列中,這是第一個(gè)明文字母。接下來(lái),我們轉(zhuǎn)到 Y 行(來(lái)自 AYUSH),找到在 E 列中找到的密文 C,因此 E 是第二個(gè)明文字母。
一個(gè)更簡(jiǎn)單的實(shí)現(xiàn)可能是通過(guò)將 [A-Z] 轉(zhuǎn)換為數(shù)字 [0-25] 以代數(shù)方式可視化 Vigenère。
Go 代碼
package main import ( "fmt" "strings" ) func encodeString(cipher, key rune) rune { const asciiA rune = 65 const numLetters = 26 plainTextIndex := cipher + key asciiLetter := (plainTextIndex+numLetters)%numLetters + asciiA return asciiLetter } func encode(message, kw string) string { var plainText strings.Builder kwChars := []rune(kw) for i, cipherChar := range message { key := i % len(kwChars) plainText.WriteRune(encodeString(cipherChar, kwChars[key])) } return plainText.String() } func decipherString(cipher, key rune) rune { const asciiA rune = 65 const numLetters = 26 plainTextIndex := cipher - key asciiLetter := (plainTextIndex+numLetters)%numLetters + asciiA return asciiLetter } func decipher(message, kw string) string { var plainText strings.Builder kwChars := []rune(kw) for i, cipherChar := range message { key := i % len(kwChars) plainText.WriteRune(decipherString(cipherChar, kwChars[key])) } return plainText.String() } func main() { fmt.Println("Enter Your string: ") var first string fmt.Scanln(&first) fmt.Println("Enter your KEY: ") var second string fmt.Scanln(&second) cipherText := first keyword := second fmt.Print("Do you want to 1. Encrypt or 2. Decrypt") var option int fmt.Scanln(&option) if option == 1 { fmt.Println(encode(cipherText, keyword)) } else if option == 2 { fmt.Println(decipher(cipherText, keyword)) } else { fmt.Println("please choose the right option") } }
到此這篇關(guān)于Go 語(yǔ)言簡(jiǎn)單實(shí)現(xiàn) Vigenere 加密算法的文章就介紹到這了,更多相關(guān)Go Vigenere 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
CSP communicating sequential processes并發(fā)模型
這篇文章主要為大家介紹了CSP communicating sequential processes并發(fā)模型,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05vim配置go語(yǔ)言語(yǔ)法高亮問(wèn)題的解決方法
vim配置go語(yǔ)言語(yǔ)法高亮的問(wèn)題已經(jīng)遇到過(guò)好幾次了,每次都是找不到答案,今天小編給大家?guī)?lái)了vim配置go語(yǔ)言語(yǔ)法高亮問(wèn)題的解決方法,感興趣的朋友一起看看吧2018-01-01Golang中json和jsoniter的區(qū)別使用示例
這篇文章主要介紹了Golang中json和jsoniter的區(qū)別使用示例,本文給大家分享兩種區(qū)別,結(jié)合示例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2023-12-12golang 進(jìn)度條功能實(shí)現(xiàn)示例
這篇文章主要介紹了golang 進(jìn)度條功能實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08使用Go語(yǔ)言實(shí)現(xiàn)微信公眾平臺(tái)
這篇文章主要介紹了使用Go語(yǔ)言實(shí)現(xiàn)微信公眾平臺(tái),雖然不是全部代碼,但是也是給我們提供了一個(gè)非常好的思路,需要的朋友可以參考下2015-01-01Golang的Crypto/SHA256庫(kù)實(shí)戰(zhàn)指南
無(wú)論是在保護(hù)數(shù)據(jù)安全、驗(yàn)證數(shù)據(jù)完整性,還是在構(gòu)建復(fù)雜的安全系統(tǒng)中,crypto/sha256都是Golang程序員不可或缺的工具,本文主要介紹了Golang的Crypto/SHA256庫(kù)實(shí)戰(zhàn)指南,感興趣的可以了解一下2024-02-02golang的Pseudo-versions使用問(wèn)題解析
這篇文章主要為大家介紹有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪了golang的Pseudo-versions使用問(wèn)題解析,2023-07-07