当前位置: 首页 > article >正文

别再死记硬背了!用Python代码复现凯撒密码和维吉尼亚密码,5分钟搞懂古典密码学

用Python代码复现凯撒密码和维吉尼亚密码5分钟掌握古典密码学精髓古典密码学不仅是现代加密技术的基石更是一把打开计算机安全思维的钥匙。当我们用Python亲手实现这些诞生于两千年前的加密算法时会发现它们精妙的设计思想至今仍在影响我们的数字安全体系。本文将通过可运行的代码示例带你穿越时空体验密码学的进化历程。1. 为什么需要学习古典密码在量子计算和AES加密成为热点的今天学习凯撒密码这类古老玩具似乎有些不合时宜。但真正做过密码开发的人都知道理解古典密码的三大价值思维训练古典密码展现了最纯粹的加密思想是理解混淆、扩散等现代密码学概念的绝佳入口安全启蒙通过破解这些简单密码能建立对侧信道攻击、频率分析等技术的直觉认知历史传承维吉尼亚密码的多表替代思想直接催生了现代流密码的设计范式# 古典密码与现代密码的传承关系示意 class CipherEvolution: def __init__(self): self.ancient [凯撒密码, 维吉尼亚密码] self.modern [AES, ChaCha20] def show_lineage(self): return f{ → .join(self.ancient)} → 现代{self.modern[1]}流密码2. 凯撒密码轮转的艺术公元前58年凯撒大帝用这个简单的字母移位方法保护军事通信。其核心是模运算思想——当字母移动超出范围时从另一端继续计数。2.1 加密算法实现凯撒密码的数学表达为加密E(x) (x key) mod 26解密D(x) (x - key) mod 26def caesar_encrypt(text: str, shift: int) - str: result [] for char in text: if char.isupper(): result.append(chr((ord(char) shift - 65) % 26 65)) elif char.islower(): result.append(chr((ord(char) shift - 97) % 26 97)) else: result.append(char) return .join(result) # 示例向右移动3位 plaintext ATTACK at dawn encrypted caesar_encrypt(plaintext, 3) # 输出DWWDFN dw gdzq2.2 安全缺陷与破解演示凯撒密码的致命弱点在于密钥空间太小仅25种可能通过频率分析可以轻松破解from collections import Counter def frequency_attack(ciphertext: str): freq Counter(c for c in ciphertext if c.isalpha()) common_letter freq.most_common(1)[0][0] # 假设密文中最高频字母对应明文的e probable_shift (ord(common_letter) - ord(e)) % 26 return caesar_encrypt(ciphertext, -probable_shift) # 破解示例 cracked_text frequency_attack(DWWDFN dw gdzq) # 可能输出原始明文3. 维吉尼亚密码多表替代的革命16世纪法国 cryptographer Blaise de Vigenère 提出的改进方案通过引入密钥字实现动态位移有效抵抗了单一字母频率分析。3.1 加密过程解析维吉尼亚密码的核心创新在于使用关键词作为位移模式每个明文字母采用不同的位移量形成周期性多表替代系统def vigenere_encrypt(text: str, keyword: str) - str: key_repeated (keyword * (len(text) // len(keyword) 1))[:len(text)] result [] for i, char in enumerate(text): if char.isalpha(): shift ord(key_repeated[i].upper()) - 65 result.append(caesar_encrypt(char, shift)) else: result.append(char) return .join(result) # 使用关键词KEY加密 vigenere_encrypt(meet me at midnight, KEY) # 输出WIQC WI KE AQVLWIQC3.2 安全增强与局限虽然维吉尼亚密码安全性显著提升但仍有被攻破的可能攻击方法原理防御难度卡西斯基测试寻找重复密文片段推断密钥长度中等弗里德曼测试统计字母分布偏差较高已知明文攻击利用部分已知明文-密文对高def find_repeats(ciphertext: str, min_len3): 卡西斯基测试核心代码 repeats {} for i in range(len(ciphertext) - min_len): segment ciphertext[i:imin_len] if segment in repeats: repeats[segment].append(i) else: repeats[segment] [i] return {k:v for k,v in repeats.items() if len(v)1}4. 从古典到现代密码学思维演进当我们对比这两种古典密码会发现它们已经蕴含了现代密码设计的核心要素凯撒密码的启示算法公开性Kerckhoffs原则雏形密钥保密的重要性暴力破解的威胁维吉尼亚密码的贡献引入密钥扩展概念多轮变换思想混淆与扩散的早期实践# 现代密码学中的维吉尼亚思想变体 class ModernVigenere: def __init__(self, key): self.key self._key_expansion(key) def _key_expansion(self, key): 类似AES的密钥扩展算法 return key * 4 # 简化的示例 def encrypt(self, plaintext): # 模拟CTR模式加密 return bytes([p ^ k for p,k in zip(plaintext, self.key)])5. 动手实验构建完整加密系统让我们综合运用两种古典密码创建一个增强版加密方案先用维吉尼亚密码混淆明文结构再用凯撒密码进行二次加密添加简单的校验机制class EnhancedCipher: def __init__(self, vigenere_key: str, caesar_shift: int): self.v_key vigenere_key self.c_shift caesar_shift def encrypt(self, text: str) - str: # 第一阶段维吉尼亚加密 stage1 vigenere_encrypt(text, self.v_key) # 第二阶段凯撒加密 stage2 caesar_encrypt(stage1, self.c_shift) # 添加校验值简单示例 checksum sum(ord(c) for c in stage2) % 100 return f{stage2}${checksum:02d} def decrypt(self, ciphertext: str) - str: # 验证校验和 msg, checksum ciphertext.rsplit($, 1) if sum(ord(c) for c in msg) % 100 ! int(checksum): raise ValueError(Checksum mismatch!) # 逆向解密 stage1 caesar_encrypt(msg, -self.c_shift) return vigenere_encrypt(stage1, self.v_key) # 维吉尼亚解密与加密相同在实际项目中测试这个混合加密器cipher EnhancedCipher(SECRET, 5) encrypted cipher.encrypt(Top secret message) decrypted cipher.decrypt(encrypted) # 应恢复原始明文通过这个实验我们可以直观感受到现代加密算法本质上都是在解决古典密码暴露出的安全问题只是数学复杂度更高、实现机制更精密。

相关文章:

别再死记硬背了!用Python代码复现凯撒密码和维吉尼亚密码,5分钟搞懂古典密码学

用Python代码复现凯撒密码和维吉尼亚密码:5分钟掌握古典密码学精髓 古典密码学不仅是现代加密技术的基石,更是一把打开计算机安全思维的钥匙。当我们用Python亲手实现这些诞生于两千年前的加密算法时,会发现它们精妙的设计思想至今仍在影响我…...

FPGA图像处理避坑指南:运动目标检测中的形态学滤波与包围盒算法实战解析

FPGA图像处理实战:运动目标检测中的形态学滤波与包围盒算法优化 在工业检测、智能监控和自动驾驶等领域,实时运动目标检测一直是核心需求。FPGA凭借其并行处理能力和低延迟特性,成为实现实时图像处理的理想平台。但要将算法高效部署到FPGA上&…...

R3nzSkin英雄联盟换肤工具终极指南:从零开始到实战精通

R3nzSkin英雄联盟换肤工具终极指南:从零开始到实战精通 【免费下载链接】R3nzSkin Skin changer for League of Legends (LOL) 项目地址: https://gitcode.com/gh_mirrors/r3n/R3nzSkin R3nzSkin是一款专为英雄联盟(League of Legends&#xff09…...

告别MongoDB?我用RedisJSON重构了Node.js项目的用户会话缓存(附性能对比)

告别MongoDB?我用RedisJSON重构了Node.js项目的用户会话缓存(附性能对比) 在构建现代Web应用时,会话管理一直是后端架构的核心挑战之一。当我们的电商平台用户量突破百万后,传统的MongoDB会话存储开始暴露出明显的性能…...

番茄小说下载器终极指南:3种界面轻松实现离线阅读自由

番茄小说下载器终极指南:3种界面轻松实现离线阅读自由 【免费下载链接】Tomato-Novel-Downloader 番茄小说下载器不精简版 项目地址: https://gitcode.com/gh_mirrors/to/Tomato-Novel-Downloader 你是否厌倦了只能在特定平台上在线阅读小说?是否…...

Appium MCP Server:用自然语言驱动移动端自动化测试

1. 项目概述:当AI助手学会“玩手机”最近在捣鼓移动端自动化测试,发现了一个挺有意思的玩意儿:Appium MCP Server。简单来说,它就像给Appium这个老牌自动化测试框架装上了“AI大脑”,让它能听懂人话,直接跟…...

深入解析Feign

一、前言 在微服务架构中,服务间的远程调用是最基础也是最高频的操作。如果你用过 RestTemplate,一定体会过那种手动拼接 URL、设置请求头、解析响应体的繁琐。Feign 的出现,就是为了让 HTTP 调用像调用本地方法一样简单。 二、发展历程:从 Netflix Feign 到 OpenFeign 2…...

八大网盘直链下载终极指南:LinkSwift高效配置与深度优化方案

八大网盘直链下载终极指南:LinkSwift高效配置与深度优化方案 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘 …...

初创公司如何通过 Taotoken 的 API 统一管理规避供应商锁定风险

初创公司如何通过 Taotoken 的 API 统一管理规避供应商锁定风险 1. 供应商锁定问题的技术本质 初创公司在构建大模型应用时,常面临供应商锁定(Vendor Lock-in)的技术风险。这种风险源于业务逻辑与特定模型 API 的深度耦合,当需要…...

Emacs集成GitHub/GitLab:gt.el插件实现编辑器内代码托管平台操作

1. 项目概述与核心价值如果你是一个Emacs用户,并且对在编辑器里高效浏览GitHub、GitLab这类代码托管平台有需求,那么你很可能已经厌倦了在浏览器和编辑器之间反复切换的割裂感。lorniu/gt.el这个项目,就是为了解决这个痛点而生的。简单来说&a…...

FPGA驱动S25FL256S实战:手把手教你用Verilog实现Quad SPI读写(附完整代码)

FPGA驱动S25FL256S实战:从零构建Quad SPI控制器 在嵌入式存储解决方案中,NOR Flash因其快速随机读取特性成为FPGA配置、固件存储的理想选择。S25FL256S作为Spansion(现Cypress)推出的256Mb Quad SPI Flash,支持最高133…...

从Gen1到Gen6:一文理清PCIe历代版本升级都带来了什么(带宽/编码/应用场景)

从Gen1到Gen6:PCIe技术演进与选型实战指南 当你在2023年组装一台高端游戏PC时,是否纠结过该选择PCIe 4.0还是5.0的SSD?当企业采购服务器时,面对不同代际的PCIe网卡和GPU,如何评估带宽需求与成本效益?这些问…...

LMK Pooling:长文本处理的分块重组与双通道特征提取技术

1. 项目概述:长上下文嵌入的痛点与突破 在自然语言处理领域,处理长文本一直是个棘手的问题。传统方法要么像Transformer那样受限于固定长度的注意力窗口,要么像RNN那样难以捕捉长距离依赖。LMK Pooling的出现,就像给长文本处理领域…...

别再装软件了!用macOS自带的sips命令,5分钟搞定PDF转图片、批量改尺寸

解锁macOS隐藏生产力:sips命令全场景应用指南 每天我们都在重复处理各种图片格式转换、尺寸调整的琐碎任务——将PDF论文截图转成清晰PNG插入报告、批量压缩手机照片用于上传、快速制作简易GIF表情包。这些看似简单的需求,往往让我们陷入安装臃肿软件或依…...

瑞萨RH850 FCL/FDL/EEL库怎么选?一张图看懂Flash自编程、数据存储与EEPROM仿真的区别

瑞萨RH850三大Flash库深度解析:FCL/FDL/EEL选型指南与实战对比 第一次接触瑞萨RH850的Flash操作库时,面对FCL、FDL、EEL这三个缩写字母组合,大多数嵌入式工程师都会陷入短暂的迷茫——它们看起来都涉及Flash操作,但具体差异在哪&a…...

基于React与SQLite的求职数据分析仪表盘:架构设计与工程实践

1. 项目概述与核心价值 最近在GitHub上看到一个挺有意思的项目,叫“JustAJobApp/jobseeker-analytics”。光看名字,你大概能猜到这玩意儿跟求职分析有关。没错,这是一个专门为求职者设计的开源数据分析工具。我自己也经历过海投简历、面试、等…...

Telegram集成GPT:构建智能聊天机器人的架构设计与部署实践

1. 项目概述:当Telegram遇上GPT,一个全能AI助手的诞生最近在折腾一个挺有意思的项目,叫“Helixform/TeleGPT”。简单来说,它就是一个运行在Telegram上的AI机器人。你不需要懂什么复杂的API调用,也不用去OpenAI的官网排…...

从Nginx ConfigMap到Higress路由:一个‘Hello World’服务在K8s里的完整流量旅程

从Nginx ConfigMap到Higress路由:一个‘Hello World’服务在K8s里的完整流量旅程 当你在浏览器中输入192.168.21.223:1105并按下回车时,背后发生了什么?这个简单的HTTP请求如何在Kubernetes集群中穿越层层组件,最终从Nginx Pod返回…...

8位DAC提升至12位分辨率的4种嵌入式方案解析

1. 从8位DAC突破到12位分辨率的技术解析在嵌入式系统设计中,数模转换器(DAC)的性能往往成为整个系统精度的瓶颈。传统8位DAC仅能提供256个离散输出电平,对于需要更高精度的应用场景(如精密仪器控制、音频处理等&#x…...

免费付费全攻略:手把手教你获取12.5米/5米高精度DEM数据

高精度DEM数据获取实战指南:从免费资源到商业解决方案 在数字地形分析领域,分辨率12.5米和5米的DEM数据已成为工程规划与科研项目的黄金标准。这类数据能够精确呈现地形起伏细节,为水利工程设计、地质灾害评估、通信基站选址等专业应用提供可…...

抖音音频提取终极指南:免费开源工具实现无损音乐批量下载

抖音音频提取终极指南:免费开源工具实现无损音乐批量下载 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback su…...

密集检索技术解析与Trove工具包实践指南

1. Trove工具包核心价值解析密集检索(Dense Retrieval)作为现代信息检索系统的核心技术,正在彻底改变我们处理海量文本数据的方式。与依赖关键词匹配的传统稀疏检索不同,密集检索通过深度神经网络将查询和文档映射到稠密向量空间&…...

别只刷题了!用这5个心理学模型,真正看懂你的情绪与行为模式

解码情绪与行为:5个心理学模型帮你跳出思维陷阱 1. 情绪ABC模型:重新定义你的情绪触发点 情绪ABC模型由心理学家阿尔伯特艾利斯提出,它彻底改变了我们对情绪反应的理解方式。这个模型将情绪产生过程分解为三个关键环节: A&#xf…...

强化学习数据效率优化:多阶段过滤框架解析

1. 强化学习中的数据效率困境在强化学习领域,我们常常面临一个核心矛盾:算法需要大量试错数据来学习有效策略,但实际环境中获取高质量数据的成本极高。我在工业级机器人控制项目中发现,未经处理的原始训练数据中往往包含大量低效甚…...

声明式数据可视化:从原理到实践,构建高性能交互图表

1. 项目概述:从“stravu/crystal”看现代数据可视化工具的演进最近在折腾一个数据可视化项目,偶然间在GitHub上看到了一个名为“stravu/crystal”的仓库。这个标题乍一看有点抽象,stravu像是个组织或用户名,crystal(水…...

Python逆向工程入门:用dis模块‘透视’你的.pyc文件

Python逆向工程实战:用dis模块解析字节码的底层逻辑 在软件开发和安全研究领域,逆向工程一直是个充满挑战又极具价值的技能。对于Python开发者而言,理解字节码不仅是深入语言内部机制的窗口,更是进行代码审计、性能优化和安全分析…...

构建agent调用skill:构建完成skill之后我怎么构建agent调用skill

构建完成这个技能之后我怎么才能够构建一个优质的agent,之后在我自己的项目中就能够实现技能的调用是通过agent实现的 目录 构建完成这个技能之后我怎么才能够构建一个优质的agent,之后在我自己的项目中就能够实现技能的调用是通过agent实现的 一、核心原理:Agent调用自定义…...

Convex与Better Auth集成:构建实时安全的现代Web认证系统

1. 项目概述:为什么选择 Convex Better Auth? 在构建现代 Web 应用时,身份认证(Authentication)和授权(Authorization)是两块绕不开的基石。然而,自己从零搭建一套安全、健壮且功能…...

扩散模型在工业缺陷检测中的应用与优化

1. 工业缺陷检测中的扩散模型技术概述 工业质检领域正经历一场由生成式AI带来的技术变革。作为一名在计算机视觉领域深耕多年的算法工程师,我见证了传统方法(如SVM、随机森林)到深度学习的演进,而扩散模型的出现则为这个领域带来了…...

别再memcpy了!手写C++ Vector时,二维数组拷贝为何总出错?深度解析深浅拷贝陷阱

从内存布局看C二维Vector拷贝&#xff1a;为什么你的自定义容器总崩溃&#xff1f; 当你在GitHub上找到一个"手写STL Vector教程"并兴奋地实现自己的容器类时&#xff0c;一维数据测试一切正常。但当你尝试拷贝一个vector<vector<int>>时&#xff0c;程序…...