Go 语言简单实现Vigenere加密算法
来源:脚本之家
时间:2022-12-29 09:56:26 319浏览 收藏
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《Go 语言简单实现Vigenere加密算法》,聊聊算法、Vigenere、加密,我们一起来看看吧!
Vigenere 加密算法
该密码由意大利密码学家 Giovan Battista Bellaso 于 1553 年发明,但几个世纪以来一直归功于 16 世纪的法国密码学家 Blaise de Vigenère,他在 1586 年设计了类似的密码。
Vigenere Cipher 是一种加密字母文本的方法。它使用一种简单的多字母表替换形式。多字母密码是基于替换的任何密码,使用多个替换字母表。原始文本的加密是使用 Vigenère square 或 Vigenère table 完成的。
该表由在不同行中写出 26 次的字母组成,与前一个字母相比,每个字母循环向左移动,对应于 26 种可能的凯撒密码。
在最简单的 Vigenère 类型系统中,密钥是一个单词或短语,它可以根据需要重复多次以加密消息。如果密钥是欺骗性的,并且消息是我们被发现了,请自救,那么生成的密码将是
在加密过程的不同点,密码使用与其中一行不同的字母表。每个点使用的字母取决于重复的关键字。
又例如:
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 与密钥的第一个字母 A 配对。所以使用 Vigenère 正方形的 G 行和 A 列,即 G。同理,对于明文的第二个字母,使用密钥的第二个字母,E 行的字母,Y 列的字母是 C。明文以类似的方式加密。
解密的方法是到表中与密钥对应的行,找到该行中密文字母的位置,然后将该列的标签作为明文。例如,在 A 行(来自 AYUSH)中,密文 G 出现在 G 列中,这是第一个明文字母。接下来,我们转到 Y 行(来自 AYUSH),找到在 E 列中找到的密文 C,因此 E 是第二个明文字母。
一个更简单的实现可能是通过将 [A-Z] 转换为数字 [0-25] 以代数方式可视化 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") } }
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。
-
398 收藏
-
327 收藏
-
272 收藏
-
130 收藏
-
479 收藏
-
233 收藏
-
322 收藏
-
181 收藏
-
316 收藏
-
244 收藏
-
300 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 心灵美的季节
- 这篇文章内容真是及时雨啊,好细啊,很好,码住,关注作者大大了!希望作者大大能多写Golang相关的文章。
- 2023-04-23 16:36:57
-
- 无心的白羊
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者分享文章内容!
- 2023-04-08 15:04:49
-
- 高大的御姐
- 细节满满,mark,感谢老哥的这篇博文,我会继续支持!
- 2023-03-09 15:06:20
-
- 老迟到的自行车
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者大大分享技术文章!
- 2023-02-10 05:00:27
-
- 大方的凉面
- 这篇博文太及时了,好细啊,写的不错,已加入收藏夹了,关注大佬了!希望大佬能多写Golang相关的文章。
- 2023-02-06 10:36:59
-
- 受伤的高跟鞋
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢up主分享技术文章!
- 2023-01-15 21:27:55
-
- 害怕的花瓣
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢up主分享文章!
- 2023-01-15 11:47:21
-
- 威武的春天
- 这篇文章内容太及时了,太详细了,很好,码住,关注老哥了!希望老哥能多写Golang相关的文章。
- 2023-01-11 09:05:27
-
- 疯狂的枕头
- 太详细了,已收藏,感谢老哥的这篇文章内容,我会继续支持!
- 2023-01-08 07:08:47
-
- 羞涩的飞鸟
- 这篇技术贴出现的刚刚好,好细啊,太给力了,mark,关注up主了!希望up主能多写Golang相关的文章。
- 2023-01-04 04:26:13