RSA加密算法简介[通俗易懂]

RSA加密算法简介[通俗易懂]背景RSA加密算法是公钥密码最著名的算法之一,是由MIT三位(RonRivest,AdiShamir,LenAdleman)提出的,也就以三位的名字首字母命名。该算法的理论基础是“大数分解和素数检测“,如果说有一天,大数分解和素数检测的数学理论被证明可以简单解决,那么RSA算法的加密将没有任何意义。有提出说量子计算机的出现可以大大提高RSA的破解效率。下面我们将简单学习RSA加密算法的

大家好,又见面了,我是你们的朋友全栈君。

背景

RSA加密算法是公钥密码最著名的算法之一,是由MIT三位(Ron Rivest, Adi Shamir, Len Adleman)提出的,也就以三位的名字首字母命名。
该算法的理论基础是“大数分解和素数检测“,如果说有一天,大数分解和素数检测的数学理论被证明可以简单解决,那么RSA算法的加密将没有任何意义。有提出说量子计算机的出现可以大大提高RSA的破解效率。下面我们将简单学习RSA加密算法的基本知识。

算法描述

RSA算法使用平方运算,明文以分组为单位进行加密,每个分组的二进制值小于n,即分组的大小必须小于等于log2(n)+1位(通常n的大小为1024位二进制数或309为十进制数,即n<2^1024)。对明文分组M和密文分组C,加密解密过程如下:

加密:这里写图片描述
解密:这里写图片描述

收发双方均已知n,发送方已知e,只有接收方已知d,因此RSA加密算法的公钥PU为{n,e},私钥PR为{n,d}。
d,e,n应满足如下条件:

  1. 可以找到e,d,n,使得对所有M< n,有这里写图片描述
  2. 对所有M< n,计算M^e和C^e是比较容易的;
  3. 由e,n预测d是不可行的。

算法理解

该算法使用上非常简单,将明文分组M进行加密操作得到密文分组C,接收方再对密文分组C进行解密操作得到明文分组M,加密过程也很好理解,就是对明文分组C取指数e后模n。解密过程为对密文分组M取指数d后模n。但是为什么可以这么做呢?如何得到合适的e,d,n呢?

这里面有一个非常重要的等式:

这里写图片描述

当e和d互为模这里写图片描述的乘法逆时,上述关系式成立

其中这里写图片描述为欧拉函数。也就是说当n=ed时,算法成立。
在《公钥密码 之 素数,费马定理与欧拉定理》中我们提到,对于素数p和q,有这里写图片描述

e和d应满足如下关系:
这里写图片描述

即e和d互为模这里写图片描述的乘法逆。
根据模算数的性质,仅当d(和e)与这里写图片描述互素时,d和e是模这里写图片描述的乘法逆元。因为d和这里写图片描述互素,则一定存在一个整数是d的模反元素。同理对于e也是如此。因此可知d和e互为模反元素,则得到上式等价于
这里写图片描述
这里写图片描述

这里面涉及到了模反元素,模反函数的定义为:

如果两个正整数a和n互素,那么一定可以找到整数b,使得 ab-1 被n整除,或者说ab被n除的余数是1。
这里写图片描述
其中b叫做a的模反元素。

RSA加密算法密钥生成过程:
这里写图片描述

这里面模反元素d比较难计算,可以利用扩展的欧几里得算法计算。大多数情况下我们的素数pq会选的很大,这样得到的n也会很大,可以增加加密算法的安全性。但是为什么呢?

RSA加密算法的安全性

RSA加密算法中一共涉及到p,q,n,这里写图片描述,e,d六个数字,其中{n,e}为公钥,也就是说n,e是暴露的,那么能否通过n,e来得到密钥{n,d}呢?其中关键就是得到d。
我们来看如何得到d:
1。这里写图片描述
其中e是已知的,那么关键就是如何得到这里写图片描述
2。这里写图片描述
p,q成为得到这里写图片描述的关键,而pq可以从n中得到,并且n是已知的。
3。n=pq,那么对n进行因式分解即可。

到这一步你就知道为什么要使得n很大了吧!也就解释了在一开始提到的该算法的理论基础是“大数分解和素数检测“。如果大数分解被证明是可以很快计算的,那么RSA加密后的密文就相当于裸奔了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135707.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月3日 下午8:00
下一篇 2022年5月3日 下午8:20


相关推荐

  • 转罗马字符_罗马字符是什么意思

    转罗马字符_罗马字符是什么意思publicclassNumToRoman{publicstaticstringToRomanNum(intpNum){string[,]a=newstring[3,10]{{“”,”I”,”II”,”III”,”IV”,”V”,”VI”,”VII”,”VIII”,

    2026年4月18日
    5
  • Matlab中sqrt函数的用法「建议收藏」

    Matlab中sqrt函数的用法「建议收藏」目录语法说明示例向量元素的平方根输入参数详细信息IEEE合规性提示sqrt求解平方根语法B=sqrt(X)说明B=sqrt(X)返回数组X的每个元素的平方根。对于X的负元素或复数元素,sqrt(X)生成复数结果。sqrt函数的域包含负数和复数,如果使用不当,可能会导致意外结果。对于负的复数z=u+i*w,复数方根sqrt(z)返回sqrt(r)*(cos(phi/2)+1i*sin(phi/2))…

    2022年5月1日
    114
  • 上下文无关语法

    上下文无关语法直观的理解 V 变元指代一类事物 如 V 指代动词 那么 T 总结符就是一系列具体动作 初始符就是文化最开始 未发生任何变化时的样子 产生式麻 就是动词到具体动作的映射过程 上下文无关文法是形式化描述语言的又一种工具 它表示语言的能力强于有穷自动机和正则表达式 但也有无法它表示的语言 基本思想是用变量表示串的集合 递归的使用变量去定义变量 因此善于表示嵌套的结构

    2026年3月19日
    3
  • iBatis与MyBatis区别

    iBatis与MyBatis区别对于从事 JavaEE 的开发人员来说 iBatis 是一个再熟悉不过的持久层框架了 在 Hibernate JPA 这样的一站式对象 关系映射 O RMapping 解决方案盛行之前 iBaits 基本是持久层框架的不二选择 即使在持久层框架层出不穷的今天 iBatis 凭借着易学易用 轻巧灵活等特点 也仍然拥有一席之地 尤其对于擅长 SQL 的开发人员来说 iBatis 对 SQL 和

    2026年3月19日
    2
  • 公有云和私有云的对比和区别「建议收藏」

    公有云和私有云的对比和区别「建议收藏」什么是云?云技术是指在广域网或局域网内将硬件、软件、网络等系列资源统一起来,实现数据的计算、储存、处理和共享的一种托管技术。例如云计算:将计算作为一种服务交付给用户而不是一种产品,在这种服务中,计算资源、软件和信息如同日常的水、电一样通过互联网交付给计算机和其他的计算媒介。​云计算的三种模式​按照商业模式的不同,云计算可以被分为三大类:公有云、私有云和混合云。这三种模式构成了云基础设施构建和消费的基础。​​1、公有云(PublicClouds),“公有”反映了这类云服务并非用户

    2022年6月29日
    31
  • OpenClaw中文版Molili公测开启!一键部署安装,支持钉钉/飞书控制

    OpenClaw中文版Molili公测开启!一键部署安装,支持钉钉/飞书控制

    2026年3月13日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号