美文网首页
RSA公钥加密算法笔记

RSA公钥加密算法笔记

作者: fruits_ | 来源:发表于2017-10-26 14:04 被阅读0次

RSA是目前最有影响力和常用的公钥加密算法

这篇笔记目的是梳理RSA算法加解密的证明思路
RSA算法是一种非对称密码算法,所谓非对称,就是指该算法需要一对密钥,若使用其中一个进行加密,则需要另一个才能解密。

RSA算法涉及3个参数: n, e1, e2
其中要求:

  • n是两个大质数p,q的积,n的二进制表示时所占位数即密钥长度
  • e1, e2是一对相关的值,e1可任意取,但要求与(p-1)(q-1)互质
  • 再选择e2,要求(e1e2) ≡ 1 (mod(p-1) * (q-1))

这里我们假设有A B 2个对象,A要利用RSA算法向B发送数据。
(N, e1)是B公共登记的或是其它可访问文件里的公钥,(N, e2)是B本地的私钥
M (message) 是A要发送的明文数据,C (ciphertext)是密文,简单应有如下关系


即A将数据通过公钥(N, e1)加密后得C,将C发送给B,B需要通过私钥(N, e2)解密可以还原得到M。
于是自然有公式
C = M^e1 % N
C^e2 = M^(e1e2) % N
欲使Ce2 % N = M, 即需使得 M(e1e2) % N = M,也即
M^(e1e2) ≡ M % N
现在我们看前提③,即 e1e2 ≡ 1 (mod(p-1) * (q-1))
再往前看前提①,即N是2个大素数p,q的积。那么有多少个与N互素且比N小的数呢?这个数被称为欧拉函数φ(N)。逆向思考,与N不互素的数有多少?对于N,不互素的数有
1p, 2p, 3p,....,(q-1)p
1q, 2q, 3q,....,(p-1)q
上面总共有(q-1) + (p-1)个,那么由于互补,与N互素的数有(pq - 1) - [(q-1)+(p-1)],即
(p-1)(q-1)个,那么前提③,其实就是 e1e2 ≡ 1 mod φ(N)
上式的另外一种表述方式:存在整数k满足
e1e2 = kφ(N) + 1

回头看式子④,可以得知,我们现在的目的就是去证明
M(kφ(N)+1) ≡ M % N

首先看2个关于模算数的基本结果和欧拉定理:
[(a % n) × (b % n)] % n = (a × b) % n
可知若x % n = 1, 则 x^y % n = 1, 同理若 x % n = 0, 则x^y % n = 0
[(a % n) - (b % n)] % n = (a - b) % n
欧拉定理:若a与n互素,则有 a^(φ(n)) mod n = 1

要证明M(kφ(N)+1) ≡ M % N, 而N=pq,我们从N的因子p入手。首先证明M(kφ(N)+1) ≡ M % p

  • 若M和p不互素,即M % p= 0,则 M(kφ(N)+1) ≡ M % p
  • 若M和p互素。由欧拉定理M(φ(p)) % p = 1
    M(kφ(N)+1) % p = [M× M(p-1)k(q-1)] % p
    = (M % p) × [M^(φ(p)) % p] k(q-1)
    = (M % p) × 1k(q-1) = M % p

由上两项证明可知 M(kφ(N)+1) ≡ M % p
可得 [M(kφ(N)+1) - M] % p = [M(kφ(N)+1) % p - M % p] = 0
根据同样的证明可得 [M(kφ(N)+1) - M] % q = 0。 又因为p ≠ q,所以必然存在一个整数r使得 M(kφ(N)+1) - M = (pq)r=Nr
即 [M(kφ(N)+1) - M] % N = 0 即 M(kφ(N)+1) ≡ M % N

相关文章

  • # RSA 公钥加密算法

    # RSA 公钥加密算法 # RSA 公钥加密算法

  • RSA非对称加密算法

    RSA算法,经典非对称加密算法,通过生成公钥 私钥 进行加密解密 公钥加密 私钥解密 反之 私钥加密 公钥...

  • iOS RSA加签和验签(SHA1WithRSA)

    RSA 简介 RSA是一种非对称加密算法,使用公钥加密就可以使用私钥解密,使用私钥加密就可以使用公钥解密。RSA公...

  • Linux配置免密登录

    1、公钥-私钥对: 称为非对称加密方式 2、生成公钥-私钥对命令: 参数:-t:加密算法 rsa:不对称加密算法...

  • 5分钟了解RSA加解密算法

    By Long Luo 一、RSA说明 RSA公钥加密算法是1977年由Ron Rivest、Adi Shamir...

  • iOS RSA加签和验签

    RSA是一种非对称加密算法,使用公钥加密就可以使用私钥解密,使用私钥加密就可以使用公钥解密。RSA公钥对外公开,私...

  • rsa加密

    看这里 1、RSA加密算法是目前最有影响力的公钥加密算法,并且被普遍认为是目前最优秀的公钥方案之一。RSA是第一个...

  • [ 加密 ] RSA 公认目前最优秀的公钥方案之一

    RSA 加密算法是目前最有影响力的公钥加密算法,并且被普遍认为是目前 最优秀的公钥方案之一 RSA 是第一个能同时...

  • 椭圆曲线加密算法中的密谋

    公钥加密算法有两种,RSA 和 ECC,RSA 简单易懂但效率低,ECC 效率高,用 256 位秘钥抵得过 RSA...

  • RSA加密

    RSA基本原理: RSA加密算法是基于一个密钥对的,分为公钥和私钥,一般情况公钥加密,私钥解密,但也可私钥加密,公...

网友评论

      本文标题:RSA公钥加密算法笔记

      本文链接:https://www.haomeiwen.com/subject/rerguxtx.html