首先看一道问题:若Rabin加密的模为 N=2366232284015146849567653630179316337954424149957532872696957, 密文为C=389180666582861787819700888339376947930588111461036399156437, 试解密出明文。
先要了解一下Rabin算法的基本思想,这里给出一篇从百度文库找的介绍Rabin算法的链接:Rabin算法介绍(当然可以查看更多更详细地对于Rabin算法的介绍)
因为涉及到大整数的运算,为了方便,这里用了sagemath软件来解决问题,关于sagemath的下载安装和一些基本操作可以自行了解,很简单,这里不做过多介绍。
开始着手问题,明确明文空间P={0,1,...,N-1},设m为某一明文,则对应的密文c=m² mod N
对N进行质因数分解,分解成两个素数,这里用到了sagemath中的factor方法
2366232284015146849567653630179316337954424149957532872696957=990932843298892349238943242791*2387883598789374983927498237627
取p为990932843298892349238943242791,q为2387883598789374983927498237627,