CTF学记之维吉尼亚密码

编程入门 行业动态 更新时间:2024-10-08 06:20:13

CTF学记之维吉<a href=https://www.elefans.com/category/jswz/34/1736878.html style=尼亚密码"/>

CTF学记之维吉尼亚密码

2023.10.28

介绍

维吉尼亚密码(又译维热纳尔密码)是使用一系列凯撒密码组成密码字母表的加密算法,属于多表密码的一种简单形式。

维吉尼亚密码曾多次被发明。该方法最早记录在吉奥万·巴蒂斯塔·贝拉索( Giovan Battista Bellaso)于1553年所著的书《吉奥万·巴蒂斯塔·贝拉索先生的密码》(意大利语:La cifra del. Sig. Giovan Battista Bellaso)中。然而,后来在19世纪时被误传为是法国外交官布莱斯·德·维吉尼亚(Blaise De Vigenère)所创造,因此现在被称为“维吉尼亚密码”。

维吉尼亚密码以其简单易用而著称,同时初学者通常难以破解,因而又被称为“不可破译的密码”(法语:le chiffre indéchiffrable)。这也让很多人使用维吉尼亚密码来加密的目的就是为了将其破解。

加密过程

密码表:

假设秘钥为key

明文为ctfflag

第一步:

明文ctfflag
秘钥key

把秘钥循环链接

到与明文长度同长

keykeyk
在对照比密码表得出密文mxdppyq
密文mxdppyq

解码脚本实现:

def weijiniya_decode(ciphertext):ciphertext,alphabet = ciphertext.lower(),[chr(i+ord('a')) for i in range(26)]while True:key = input('请输入秘钥:\n').lower()if key.isalpha():breakelse:print('秘钥错误,请重输')key = [key[i%len(key)] for i in range(len(ciphertext))]i,j,text,dic = 0,0,'',{chr(i+ord('a')):i for i in range(26)}while j < len(ciphertext):if ciphertext[j] in dic:text += alphabet[(dic[ciphertext[j]] - dic[key[i]]) % 26];i += 1else: text += ciphertext[j]j += 1return text

更多推荐

CTF学记之维吉尼亚密码

本文发布于:2024-02-13 15:42:16,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1759282.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:尼亚   密码   学记   CTF

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!