Python实现RSA加解密算法

news/2024/9/14 9:38:35/ 标签: python, 算法, 网络, RSA, J密码学, 加密, 解密

目录

RSA_1">深入了解RSA加密算法

RSA(Rivest-Shamir-Adleman)是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman于1977年提出。作为非对称加密算法的典型代表,RSA被广泛用于数据加密和数字签名。本文将深入介绍RSA算法的工作原理,并展示如何使用Python从头实现RSA加密解密,而不依赖任何第三方加密库。


RSA_7">一、RSA算法概述

RSA是一种基于数论的非对称加密算法,利用了大数分解的计算复杂性。与对称加密算法不同,RSA使用一对密钥:公钥用于加密,私钥用于解密。这意味着即使加密密钥被公开,只有拥有解密密钥的人才能解密密文。

1.1 关键步骤

RSA加密算法的核心可以分为以下几个步骤:

  1. 密钥生成:

    • 选择两个大素数 p p p q q q,计算它们的乘积 n = p × q n = p \times q n=p×q。这个值 n n n将被用作公钥和私钥的一个组成部分。
    • 计算欧拉函数 ϕ ( n ) = ( p − 1 ) × ( q − 1 ) \phi(n) = (p-1) \times (q-1) ϕ(n)=(p1)×(q1)
    • 选择一个与 ϕ ( n ) \phi(n) ϕ(n) 互质的整数 e e e,使得 1 < e < ϕ ( n ) 1 < e < \phi(n) 1<e<ϕ(n) 这个 e e e 是公钥的一部分。
    • 计算私钥 d d d,满足 d × e ≡ 1 ( mod  ϕ ( n ) ) d \times e \equiv 1 \ (\text{mod} \ \phi(n)) d×e1 (mod ϕ(n))。这个 d d d 是私钥的一部分。
  2. 加密:

    • 加密时,将明文 M M M 转换为整数形式 m m m,然后使用公钥 ( e , n ) (e, n) (e,n) 计算密文 c c c
      c = m e ( mod  n ) c = m^e \ (\text{mod} \ n) c=me (mod n)
  3. 解密:

    • 解密时,使用私钥 ( d , n ) (d, n) (d,n) 计算明文 m m m
      m = c d ( mod  n ) m = c^d \ (\text{mod} \ n) m=cd (mod n)
1.2 安全性分析

RSA的安全性基于大数分解的困难性。随着密钥长度的增加,因数分解 (n) 的难度成指数级增长,这使得通过已知公钥推算私钥在计算上变得不可行。

RSAPython_37">二、RSA算法的Python实现

下面我们将一步步实现一个基本的RSA加密解密程序,不使用任何第三方加密库。我们将从密钥生成开始,然后实现加密解密

2.1 辅助函数

我们首先定义几个基本的数学辅助函数:

python">import random# 计算最大公约数
def gcd(a, b):while b != 0:a, b = b, a % breturn a# 扩展欧几里得算法,用于计算模逆
def extended_gcd(a, b):if b == 0:return a, 1, 0g, x1, y1 = extended_gcd(b, a % b)x = y1y = x1 - (a // b) * y1return g, x, y# 计算模逆
def mod_inverse(e, phi):g, x, _ = extended_gcd(e, phi)if g != 1:raise ValueError("模逆不存在")return x % phi# 快速幂算法
def power_mod(base, exponent, modulus):result = 1base = base % moduluswhile exponent > 0:if exponent % 2 == 1:result = (result * base) % modulusexponent = exponent >> 1base = (base * base) % modulusreturn result
2.2 密钥生成

接下来,我们定义密钥生成函数。为了简化实现,我们将使用一个简单的素数生成方法。

python"># 判断一个数是否为素数
def is_prime(n):if n <= 1:return Falseif n <= 3:return Trueif n % 2 == 0 or n % 3 == 0:return Falsei = 5while i * i <= n:if n % i == 0 or n % (i + 2) == 0:return Falsei += 6return True# 生成随机大素数
def generate_prime_candidate(length):p = 4while not is_prime(p):p = random.getrandbits(length)return p# 生成RSA密钥对
def generate_keys(bit_length):p = generate_prime_candidate(bit_length // 2)q = generate_prime_candidate(bit_length // 2)n = p * qphi = (p - 1) * (q - 1)e = random.randrange(1, phi)g = gcd(e, phi)while g != 1:e = random.randrange(1, phi)g = gcd(e, phi)d = mod_inverse(e, phi)return ((e, n), (d, n))  # 公钥和私钥
2.3 加密解密

一旦密钥生成,我们可以实现加密解密功能。

python"># RSA加密
def rsa_encrypt(plaintext, public_key):e, n = public_key# 将明文转换为整数plaintext_int = int.from_bytes(plaintext.encode('utf-8'), byteorder='big')# 加密ciphertext = power_mod(plaintext_int, e, n)return ciphertext# RSA解密
def rsa_decrypt(ciphertext, private_key):d, n = private_key# 解密plaintext_int = power_mod(ciphertext, d, n)# 将整数转换为明文plaintext = plaintext_int.to_bytes((plaintext_int.bit_length() + 7) // 8, byteorder='big').decode('utf-8')return plaintext
2.4 使用示例

最后,我们展示如何使用上述函数生成密钥,并对消息进行加密解密

python">if __name__ == "__main__":# 生成密钥对(1024位)public_key, private_key = generate_keys(1024)# 原始消息message = "Hello, RSA!"print("Original Message:", message)# 加密ciphertext = rsa_encrypt(message, public_key)print("Encrypted Message:", ciphertext)# 解密decrypted_message = rsa_decrypt(ciphertext, private_key)print("Decrypted Message:", decrypted_message)# 检查解密结果是否与原始消息一致assert decrypted_message == message

三、总结

RSA作为一种经典的非对称加密算法,依赖于大数分解的难度以保证安全性。通过上述的Python实现,我们不仅掌握了RSA的核心算法原理,也了解了密钥生成、加密解密的过程。

尽管本文中实现的RSA算法是简化版,但它提供了一个良好的基础,使你能进一步探索加密领域的复杂算法和应用。如果你希望进一步提升RSA的安全性,可以考虑增加密钥的长度或使用更加复杂的素数生成方法。

通过掌握RSA算法的实现原理,你将更好地理解现代加密系统的工作方式以及它们在保护信息安全中的重要性。


http://www.ppmy.cn/news/1517055.html

相关文章

如何快速熟悉一个软件

当入职一家新公司时&#xff0c;必然要熟悉一些新的软件项目&#xff0c;这个时候&#xff0c;如何才能快速熟悉软件项目&#xff0c;以达到快速上手的目的。 1大忌 还记得自己刚毕业的第一份工作&#xff0c;一上来就去看代码&#xff0c;看代码的细节。在看代码的时候&…

[C++]set和map的介绍及使用

关于set和map的接口函数部分&#xff0c;只重点介绍一些相较于别的容器有特殊地方的接口&#xff0c;set和map的接口可以触类旁通。 一、概念 &#xff08;一&#xff09;、关联式容器 关联式容器存储的元素是一个个的键值对<key,value>。通过键&#xff08;key&#x…

MATLAB 生成指定范围、角度、厚度的含噪平面点云(77)

模拟生成点云并可视化显示,可以验证算法有效性,尤其是针对验证算法的某方面 MATLAB 生成指定范围、角度、厚度的含噪平面点云(77) 一、算法介绍二、使用步骤1.代码2.效果一、算法介绍 如题,模拟生成一组平面点云,含有噪声点,确定算法稳定性,可以指定生成平面的范围,厚…

Java集合—Map系列集合(习题一)

文章目录 Java集合—Map集合&#xff08;习题&#xff09;1.使用泛型修改根据学员姓名找学员对象2.运用Map的三种遍历方式进行遍历迭代器遍历键值对遍历增强遍历 综合要求 Java集合—Map集合&#xff08;习题&#xff09; 1.使用泛型修改根据学员姓名找学员对象 2.运用Map的三…

【JAVA]DAY 2在网页中输出日期和时间,实时还是静止?

一、如何输出日期文本 使用document.write(Date()); 会在网页中输出当前的日期和时间。在 2024 年 8 月 28 日星期三执行这段代码&#xff0c;可能会输出类似 “Wed Aug 28 2024 [具体时间]” 这样的内容。 Date()是 JavaScript 中的一个内置对象&#xff0c;用于处理日期和…

UE5 多个类选择界面生成

在Unreal Engine 5 (UE5) 中&#xff0c;如果你想要创建一个可以选择多个类的界面&#xff0c;你可以使用SClassPicker小部件。以下是一个简单的例子&#xff0c;展示如何在UE5的编辑器模块中创建一个自定义的编辑器工具栏按钮&#xff0c;并打开一个类选择器。 #include &quo…

论文写作遇到的问题——个人记录用

1.实验结果图绘制 python画图字体设置 Science Plots使用中中文配置的问题 11种 Matplotlib 科研论文图表教程 2.论文写作格式 word公式居中、编号右对齐、自动编号、交叉引用 mathtype操作合集&#xff0c;使用大全 arxiv.org的文章引用格式 LaTex的下载与安装&#x…

[CLIP-VIT-L + Qwen] 多模态大模型源码阅读 - DataSet篇

[CLIP-VIT-L Qwen] 多模态大模型源码阅读 - DataSet篇 前情提要源码解读完整代码逐行解读导包readjson函数data_collate函数ImageCaptionDataset类&#xff08;init函数&#xff09;ImageCaptionDataset类&#xff08;readImage函数&#xff09; 参考repo:WatchTower-Liu/VLM-…

Java中Objecy类

没有成员变量 也就只有无参 的构造方法 /*** ClassName Test* author gyf* Date 2024/8/28 10:32* Version V1.0* Description : */ public class Test {public static void main(String[] args) {// toString()Object object new Object();System.out.println(object);String…

网络安全新视角:人工智能在防御中的最新应用

人工智能在网络安全中的最新应用 概述 人工智能&#xff08;AI&#xff09;在网络安全领域的应用正日益成熟&#xff0c;它通过机器学习和深度学习技术&#xff0c;为网络安全带来了革命性的变革。AI技术不仅能够自动化、智能化地检测、分析和应对安全威胁&#xff0c;还能够…

Jenkins:自动化的魔法师,打造无缝CI/CD流水线

标题&#xff1a;“Jenkins&#xff1a;自动化的魔法师&#xff0c;打造无缝CI/CD流水线” 在当今快速发展的软件开发领域&#xff0c;持续集成&#xff08;Continuous Integration, CI&#xff09;和持续部署&#xff08;Continuous Deployment, CD&#xff09;已经成为提升开…

Docker续1:

一、打包传输 1.打包 [rootlocalhost ~]# systemctl start docker [rootlocalhost ~]# docker save -o centos.tar centos:latest [rootlocalhost ~]# ls anaconda-ks.cfg centos.tar 2.传输 [rootlocalhost ~]# scp centos.tar root192.168.1.100:/root 3.删除镜像 [r…

总结:Python语法

Python中的字典、列表和数组是三种常用的数据结构&#xff0c;它们各自有不同的用途和特性。 字典&#xff08;Dictionary&#xff09; 字典是一种无序的、可变的数据结构&#xff0c;它存储键值对&#xff08;key-value pairs&#xff09;。字典中的每个元素都是一个键值对&…

flink--会话模式与应用模式

flink-会话模式部署 会话情况&#xff1a; 添加依赖 <properties><flink.version>1.17.2</flink.version> </properties> ​ <dependencies><dependency><groupId>org.apache.flink</groupId><artifactId>flink-strea…

CSS属性

一、CSS列表样式 1、list-style-type属性&#xff08;列表项标记&#xff09; CSS列表属性允许我们设置不同的列表项标记。 在HTML中&#xff0c;有​两种类型​的列表&#xff1a; ​无序列表​&#xff08;<ul>&#xff09; - 列表项目用​项目符号​标记​有序列表…

【Linux】自动化构建工具makefile

目录 背景 makefile简单编写 .PHONY makefile中常用选项 makefile的自动推导 背景 会不会写makefile&#xff0c;从一个侧面说明了一个人是否具备完成大型工程的能力 ​ ◉ 一个工程中的源文件不计数&#xff0c;其按类型、功能、模块分别放在若干个目录中&#xff0c;mak…

开放式耳机怎么戴?佩戴舒适在线的几款开放式耳机分享

开放式耳机的佩戴方式与传统的入耳式耳机有所不同&#xff0c;它采用了一种挂耳式的设计&#xff0c;提供了一种新颖的佩戴体验&#xff0c;以下是开放式耳机的佩戴方式。 1. 开箱及外观&#xff1a;首先&#xff0c;从包装盒中取出耳机及其配件&#xff0c;包括耳机本体、充电…

使用 FinalShell 链接 Centos

1. 安装 FinalShell 下载地址&#xff1a;https://www.hostbuf.com/t/988.html 2. 查看 IP地址。 2.1 通过命令查询IP 输入 ip addr show 查询&#xff0c;输出效果如下截图&#xff0c;其中的 192.168.1.5 就是 IP 地址。 2.2 通过可视化界面查询IP 点击右上角的网络图标…

LoadBalancer负载均衡

一、概述 1.1、Ribbon目前也进入维护模式 Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端负载均衡的工具。 简单的说&#xff0c;Ribbon是Netflix发布的开源项目&#xff0c;主要功能是提供客户端的软件负载均衡算法和服务调用。Ribbon客户端组件提供一系列完善的…

企业中需要哪些告警Rules

文章目录 企业中需要哪些告警Rules前言定义告警规则企业中的告警rulesNode.rulesprometheus.ruleswebsite.rulespod.rulesvolume.rulesprocess.rules 总结 企业中需要哪些告警Rules 前言 Prometheus中的告警规则允许你基于PromQL表达式定义告警触发条件&#xff0c;Prometheus…