7.3RSA算法

RSA算法:
大数分解问题:
计算两个素数的乘积非常容易
分解该乘积却异常困难
特别是在这2个素数都很大的情况下

1、起源

1978年美国MIT的三名数学家R.Rivest,A.Shamir和L.Adleman提出了著名的公钥密码体制:RAS公钥算法

2、思想

RAS算法基于指数加密概念,以2个大素数的乘积作为算法的公钥来加密消息,密文的解密必须知道相应的两个大素数

3、RSA公钥算法特点

  • 思想最简单
  • 分析最透彻
  • 应用最广泛
  • 易于理解和实现
  • 经受住了密码分析,具有一定的可信度

4、加密变换

将信息划分成数值小于n的一系列数据分组
对每个明文分组m进行如下的加密变换得到密文c:
c=m的e次方 mod n

5、解密变换

m=c的d次方 mod n

6、RSA算法的安全性

为了保证算法的安全性,普遍认为RAS的模数长度介于1024bit和2048bit之间
除了对RSA算法本身的攻击外,RSA算法还面临着攻击者对密钥协议的攻击

共用模数攻击
低加密指数攻击
中间相遇攻击

7、RSA算法的参数选择

1)模n的确定
p,q要足够大
p,q应为强素数
p,q之差要合适
(p-1)与(q-1)的最大公因数要小(防止迭代攻击)
2)加密密钥e的选取


 - e要与模数n的欧拉函数值互素
 - e不能太小,e太小容易遭受低加密指数攻击
 - e在模数g(n)下的阶要足够大

3)解密密钥d的选取
不能太小

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值