不对称密钥密码体系之RSA
公钥密码的特性:
1.加密和解密使用不同的钥匙
2.从一个钥匙推出另一个钥匙在计算上不可行
3.每个钥匙都可以做加密和解密
RSA算法:
1978年, MIT三位数学家 R.L.Rivest,A.Shamir和L.Adleman发明了RSA算法。 RSA算法可用于加密、又可用于数字签字,易懂且易于实现,是目前仍然安全并且逐步被广泛应用的一种体制。 国际上一些标准化组织ISO、ITU、及SWIFT等均已接受RSA体制作为标准。
RSA涉及的一些数论知识...
Euler函数:
设n为一正整数,小于n且与n互素的整数的个数,称为Euler数。
1.若n为素数,则Φ(n)=n-1
2.若n为两个素数的乘积,则Φ(n)=Φ(p1)Φ(p2)=(p1)x(p2)
Euler定理:
若a与n互素,则aΦ(n)≡1 mod n
RSA密钥对生成步骤
1.独立地选取两个大素数p和q,计算n=pXq,计算Φ(n)=(p-1)(q-1)
2.选一整数e,(1<=e<Φ(n),e与Φ(n)互素)。在模Φ(n)下,e有唯一逆元,
计算d=e-1mod (Φ(n))
3.取公钥为(n,e),私钥为(n,d),并销毁p、q
RSA加密和解密的步骤
加密前,首先将明文分成比n小的数据分组,再对每个每个分组加密
加密:C=Me(mod n)
解密:M=Cd(mod n)
RSA密钥对生成实例
1.独立选取两个素数(这里取的素数很小)p1=47和p2=71
n=47X71=3337
Φ(n)=(47-1)(71-1)=3220
2.选整数e=79,(1<=e<3220,3220与79互素)。在模3220下,79有逆元d=1019
3.取公钥(3337,79),私钥(3337,1019),销毁47,71
加密消息“RSA”,ascii码为828365
分成比n小的数据,为了简单,M1=82,M2=83,M3=65
加密后:C1=274,C2=2251,C3=541
结果:274,2251,541
解密后:M1=82,M2=83,M3=65
结果是正确的,过程就不写出来了,套用公式就能算。
RSA的速度:
硬件实现:比DES大约慢1000倍
软件实现:比DES大约慢100倍
相同安全强度所需的密钥长度比较:

RSA的缺点:
受到素数产生技术的限制,产生密钥很麻烦。
分组长度很长,为保证足够安全,n至少要600比特以上,使运算代价很高,且随着大数分解技术的发展,这个长度还需要增加,不利于数据格式的标准化。
不对称密钥密码体系之RSA的更多相关文章
- 密钥密码体系CA,CSC,CV
		
密钥密码体系CA,CD,CSC,CV 片内操作系统 (cos) 密码学(Cryptography) 非接触式智能卡Contactless Smart Card, CSC 密钥名词 名词 英文说明 中文 ...
 - DES,3DES,AES这三种对称密钥的区别与联系
		
DES:Data Encryption Standard(数据加密标准,又美国国密局,选中的IBM的方案,密钥长度为56,标准提出是要使用64位长的密钥,但是实际中DES算法只用了64位中的56位密钥 ...
 - 密码学系列之:blowfish对称密钥分组算法
		
目录 简介 blowfish详解 密钥数组和S-box 密钥数组 S-box 生成最终的K数组 blowfish blowfish的应用 blowfish的缺点 简介 Blowfish是由Bruce ...
 - flash + php对称密钥加密的交互
		
这几天研究了下php和flash中的对称密钥加密的交互问题,经过研究以后决定,在项目中使用aes加密.问题也就来了,在flash中的加密数据如何与php的amf进行数据交互,最终决定使用base64编 ...
 - 加密算法大全图解 :密码体系,对称加密算法,非对称加密算法,消息摘要, Base64,数字签名,RSA,DES,MD5,AES,SHA,ElGamal,
		
1. 加密算法大全: ***************************************************************************************** ...
 - [Node.js] 对称加密、公钥加密和RSA
		
原文地址:http://www.moye.me/2015/06/14/cryptography_rsa/ 引子 对于加解密,我一直处于一种知其然不知其所以然的状态,项目核心部分并不倚重加解密算法时,可 ...
 - 前后端分离密码登陆加密RSA方案(java后端)
		
前言:密码加密有很多种方案,这里不做过多讨论,本篇文章是基于RSA加密实现. 首先在前端工程中需要引入加密js: "jsencrypt": "2.3.1",(注 ...
 - 密码学系列之:twofish对称密钥分组算法
		
简介 之前的文章我们讲到blowfish算法因为每次加密的块比较小只有64bits,所以不建议使用blowfish加密超过4G的文件.同时因为加密块小还会导致生日攻击等.所以才有了blowfish的继 ...
 - SQL Server Reporting Service 报错:报表服务器无法解密用于访问报表服务器数据库中的敏感数据或加密数据的对称密钥,必须还原备份密钥或删除所有加密的内容。
		
出现这个问题,可以通过reporting services 配置管理工具来处理 首先,打开配置管理工具,连接. 在左侧的导航选项中选择Encryption Keys,将出现如图所示的界面,在右侧点击d ...
 
随机推荐
- tail -f logfile.log    一直监控某个文件,若该文件有改动,立即在屏幕上输出
			
tail -f logfile.log 可以一直监控某个文件,只要文件有改动,就立即在屏幕上输出
 - Linux必学的命令
			
Linux必学的命令Linux提供了大量的命令,利用它可以有效地完成大量的工作,如磁盘操作.文件存取.目录操作.进程管理.文件权限设定等.所以,在Linux系统上工作离不开使用系统提供的命令.要想真正 ...
 - Hadoop build error java.lang.NoClassDefFoundError: org/sonatype/aether/graph/DependencyFilter
			
When running the command: + mvn site site:stage -DskipTests -DskipTest -DskipITs you get an error: ...
 - hdoj 2802 F(N)【递推  规律】
			
F(N) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
 - Android开发中如何强制横屏和强制竖屏设置
			
Android开发中如何强制横屏和强制竖屏设置 强制横屏设置: 按照下面代码示例修改Activity的onResume方法 @Override protected void onResume() { ...
 - 常用的windowd属性和对象
			
window.location.href="" 指向一个定向的url并提交数据过去 window.location.reload() 强制刷新当前 ...
 - MSSQLSERVER数据库- 判断全局临时表是否存在
			
写一下今天遇到的一个问题. 今天因为一些作用域的问题,我使用了全局临时表,然后我在存储过程里使用了这么一段语句,想判断全局临时表是否存在,如果不存在,则将他DROP掉. 可是这段语句没用. if ex ...
 - MINA之心跳协议运用
			
转自:http://my.oschina.net/yjwxh/blog/174633 摘要 心跳协议,对基于CS模式的系统开发来说是一种比较常见与有效的连接检测方式,最近在用MINA框架,原本自己写了 ...
 - iOS 极光推送
			
1.关于推送的几个证书.http://www.mobile-open.com/2016/931624.html 进入开发者中心:https://developer.apple.com/account/ ...
 - C# 导入文件日期格式(dd/MM/yyyy)
			
最近项目导入数据日期变成了这样 这是因为转换成了美国时间 美国时间格式:MM/dd/yyyy 英国时间格式:dd/MM/yyyy 避免导入出现这个问题的话就需要将excel文档单元格样式设 ...