CTF之密码学(埃特巴什码 )

一、基本原理

埃特巴什码的原理是:字母表中的最后一个字母代表第一个字母,倒数第二个字母代表第二个字母,以此类推。在罗马字母表中,对应关系如下:

  • 常文(明文):A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
  • 密文:Z Y X W V U T S R Q P O N M L K J I H G F E D C B A

二、发现者与历史背景

  • 发现者:埃特巴什码是由熊斐特博士发现的。熊斐特博士是库姆兰《死海古卷》的最初研究者之一,在《圣经》历史研究方面有着卓越的贡献,其最有名气的著作是《逾越节的阴谋》。
  • 历史背景:这种密码最初用于希伯来字母表,但可以用于任何字母表。它被运用在公元1世纪的艾赛尼/萨多吉/拿撒勒教派的经文中,用以隐藏姓名。此外,早在公元前500年,它就被抄经人用来写作《耶利米书》。耶利米是活动在公元前627~前586年间的犹太先知,圣经旧约书中有许多关于他的记载。

三、应用与示例

  • 应用:熊斐特博士运用埃特巴什码来研究别人利用其他方法不能破解的那些经文。此外,它还被用于隐藏和传递秘密信息。
  • 示例:以罗马字母表为例,若明文为"the quickbrownfoxjumpsover the lazy dog",则对应的密文为"gsvjfrxpyildm ulc qfnkh levi gsv ozab wlt"。

python解码程序

简单版

python 复制代码
def atbash_decode(txt):
    answer = ""
    for char in txt:
        if 'a' <= char <= 'z':  # 小写字母
            answer += chr(ord('z') - ord(char) + ord('a'))
        elif 'A' <= char <= 'Z':  # 大写字母
            answer += chr(ord('Z') - ord(char) + ord('A'))
        else:  # 非字母字符
            answer += char
    return answer

# 使用示例
txt = input("请输入要解码的文本: ")
print("解码后的文本:", atbash_decode(txt))

困难版

python 复制代码
lower = [chr(i) for i in range(ord('a'), ord('z') + 1)]
upper = [chr(i) for i in range(ord('A'), ord('Z') + 1)]


def kashidecode(txt):
    answer = ""
    for i in range(len(txt)):
        if txt[i].islower():
            # 找到当前小写字母在 lower 列表中的索引
            index = lower.index(txt[i])
            # 使用该索引从列表的末尾获取对应的字母
            answer += lower[-1 - index]
        elif txt[i].isupper():
            # 对大写字母做同样的处理
            index = upper.index(txt[i])
            answer += upper[-1 - index]
        else:
            # 非字母字符保持不变
            answer += txt[i]
    return answer


if __name__ == '__main__':
    txt = input("请输入要解码的文本: ")
    answer = kashidecode(txt)
    print("解码后的文本:", answer)
相关推荐
曲幽11 分钟前
FastAPI 生产环境静态文件完全指南:从 /favicon.ico 404 到 HSTS 混合内容,一次全根治
python·fastapi·web·static·media·404·hsts·favicon·url_for
Dontla12 分钟前
Python asyncpg库介绍(基于Python asyncio的PostgreSQL数据库驱动)连接池、SQLAlchemy
数据库·python·postgresql
zh15702320 分钟前
如何编写动态SQL存储过程_使用sp_executesql执行灵活查询
jvm·数据库·python
2401_8242226925 分钟前
SQL报表统计数据量巨大_分批统计策略
jvm·数据库·python
X566128 分钟前
mysql如何处理连接数过多报错_调整max_connections参数
jvm·数据库·python
m0_6091604942 分钟前
MongoDB中什么是Hashed Shard Key的哈希冲突_哈希函数的分布均匀性分析
jvm·数据库·python
Ulyanov43 分钟前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》 开发环境搭建与工具链极简主义 —— 拒绝臃肿,构建工业级基座
开发语言·python·qt·ui·架构·系统仿真
wuxinyan1231 小时前
大模型学习之路03:提示工程从入门到精通(第三篇)
人工智能·python·学习
如何原谅奋力过但无声1 小时前
【灵神高频面试题合集01-03】相向双指针、滑动窗口
数据结构·python·算法·leetcode
WHS-_-20221 小时前
Rank-Revealing Bayesian Block-Term Tensor Completion With Graph Information
人工智能·python·机器学习