讲讲自己学习RSA中的实践过程,已经对RSA熟悉的看家就不用在此浪费时间了。
<一>基础
RSA算法非常简单,概述如下:
找两素数p和q
取n =p*q
取t=(p-1)*(q-1)
取任何一个数e,要求满足e<t并且e与t互素(就是最大公因数为1)
取d*e%t==1
这样最终得到三个数: nd e
设消息为数M (M <n)
设c=(M**d)%n就得到了加密后的消息c
设m=(c**e)%n则 m == M,从而完成对c的解密。
注:**表示次方,上面两式中的d和e可以互换。
在对称加密中:
n d两个数构成公钥,可以告诉别人;
n e两个数构成私钥,e自己保留,不让任何人知道。
给别人发送的信息使用e加密,只要别人能用d解开就证明信息是由你发送的,构成了签名机制。
别人给你发送信息时使用d加密,这样只有拥有e的你能够对其解密。
RSA的安全性在于对于一个大数n,没有有效的方法能够将其分解
从而在已知n d的情况下无法获得e;同样在已知n e的情况下无法
求得d。
<二>实践
接下来我们来一个实践,看看实际的操作:
找两个素数:
p=47
q=59
这样
n=p*q=2773
t=(p-1)*(q-1)=2668
取e=63,满足e<t并且e和t互素
用perl简单穷举可以获得满主 e*d%t ==1的数d:
C:Temp>perl -e "foreach $i (1..9999){print($i),last if $i*63&68==1 }"
847
即d=847
最终我们获得关键的
n=2773
d=847
e=63
取消息M=244我们看看
加密:
c=M**d%n = 244**847'73
用perl的大数计算来算一下:
C:Temp>perl -Mbigint -e "print 244**847'73"
465
即用d对M加密后获得加密信息c=465
解密:
我们可以用e来对加密后的c进行解密,还原M:
m=c**e%n=465**63'73 :
C:Temp>perl -Mbigint -e "print 465**63'73"
244
即用e对c解密后获得m=244 , 该值和原始信息M相等。
-----------------------------------------------------------------------
RSA算法详解与举例 rsa举例
更多阅读
BIOS详解与设置电脑故障维修判断指导大全 电脑主板bios设置详解
BIOS详解与设置BIOS 全名为(Basic Input Output System)即基本输入/输出系统,是电脑中最基础的而又最重要的程序。我们把这一段程序存放在一个不需要电源的记忆体(芯片)中,这就是平时所说的BIOS。它为计算机提供最低级的、最直接的硬件
马赛克装家灵巧好用 五大案例52图详解 五大常用算法详解
导语:马赛克多变而不凌乱,它用混合色彩来表达秩序的美感。马赛克灵巧多变,装饰性强,经常被用在大空间里,但也并非大户型的专利。本期5大案例细致探究马赛克拼贴,让本不大的居室显得更丰富饱满,奇妙的视觉艺术让空间无形因层次多样而增大。
JDK7中的排序算法详解--Collections.sort和Arrays.sort arrays.sort 降序
1. 为什么写这篇文章这篇文章的根源是在产品中发现了一个诡异的bug:只能在产品环境下重现,在我的本地开发环境无法重现,而双方的代码没有任何区别。最后用remotedebug的方法找到异常所在:Exception in thread "main"java.lang.Illegal
直接引语和间接引语详解与练习
直接引语和间接引语一、概述引用或转述别人说的话时有两种方法:直接引述别人的原话,这叫做直接引语(directspeech)。用自己的话转述别人的话,叫间接引语(indirectspeech)。一般地讲,直接引语前后要加引号,间接引语不用引号,而用宾语从句来
转:RAW格式详解与实战应用
什么是RAW