RSA算法描述

博客介绍了加密解密算法相关内容。先随机产生两个大素数p和q,计算n = p * q ,再选加密密钥e,用Euclid算法算解密密钥d,得到公钥和私钥。加密时将信息分块,按ci = mi^e ( mod n )计算密文,解密按mi = ci^d ( mod n )计算。

1、密钥对的产生。根据用户输入的pq的位数(bits)随机产生两个大素数,p q 。计算:

n = p * q

2、然后随机选择加密密钥e,要求 e ( p - 1 ) * ( q - 1 ) 互质。最后,利用Euclid 算法计算解密密钥d, 满足 e * d = 1 ( mod ( p - 1 ) * ( q - 1 ) ) 其中nd也要互质。数en是公钥,d是私钥。

3、加密信息 m时,首先把m分成等长数据块 m1 ,m2,..., mi ,块长s,其中 2^s <= n, s 尽可能的大。对应的密文是:

ci = mi^e ( mod n )

解密时作如下计算:

mi = ci^d ( mod n )

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值