美文网首页产品经理进阶产品经理
产品经理要懂点数学(2)

产品经理要懂点数学(2)

作者: 败家 | 来源:发表于2019-07-23 13:36 被阅读3次

关键词:对称加密算法,RSA算法,素数(质数),素数分布,数论。


历史

1976年以前,所有的加密方法都是同一种模式:

(1)甲方选择某一种加密规则,对信息进行加密;

(2)乙方使用同一种规则,对信息进行解密。

由于加密和解密使用同样规则(简称"密钥"),这被称为“对称加密算法”(Symmetric-key algorithm)

这种加密模式有一个最大弱点:甲方必须把加密规则告诉乙方,否则无法解密。保存和传递密钥,就成了最头疼的问题。

1976年,两位美国计算机学家Whitfield Diffie 和Martin Hellman,提出了一种崭新构思,可以在不直接传递密钥的情况下,完成解密。这被称为"Diffie-Hellman密钥交换算法"。意味着加密和解密可以使用不同的规则,只要这两种规则之间存在某种对应关系即可,这样就避免了直接传递密钥。

这种新的加密模式被称为"非对称加密算法"。

(1)乙方生成两把密钥(公钥和私钥)。公钥是公开的,任何人都可以获得,私钥则是保密的。

(2)甲方获取乙方的公钥,然后用它对信息加密。

(3)乙方得到加密后的信息,用私钥解密。

如果公钥加密的信息只有私钥解得开,那么只要私钥不泄漏,通信就是安全的。


RSA算法相关

1977年,三位数学家Rivest、Shamir 和Adleman 设计了一种算法,可以实现非对称加密。这种算法用他们三个人的名字命名,叫做RSA,RSA加密算法,是一种非对称加密算法,在公开密钥加密和电子商业活动中被广泛应用。

因数分解决定了RSA算法的可靠性,到目前为止,世界上还没有任何可靠的攻击RSA算法的方式,只有短的RSA钥匙才可能被强力方式解破。长度超过768位的密钥,还无法破解(至少没人公开宣布)。因此可以认为,1024位的RSA密钥基本安全,2048位的密钥极其安全。同时RSA算法也是素数的经典运用。

因素分解:一个整数分解成多个约数(因数),根据算术基本定理结果是唯一的。如:12=2*3*2;

素数:又称质数,在大于1的自然数中,除了1和它本身以外不再有其他因数,质数的个数是无穷的;

互质:互质是公约数只有1的两个整数,叫做互质整数。公约数只有1的两个自然数,叫做互质自然数,后者是前者的特殊情形

扩展欧几里得算法:是用来在已知a, b求解一组x,y,使它们满足贝祖等式: ax+by = gcd(a, b) =d(解一定存在,根据数论中的相关定理)。扩展欧几里德常用在求解模线性方程及方程组中。

乘法逆元:是指数学领域群G中任意一个元素a,都在G中有唯一的逆元a‘,具有性质a×a'=a'×a=e,其中e为该群的单位元。

RSA算法原理

生成公钥和私钥步骤。

1)选择相异素数P、Q,并得到乘积N ,既「N=P*Q」。

2)将P、Q各减1,再互乘,得到数值\varphi(n),既「\varphi(n)=(P-1)(Q-1)」。

3)选择整数E为密钥,使E和\varphi(n)互质,且E小于。

4)根据公式DE mod \varphi(n)=1,计算出D的值 ,作为另外一个密钥

5)通过以上步骤计算出,N,E,D3个数,N、E为公钥,N、D为私钥。

简单实例

P=3  Q=11

N=P*Q

    N=33

\varphi(n)=(P-1)(Q-1)=2*10=20

E=7(7<8)

DE mod \varphi(n)=1

D*7=1(mod 20)

D=3

公钥(33,7), 私钥(33,3)

公钥加密

C=M^E mod N

明文 :M=5

加密:C=(5^7)mod 33=14

密文 :C=14

私钥解密

M=C^D mod N

密文:C=14

解密 :M=(14^3)mod 33

M=5

参考:「百度文库」、「RSA算法详解」、「几何原本」「程序员的数学思维修炼」、「RSA算法原理阮一峰」

相关文章

  • 产品经理要懂点数学(2)

    关键词:对称加密算法,RSA算法,素数(质数),素数分布,数论。 历史 1976年以前,所有的加密方法都是同一种模...

  • 我眼中的产品经理

    我眼中的产品经理 产品经理是该多懂技术,还是要懂设计,还是懂用户; 产品经理是要擅长沟通,逻辑条理清晰,还是会汇报...

  • 产品经理要懂点数学(1)

    从0开始 在计算机中,我们通常用到的“0”,并不是代表什么都没有,它在独特的场景中,代表这不同的意思,如: 1)温...

  • 随笔:产品经理的核心能力

    产品经理要懂市场懂用户懂业务懂商业原理,要有悟性,要思维敏锐快速,要杀伐果断。做一个灵动的产品经理,而不是闭门造车...

  • 产品经理对活动运营要了解到什么程度?看这个就够了

    在公司里产品经理可以说什么都要懂一点,要懂点技术和开发沟通数据库设计,要有审美和设计师K效果图,同样的,产品经理也...

  • 产品经理要懂的运营

    对于产品经理要不要懂技术、懂的话要懂到什么程度这个话题,是经常看到新人产品经理们问的,大概是因为产品经理们经常被技...

  • 成为优秀产品经理的10条建议

    本文来源为:《360-如何成为一名优秀的产品经理》。 1.产品经理要有技术背景。即PM要懂技术。 2.做产品的目的...

  • 腾讯的产品经理如何学习

    文章导读一、产品经理要懂什么?二、产品经理眼中的产品是什么?三、产品经理具体要干什么?四、合格产品经理需要什么能力...

  • 产品经理要懂技术么?

    一、产品经理要懂技术么? 参与产品设计并通过与工程师协作来共同研发产品的产品经理都需要懂技术 二、产品思维与技术思...

  • 产品经理需要懂技术吗?

    产品经理如果需要懂技术,要掌握哪些技术,为什么?产品经理如果不需要懂技术,那要具备哪些能力,为什么? Wallac...

网友评论

    本文标题:产品经理要懂点数学(2)

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