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

从凯撒密码到AES:用Python手把手实现5种加密算法,理解它们的本质区别

从凯撒密码到AES用Python手把手实现5种加密算法理解它们的本质区别加密技术就像数字世界的隐形护盾从古罗马战场的密信到现代银行的在线交易算法进化史就是一部人类与破解者斗智斗勇的编年史。今天我们将用Python这把解剖刀逐层揭开五种典型加密算法的神秘面纱——不只是调用现成库函数而是从零开始编写简化版本在代码实践中感受密码学思维的演变。无论你是想为个人项目添加基础安全防护还是计划系统学习网络安全这场从古典到现代的加密之旅都会让你收获远超API文档的深刻认知。1. 凯撒密码加密算法的Hello World公元前58年凯撒大帝用字母位移3位的简单规则保护军事情报这种加密方式如今看来就像用纸箱当防弹衣但却是理解加密本质的绝佳起点。其核心思想是替换式加密——每个明文字母被字母表中固定距离后的字母替代。def caesar_encrypt(plaintext, shift3): ciphertext for char in plaintext.lower(): if char.isalpha(): shifted ord(char) shift if shifted ord(z): shifted - 26 ciphertext chr(shifted) else: ciphertext char return ciphertext print(caesar_encrypt(ATTACK AT DAWN)) # 输出: dwwdfn dw gdzq这个26行代码的实现暴露了凯撒密码的致命弱点密钥空间极小仅有25种有效位移可能频率分析攻击英语字母出现频率分布明显如e出现率约12.7%无混淆扩散明文结构特征完整保留现代安全启示即使将位移量作为密钥key凯撒密码也因缺乏复杂的混淆confusion和扩散diffusion机制而毫无安全性可言。2. 维吉尼亚密码多表替换的文艺复兴16世纪法国外交官Blaise de Vigenère发明的同名密码实际由Giovan Battista Bellaso首创通过引入密钥词实现周期性多表替换显著提升了安全性。其核心突破是相同的明文字母在不同位置可能被替换为不同密文字母。def vigenere_encrypt(plaintext, keyword): keyword keyword.lower() ciphertext [] key_index 0 for char in plaintext.lower(): if char.isalpha(): shift ord(keyword[key_index % len(keyword)]) - ord(a) encrypted ord(a) (ord(char) - ord(a) shift) % 26 ciphertext.append(chr(encrypted)) key_index 1 else: ciphertext.append(char) return .join(ciphertext) print(vigenere_encrypt(meet me at the park, key)) # 输出: wijv wi qd xvr qevq维吉尼亚密码的安全性取决于密钥长度短密钥仍可能被Kasiski测试破解密钥随机性自然语言密钥存在模式特征重复周期相同密钥片段加密的明文会呈现统计规律安全要素凯撒密码维吉尼亚密码密钥空间2526^mm为密钥长度抗频率分析❌⚠️短密钥时多表替换❌✅3. XOR流密码二进制时代的轻量级方案异或XOR运算因其可逆性成为最简单的加密操作之一A ⊕ key ciphercipher ⊕ key A。这种逐比特处理的特性使其非常适合流密码实现也是现代加密算法的基本构件。import os def xor_encrypt(plaintext, key): # 生成与明文等长的随机密钥流 if isinstance(key, int): key bytes([key] * len(plaintext)) return bytes([p ^ k for p, k in zip(plaintext, key)]) # 使用示例 plaintext bSecret Message key os.urandom(len(plaintext)) # 推荐使用加密安全随机数 ciphertext xor_encrypt(plaintext, key) decrypted xor_encrypt(ciphertext, key) assert decrypted plaintext # 解密验证XOR密码的安全隐患包括密钥重用攻击c1 ⊕ c2 p1 ⊕ p2会泄露明文关系低熵密钥非随机密钥如密码派生易受统计攻击无完整性保护密文可被任意篡改而不被发现重要应用当密钥与明文等长且完全随机时XOR密码构成理论上不可破解的一次性密码本One-Time Pad但密钥分发难题限制了其实际应用。4. SHA-256哈希数字指纹的工业标准哈希函数将任意长度输入压缩为固定长度输出如SHA-256的256位具有单向性不可逆和抗碰撞难以找到相同输出的不同输入特性。现代密码学中哈希广泛用于密码存储、数字签名和区块链等场景。import hashlib def hash_message(message): # 创建sha256对象 sha256 hashlib.sha256() # 更新哈希对象支持分块处理大文件 sha256.update(message.encode(utf-8)) # 获取16进制格式的哈希值 return sha256.hexdigest() print(hash_message(Hello Crypto)) # 输出: 4a6f8f7e...哈希算法的关键安全属性确定性相同输入永远产生相同输出雪崩效应微小输入变化导致输出剧变前像抵抗难以通过输出反推输入抗第二前像攻击给定输入1难找输入2使hash(1)hash(2)哈希算法输出长度安全性状态典型应用场景MD5128-bit已破解文件校验非安全场景SHA-1160-bit理论破解逐步淘汰中SHA-256256-bit目前安全比特币、TLS证书SHA-3可变新一代标准高安全需求系统5. AES加密对称加密的黄金标准高级加密标准AES作为现代对称加密的典范采用替换-置换网络SPN结构和多轮加密机制。虽然完整实现涉及复杂的数学运算但我们可以通过Python标准库体验其强大功能from Crypto.Cipher import AES from Crypto.Random import get_random_bytes import base64 def aes_encrypt(plaintext, keyNone): # 生成16字节AES-128随机密钥若未提供 key key or get_random_bytes(16) # 创建加密器CBC模式需要初始化向量IV cipher AES.new(key, AES.MODE_CBC) # 明文需要填充至16字节倍数 pad_len 16 - (len(plaintext) % 16) padded plaintext bytes([pad_len] * pad_len) # 加密并返回IV密文便于解密 ciphertext cipher.encrypt(padded) return base64.b64encode(cipher.iv ciphertext).decode() def aes_decrypt(encrypted, key): data base64.b64decode(encrypted) iv, ciphertext data[:16], data[16:] cipher AES.new(key, AES.MODE_CBC, iviv) padded cipher.decrypt(ciphertext) pad_len padded[-1] return padded[:-pad_len] # 使用示例 key get_random_bytes(16) # 保存好密钥 secret_msg Confidential Data.encode() encrypted aes_encrypt(secret_msg, key) print(f加密结果: {encrypted}) decrypted aes_decrypt(encrypted, key) print(f解密结果: {decrypted.decode()})AES的核心优势体现在密钥灵活性支持128/192/256位密钥长度高效实现硬件加速下可达GB/s级吞吐量安全验证历经20余年高强度密码分析仍保持安全实际部署时还需注意模式选择ECB模式不安全推荐CBC或GCM密钥管理密钥需要安全存储和分发完整性验证结合HMAC防止篡改从凯撒密码到AES的演进路线清晰地展现了密码学发展的三个关键跃迁密钥空间的指数级扩展25→2^128、加密操作从字符级到比特级的转变以及从简单替换到复杂数学结构的跨越。在亲手实现这些算法的过程中最深刻的体会是现代加密算法并非依靠隐蔽性security through obscurity而是基于严格的数学难题和经过公开验证的设计原则。

相关文章:

从凯撒密码到AES:用Python手把手实现5种加密算法,理解它们的本质区别

从凯撒密码到AES:用Python手把手实现5种加密算法,理解它们的本质区别 加密技术就像数字世界的隐形护盾,从古罗马战场的密信到现代银行的在线交易,算法进化史就是一部人类与破解者斗智斗勇的编年史。今天我们将用Python这把"解…...

一款基于 .NET 开源、跨平台应用程序自动升级组件适

基础示例:单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤: 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

04-微服务篇

文章目录一、Spring Cloud1. Spring Cloud 5大组件有哪些?2. 服务注册和发现是什么意思?Spring Cloud 如何实现服务注册发现?3. 我看你之前也用过nacos,你能说下nacos与eureka的区别?4. 你们项目负载均衡如何实现的&am…...

微星主板无U更新BIOS

客户的微星PRO B650M-P 主板升级9600X cpu 开不了机,手头也没低点的U 看了下主板支持Flash BIOS Button 也就是无U盲刷BIOS 首先 U 盘需要格式化FAT32 格式 ,然后 官网下载最新BIOS解压缩后修改文件名需成 MSI.ROM ,然后复制到U盘根目录 ,插入主板BIOS USB接口 然后 插上CPU 供…...

重新定义窗口自由:SRWE如何解锁任意程序的分辨率限制

重新定义窗口自由:SRWE如何解锁任意程序的分辨率限制 【免费下载链接】SRWE Simple Runtime Window Editor 项目地址: https://gitcode.com/gh_mirrors/sr/SRWE 你是否曾因软件窗口无法调整到理想尺寸而感到束手无策?当游戏只支持有限分辨率、专业…...

把近万个源文件喂给AI之前,我先做了一件事刀

插件化架构 v3 版本最大的变化是引入了模块化插件系统。此前版本中集成在核心包里的原生功能,现在被拆分成独立的插件。 每个插件都是一个独立的 Composer 包,包含 Swift 和 Kotlin 代码、权限清单以及原生依赖。开发者只需安装实际用到的插件&#xff0…...

Windows 11下ROS2 Humble与PyCharm无缝集成实战(避坑指南+完整配置流程)

Windows 11下ROS2 Humble与PyCharm无缝集成实战(避坑指南完整配置流程) 在机器人操作系统(ROS)生态中,Windows平台的支持一直是个挑战。随着ROS2 Humble版本的发布,微软与开源社区的深度合作为Windows开发者…...

Linux内核中的命名空间详解

Linux内核中的命名空间详解 引言 命名空间(Namespace)是Linux内核中实现资源隔离的重要机制,它为容器技术提供了基础支持。通过命名空间,不同的进程可以看到不同的系统视图,实现了进程间的隔离。本文将深入探讨Linux内…...

手把手调参:解决OpenCV光流法追踪“跟丢”和“鬼影”的实战指南

手把手调参:解决OpenCV光流法追踪“跟丢”和“鬼影”的实战指南 去年在开发一套工业质检系统时,我们遇到了一个棘手问题:传送带上的零件因为表面反光和快速移动,导致光流追踪频繁丢失目标。经过两周的密集调参和算法优化&#xff…...

Linux内核中的热插拔详解

Linux内核中的热插拔详解 引言 热插拔(Hotplug)是Linux内核中的一项重要功能,它允许在系统运行时动态添加或移除硬件设备,无需重启系统。热插拔技术大大提高了系统的灵活性和可用性,广泛应用于服务器、工作站和嵌入式系…...

从玩具四轴到工业机械臂:无刷电机120度与180度导通角该怎么选?实战经验分享

从玩具四轴到工业机械臂:无刷电机120度与180度导通角该怎么选?实战经验分享 当你在设计一台需要精确控制的无人机或工业机械臂时,无刷电机的驱动策略选择往往成为决定项目成败的关键因素之一。我曾见过一个团队花费数月时间优化机械臂算法&am…...

LangGraph架构深度解析:如何构建企业级状态化智能体工作流

LangGraph架构深度解析:如何构建企业级状态化智能体工作流 【免费下载链接】langgraph Build resilient language agents as graphs. 项目地址: https://gitcode.com/GitHub_Trending/la/langgraph LangGraph是一个基于Pregel算法的低层级编排框架&#xff0…...

根据WFWORKITEM 表的< PROCESSDEFNAME>字段关联WFPROCESSDEFPROPERTIES表获取对应app_code

问题描述&#xff1a; 根据WFWORKITEM 表的< PROCESSDEFNAME>字段关联WFPROCESSDEFPROPERTIES表获取对应app_code 解答: 因为WFPROCESSDEFPROPERTIES表在同一个<tenant_id>&#xff08;租户&#xff09;的<PROCESSDEFNAME>值是唯一的&#xff0c; 所以可…...

Linux I/O 演进史:从管道到零拷贝,一篇串起个服务端核心原语于

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时&#xff0c;输出结果中包含大量由集群自动生成的元数据&#xff08;如 managedFields、resourceVersion、uid 等&#xff09;。这些信息在实际复用 yaml 清单时需要手动清理&#xff0c;增加了额外的工作量。 使用 kube…...

RIGOL DS2302A-S数字示波器:高性能信号分析的终极解决方案

1. 为什么工程师都爱用RIGOL DS2302A-S&#xff1f; 第一次接触RIGOL DS2302A-S是在调试一块高速PCB板时&#xff0c;当时手头的示波器死活抓不到那个诡异的时钟抖动。同事把他的DS2302A-S推过来&#xff0c;300MHz带宽配合2GSa/s采样率&#xff0c;瞬间就让那个藏在噪声里的3n…...

Windows注册表深度解析:核心结构与关键应用场景

1. Windows注册表的核心结构解析 第一次打开注册表编辑器时&#xff0c;那个树状结构的界面可能会让人望而生畏。但当你理解它的设计逻辑后&#xff0c;会发现这个"系统大管家"其实很有条理。注册表的核心是五大根键&#xff08;Root Key&#xff09;&#xff0c;每个…...

科哥Face Fusion镜像:UI界面自定义修改,实现边框特效的保姆级教程

科哥Face Fusion镜像&#xff1a;UI界面自定义修改&#xff0c;实现边框特效的保姆级教程 1. 从基础融合到创意特效的升级之路 如果你已经体验过科哥Face Fusion镜像的基础人脸融合功能&#xff0c;可能会好奇&#xff1a;这个强大的工具能否进一步个性化&#xff1f;比如为合…...

Piggy_Packages V2026.1 帮助文档(九)模式评估

获取Piggy_Packages 还没有Piggy_Packages的同学&#xff0c;请参考这篇帖子获取&#xff1a; Piggy_Packages V2026.1 帮助文档&#xff08;一&#xff09;开箱即用 模型评估工具&#xff08;MET&#xff09;是一种常用的对WRF预报结果进行评估的工具。今天我们来学习一项它…...

深入探讨Android Framework开发工程师:职责、技术与面试指南

引言 Android Framework开发工程师是移动操作系统领域的核心角色,负责构建和维护Android系统的底层框架。该岗位要求深入理解系统架构,解决性能瓶颈,并确保应用稳定性。随着Android生态的快速发展,掌握Framework开发技术成为高级工程师的必备技能。本文基于标准职位描述,…...

我试了四种去除 Gemini 水印的方法,整理成一篇实用对比驹

认识Pass层级结构 Pass范围从上到下一共分为5个层级&#xff1a; 模块层级&#xff1a;单个.ll或.bc文件 调用图层级&#xff1a;函数调用的关系。 函数层级&#xff1a;单个函数。 基本块层级&#xff1a;单个代码块。例如C语言中{}括起来的最小代码。 指令层级&#xff1a;单…...

基于蓝牙BLE芯片的无人机识别参考方案

蓝牙BLE芯片的底层能力&#xff0c;主要集中在射频信号处理、基带算法、网络协议栈以及低功耗全局优化几个方面。以市面上典型的方案为例&#xff0c;采用青稞RISC-V处理器内核作为计算核心&#xff0c;同时集成了USB、防水级触摸感应、NFC、段式LCD等多种外设接口。这意味着它…...

【大模型工程化生死线】:版本失控=线上崩盘?3步构建军工级回滚机制

第一章&#xff1a;大模型工程化版本管理与回滚机制 2026奇点智能技术大会(https://ml-summit.org) 大模型工程化中的版本管理远超传统软件的 Git commit 粒度&#xff0c;需同时追踪模型权重、Tokenizer 配置、训练超参、推理服务镜像及依赖环境快照。单一 SHA 哈希已无法承载…...

如何在 Go 中构建支持持久化存储的权威 DNS 服务器

本文介绍如何基于 miekg/dns 库实现具备持久化能力的权威 dns 服务器&#xff0c;涵盖原生 zone 文件支持、外部存储集成方案&#xff08;如 etcd&#xff09;&#xff0c;以及实际部署注意事项。 本文介绍如何基于 miekg/dns 库实现具备持久化能力的权威 dns 服务器&…...

GLM-4.1V-9B-Base效果展示:中文菜单图片→菜品识别→价格/辣度/推荐指数

GLM-4.1V-9B-Base效果展示&#xff1a;中文菜单图片→菜品识别→价格/辣度/推荐指数 1. 模型介绍 GLM-4.1V-9B-Base是智谱开源的一款视觉多模态理解模型&#xff0c;专门针对中文场景下的图像理解任务进行了优化。不同于普通的图像识别模型&#xff0c;它能够结合视觉内容和自…...

重新思考输入边界:QKeyMapper如何颠覆Windows平台输入设备协作范式

重新思考输入边界&#xff1a;QKeyMapper如何颠覆Windows平台输入设备协作范式 【免费下载链接】QKeyMapper [按键映射工具] QKeyMapper&#xff0c;Qt开发Win10&Win11可用&#xff0c;不修改注册表、不需重新启动系统&#xff0c;可立即生效和停止。支持游戏手柄映射到键鼠…...

LLM服务SLA跌破99.2%?(GPU资源利用率不足31%真相曝光)——弹性伸缩动态水位算法实战手册

第一章&#xff1a;LLM服务SLA跌破99.2%&#xff1f;——GPU资源利用率不足31%的系统性归因 2026奇点智能技术大会(https://ml-summit.org) 当大模型推理服务的端到端SLA连续三小时低于99.2%&#xff0c;而监控平台却显示A100集群平均GPU利用率长期徘徊在28%–31%之间时&#…...

江西市口碑好的专业中专学校哪家权威

江西市口碑好的专业中专学校哪家权威在江西省&#xff0c;选择一所口碑好且权威的专业中专学校对于学生未来的职业发展至关重要。赣州现代科技职业学校作为赣州市的一所知名职业高中&#xff0c;在教学质量、实训设施以及就业保障等方面都表现出色&#xff0c;是众多学子和家长…...

为什么92%的AI原生应用无法精准归因故障?曝光3个被忽视的OpenTelemetry SDK陷阱、2个LLM Token级Span拆分反模式

第一章&#xff1a;AI原生软件研发链路追踪系统搭建 2026奇点智能技术大会(https://ml-summit.org) AI原生软件的研发过程高度依赖模型版本、数据集快照、训练参数、推理服务部署状态及用户反馈信号的强关联性。传统APM工具难以刻画从Prompt工程→微调训练→RAG索引更新→LLM网…...

OpenCore Legacy Patcher终极指南:4步解决老Mac显卡驱动与系统升级问题

OpenCore Legacy Patcher终极指南&#xff1a;4步解决老Mac显卡驱动与系统升级问题 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 你是否还在为老款Mac无法升…...

语言介绍、软件安装、项目创建、输出语句、注释

C# 语言简绍C#是什么&#xff1f;1.C# 编程是基于 C 和 C 编程语言衍生出来的面向对象的编程语言2.C#是微软公司发布的一种面向对象的、运行于.NET Framework之上的高级程序设计语言。C#与C和C的对比1.C#是由C和C衍生出来的面向对象的编程语言。2.它在继承C和C强大功能的同时去…...