rsa算法的问题???

tombaby 2002-07-10 08:36:56
在RSA算法中加密明文m^e mod n其中中间结果m^e在e选的大的情况下会非常大,这在计算机中怎么办才不会发生数值越界的情况,或者怎么来解决.
...全文
27 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
saint001 2002-07-15
  • 打赏
  • 举报
回复
把e用二进制表示
e1 e2 e3 ... en(反序排列,从低位到高位)
a=m;
y=1;
for i=1:n
if e(i)=1
y=y*a mod n;
end
a=a*a mod n;
end
输出为y
这是一个可行的算法,密码学中有比较成熟,详细的
比这个好
zhouxinghai 2002-07-15
  • 打赏
  • 举报
回复
补充:
看《应用密码学》一书,
需要存储的大数的长度为n的二倍
libi 2002-07-15
  • 打赏
  • 举报
回复
对于一个n位数的乘法运算,必须先得有一个2n位的寄存器才能做的,指数运算相当于多次乘法运算,对于越界问题可以每次做完乘法都执行一次取模运算来避免。
alidiedie 2002-07-10
  • 打赏
  • 举报
回复
用大数乘法的思想.
如果m^e mod n特别大,且m能分解成两个较小数的乘积.比如m=x*y.
那么m^e mod n应该和 ((x^e mod n)*(y^e mod n))mod n相等.

明白了吗?

6^2 mod 5 =1
同样因为 6=2*3.
所以
6^2 mod 5 = ((2^2 mod 5) *(3 ^2 mod 5))mod 5=1;

这样就解决了.实际中也是这么作的.
【课程介绍】     课程目标:             - 有状态登录和无状态登录的区别             - 常见的非对称加密算法和非对称的加密方式             - 老版本只使用jwt进行加密的弊端             - 授权中心的授权流程             - 如何整合网关组件实现jwt安全验证             - 理解什么是公钥什么是私钥      - 深刻理解授权流程什么是有状态? 有状态服务,即服务端需要记录每次会话的客户端信息,从而识别客户端身份,根据用户身份进行请求的处理,典型的设计如tomcat中的session。例如登录:用户登录后,我们把登录者的信息保存在服务端session中,并且给用户一个cookie值,记录对应的session。然后下次请求,用户携带cookie值来,我们就能识别到对应session,从而找到用户的信息。缺点是什么?- 服务端保存大量数据,增加服务端压力- 服务端保存用户状态,无法进行水平扩展- 客户端请求依赖服务端,多次请求必须访问同一台服务器。什么是无状态? 微服务集群中的每个服务,对外提供的都是Rest风格的接口。而Rest风格的一个最重要的规范就是:服务的无状态性,即:- 服务端不保存任何客户端请求者信息- 客户端的每次请求必须具备自描述信息,通过这些信息识别客户端身份带来的好处是什么呢?- 客户端请求不依赖服务端的信息,任何多次请求不需要必须访问到同一台服务- 服务端的集群和状态对客户端透明- 服务端可以任意的迁移和伸缩- 减小服务端存储压力

33,010

社区成员

发帖
与我相关
我的任务
社区描述
数据结构与算法相关内容讨论专区
社区管理员
  • 数据结构与算法社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧