由来:
RSA加密算法是一种非对称加密算法。在公钥加密标准和电子商业中RSA被广泛使用。RSA是1977年由罗纳德·李维斯特(Ron Rivest)、阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一起提出的。当时他们三人都在麻省理工学院工作。RSA就是他们三人姓氏开头字母拼在一起组成的。
算法基础:
RSA算法非常简单,概述如下:
找两素数p和q
取n=p*q
取t=(p-1)*(q-1)
取任何一个数e,要求满足e<t并且e与t互素(就是最大公因数为1)
取d*e%t==1
这样最终得到三个数: n d 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=5
q=19
这样
n=p*q=95
t=(p-1)*(q-1)=72
取e=17,满足e<t并且e和t互素
通过穷举得到d:
即d=17
最终我们获得关键的
n=95
d=17
e=17
加密消息M=9我们看看
加密后:
74
解密:
我们可以用e来对加密后的c进行解密,还原m:
9
即用e对c解密后获得m=9, 该值和原始信息M相等。
参考地址:http://zh.wikipedia.org/wiki/RSA%E5%8A%A0%E5%AF%86%E6%BC%94%E7%AE%97%E6%B3%95
http://hi.baidu.com/ekelxgyufbeimve/item/2e36e380a842fe2a110ef35f
分享到:
相关推荐
RSA加密算法在VBRSA加密算法在VBRSA加密算法在VB
RSA加密算法的实现,使用c++语言编程,使用dev c++平台编码,文件为cpp格式。经过反复测试代码正确,可搭配RSA讲解教程一起使用,讲解教程点击我的个人主页即可查看,希望能够对你有帮助,谢谢。
RSA加密算法.ppt
RSA加密算法实验报告.pdf
QT上RSA加密算法实现,附带图形界面,更加直观
RSA公钥加密算法是1977年由罗纳德·李维斯特(Ron Rivest)、阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一起提出的。1987年首次公布,当时他们三人都在麻省理工学院工作。RSA就是他们三人姓氏...
RSA加密算法流程图源代码;RSA加密算法流程图源代码
RSA加密算法的C语言实现
RSA加密算法源码,与大家分享
本例是基于VS2012平台,对于RSA加密算法的实现
RSA加密算法实现以及C#与java互通加解密,解决RSA算法在java与C#相互通用
用实例讲解RSA加密算法(精)
基于python+django的基于RSA加密算法软件的研究设计的实现.zip基于python+django的基于RSA加密算法软件的研究设计的实现.zip 运行步骤 需要先安装Python的相关依赖:pymysql,Django ,requests ,pycryptodomex,...
本rsa算法是使用Java与javascript加密解密范例代码,该资料从互联网收集,加上了自己的使用体会,如果对你有帮助那是万幸! js加密部分
RSA加密算法介绍,密匙的求解过程讲解,密匙的求解实例分析。
RSA加密算法实现附源代码, RSA 可用于数字签名,方案是用 ( a ) 式签名, ( b )式验证。具体操作时考虑到安全性和 m信息量较大等因素,一般是先作HASH 运算。RSA 的安全性。RSA的安全性依赖于大数分解,但是否等同...
这个算法非原创,真心不错,所以上传分享出来.实测过,满足需求
此代码不是简单利用RSA去实现加密解密的烂大街代码,而且通过本人推敲后结合实际应用而且构建出来的一段如何利用RSA加密算法保证通信过程中数据包不被第三方截获的技术,其中包含了 数字签名好双向加密、生成哈希码...
用java实现的rsa加密算法,里面有详细的加密过程的实现