第二十一个知识点:CRT算法如何提高RSA的性能?

第二十一个知识点:CRT算法如何提高RSA的性能?

中国剩余定理(The Chinese Remainder Theorem,CRT)表明,如果我们有两个等式x=amodNx=bmodM,那么x存在一个唯一一个modMN的解,当且仅当gcd(M,N)=1.

在RSA中,我们可能会执行一个模幂在一个几千个位的数字上[1].一般来说,公钥加密要比对称加密要慢.这种特性可能导致web服务器网络变慢,而在实现过程中提高效率(软件算法)对于避免性能问题起着至关重要的作用.

我们表示RSA方案中主要的加密操作就是模幂算法M=CdmodN.模幂能够用h-1次乘法和t-1次平方运算.(t是指数的长度,h是汉明系数).平均来说需要的次数一共是t+t/21.

更多的性能提升需要二进制指数算法或者窗口方法.对于后者我们依次处理w位.对于这个方案我们仍然需要t次平方运算,但是乘法次数减少到t/w.更多的性能提升能通过滑动窗口法得到进一步改进.

为了让RSA指数算法更快,我们能够执行一些额外的小技巧,当我们加密或者解密RSA的时候.CRT被用于这种情况.因此我们首先考虑一个私钥操作,这意味着我们能够获得私钥,因此获得了N的分解数N=pq.如果我们假设我们解密一个消息,那么我们的目标就是计算M=CdmodN.

首先我们要计算MmodpMmodq:

Mp=Cdmodp=Cdmodp1modq

Mq=Cdmodq=Cdmodp1modq

这个计算需要两个512模,512幂的运算,因为p, q都是512bit的.这会比1024,1024的快的多.

使用找CRT我们能恢复M,通过使用Mp,Mq.

计算T=p1modq,然后保存下来.

M能够通过MpMq用下面的办法恢复.

U=(MqMp)Tmodq

M=Mp+up

[1] http://www.cs.bris.ac.uk/~nigel/Crypto_Book/book.ps (Chapter 15)

good for write down

下面是说的比较好的CRT方法:

https://www.di-mgt.com.au/crt_rsa.html

posted @   WangZhuo2000  阅读(3404)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示