RSA 加密算法主要公式

简介: RSA 加密算法主要公式

RSA 是非对称的加密算法,其中它有一些相关的数学公式。让我们从一道题开始了解 RSA 的数学公式。


计算问题

下面是一道关于 RSA 计算的问题,比较简单,可以从这道题来学习和了解关于 RSA 非对称加密算法的相关知识。当然,具体关于 RSA 加密算法的知识不能仅限于以下问题,应该更全面的了解相关的知识。但是下面的问题已经把其中的重点算法表现出来了。


问题:在 RSA 算法中,取密钥 E = 3,D = 7,则明文 6 的密文是()。


RSA 算法的相关公式

下面是关于 RSA 的主要数学公式:

n = p * q

ø(n) = (p - 1) * (q - 1)

ed ≡ 1 mod ø(n)

c = m**e mod n

m = c**d mod n


对上面的公式进行一个简单的说明。

  • 在整个公钥体制中,e 和 n 是公开的,e 是公钥,n 是两个大素数的乘积。
  • m 和 c 分别是明文和密文,这部分在所有的加密算法中都会涉及。
  • 其余的 p、q、d 是保密的,p 和 q 是两个大素数,n 就是通过 p 和 q 相乘得到的,d 是私钥。
  • e 和 d 的关系满足 e * d ≡ 1 mod ø(n) ,也就是说 d 是 e 的乘法逆元,或者说e * d 和 1 同 ø(n)  求模同余。其中 ≡ 是数论中的“求模同余”的意思,而不是“恒等”的意思。


说明:其中两个 ** 是幂次方的意思,这种写法是 Python 语言中的写法,比如 7 ** 3 就是 7 的 3 次方的意思。


将题中的数带入公式

ed ≡ 1 mod ø(n)

3 * 7 ≡ 1 mod ø(n)

21 ≡ 1 mod ø(n)

ø(n) = 20

ø(n) = 2 * 10 = (p - 1) * (q - 1)

p, q = 3, 11

n = p * q = 3 * 11 = 3


上面的步骤通过 ed 得到了 ø(n),而 ø(n) 是 20 的情况下,我们可能算出 p - 1 和 q - 1 是 4 和 5,也可能是 2 和 10。

如果 p - 1 和 q - 1 分别是 4 和 5,那么 p 和 q 就是 5 和 6,而 6 不是素数;

如果 p - 1 和 q - 1 分别是 2 和 10,那么 p 和 q 就是 3 和 11,此时两个数都为素数。

得到 p 和 q 以后,就得到了 n。


在得到 n 以后套用加密算法的公式,即可计算 6 的密文。

c = m**e mod n = 6 ** 3 mod 33 = 18


因此 明文 6 的密文是 18。

其中 6 ** 3 是 6 * 6 * 6,通过降幂可以简化为


6 ** 3

3 = 1 * (2 ** 0) + 1 * (2 ** 1)

t0 = 6 mod 33 = 6

t1 = 6 ** 2 mod 33 = 3

t0 * t1 mod n = 6 * 3 mod 33 = 18


可以在 Python 的交互环境中进行验算:

>>>6**3%3318

将密文进行解密验算

除了用 Python 验算以外,用解密算法对密文 18 进行解密,如果得到明文 6,也说明上面的计算是正确的。

m = c ** d mod n = 18 ** 7 mod 33 = 6

其中 18 ** 7 如果使用 7 个 18 相乘来手动计算,是一件麻烦的事情,所以这里使用降幂的方式来进行手动计算,是非常有必要的。


18 ** 7

7 = 1 * (2 ** 0) + 1 * (2 ** 1) + 1 * (2 ** 2)

t0 = 18 mod 33 = 18

t1 = 18 ** 2 mod 33 = 27

t2 = 27 ** 2 mod 33 = 3

t0 * t1 * t2 mod n = 18 * 27 * 3 mod 33 = 6


通过降幂计算,18 ** 7 计算起来只用了 4 步就完成了,数值也没有太大。

因此,密文 18 解密后是 6


在 Python 下进行验算:

>>>18**7%336

上面就是 RSA 的关键相关的公式,其中虽然 n 是公开的,但是实际 n 是两个非常大的素数相乘得到的(题目中的 3 和 11 这种素数太小了),很难通过 n 分解出两个大的素数,因此保证了其安全性。


相关文章
|
3月前
|
存储 安全 数据安全/隐私保护
打造安全防线!Python AES&RSA加密工具,黑客绕道走的秘籍
【9月更文挑战第9天】随着数字化时代的到来,信息安全问题日益凸显。本文将介绍如何使用Python结合AES与RSA两种加密算法,构建强大的加密工具。AES以其高效性和强安全性著称,适用于大量数据的快速加密;RSA作为非对称加密算法,在加密小量数据及实现数字签名方面表现卓越。通过整合两者,可以构建既安全又灵活的加密系统。首先,需要安装pycryptodome库。接着,实现AES加密与解密功能,最后利用RSA加密AES密钥,确保其安全传输。这种设计不仅提高了数据传输效率,还增强了密钥交换的安全性,为敏感数据提供坚实保护。
235 43
|
3月前
|
安全 算法 网络安全
浅谈非对称加密(RSA)
浅谈非对称加密(RSA)
162 0
|
2月前
|
算法 安全 Go
RSA加密算法详解与Python和Go实现
RSA加密算法详解与Python和Go实现
158 1
|
2月前
|
算法 安全 网络安全
使用 Python 实现 RSA 加密
使用 Python 实现 RSA 加密
101 2
|
3月前
|
存储 安全 算法
RSA在手,安全我有!Python加密解密技术,让你的数据密码坚不可摧
【9月更文挑战第11天】在数字化时代,信息安全至关重要。传统的加密方法已难以应对日益复杂的网络攻击。RSA加密算法凭借其强大的安全性和广泛的应用场景,成为保护敏感数据的首选。本文介绍RSA的基本原理及在Python中的实现方法,并探讨其优势与挑战。通过使用PyCryptodome库,我们展示了RSA加密解密的完整流程,帮助读者理解如何利用RSA为数据提供安全保障。
145 5
|
3月前
|
安全 算法 数据安全/隐私保护
深度揭秘!Python加密技术的背后,AES与RSA如何守护你的数据安全
【9月更文挑战第10天】随着数字化时代的到来,数据安全成为企业和个人面临的重大挑战。Python 作为功能强大的编程语言,在数据加密领域扮演着重要角色。AES 和 RSA 是两种主流加密算法,分别以对称和非对称加密方式保障数据安全。AES(Advanced Encryption Standard)因其高效性和安全性,在数据加密中广泛应用;而 RSA 则利用公钥和私钥机制,在密钥交换和数字签名方面表现卓越。
88 3
|
3月前
|
存储 安全 数据库
双重防护,无懈可击!Python AES+RSA加密方案,构建最强数据安全堡垒
【9月更文挑战第11天】在数字时代,数据安全至关重要。AES与RSA加密技术相结合,构成了一道坚固防线。AES以其高效性保障数据加密,而RSA则确保密钥安全传输,二者相辅相成,提供双重保护。本文通过Python代码示例展示了这一加密方案的魅力,强调了其在实际应用中的重要性和安全性。使用HTTPS等安全协议传输加密密钥和密文,确保数据在数字世界中自由流通而无忧。
80 1
|
3月前
|
安全 数据安全/隐私保护 Python
情书也能加密?Python AES&RSA,让每一份数据都充满爱的密码
【9月更文挑战第8天】在这个数字化时代,情书不再局限于纸笔,也可能以电子形式在网络中传递。为了确保其安全,Python提供了AES和RSA等加密工具,为情书编织爱的密码。首先,通过安装pycryptodome库,我们可以利用AES对称加密算法高效保护数据;接着,使用RSA非对称加密算法加密AES密钥和IV,进一步增强安全性。即使情书被截获,没有正确密钥也无法解读内容。让我们用Python为爱情编织一张安全的网,守护每份珍贵情感。
54 2
|
4月前
|
算法 安全 数据安全/隐私保护
Android经典实战之常见的移动端加密算法和用kotlin进行AES-256加密和解密
本文介绍了移动端开发中常用的数据加密算法,包括对称加密(如 AES 和 DES)、非对称加密(如 RSA)、散列算法(如 SHA-256 和 MD5)及消息认证码(如 HMAC)。重点讲解了如何使用 Kotlin 实现 AES-256 的加密和解密,并提供了详细的代码示例。通过生成密钥、加密和解密数据等步骤,展示了如何在 Kotlin 项目中实现数据的安全加密。
169 1
|
4月前
|
算法 安全 数据安全/隐私保护
Android经典实战之常见的移动端加密算法和用kotlin进行AES-256加密和解密
本文介绍了移动端开发中常用的数据加密算法,包括对称加密(如 AES 和 DES)、非对称加密(如 RSA)、散列算法(如 SHA-256 和 MD5)及消息认证码(如 HMAC)。重点展示了如何使用 Kotlin 实现 AES-256 的加密和解密,提供了详细的代码示例。
92 2