RSA1

image-20240602163129651

已知dp和dq的求解明文

dp=d%(p-1)

dq=d%(q-1)

因为n=p*q

所以

m1=c^d(mod p)=>m1=c^(dp)(mod p)
m2=c^d(mod q)=>m2=c^(dq)(mod q)
m=c^d+k*n
m1+kp=c^d
m2+kq=c^d
k≡p ′(m2−m1)(mod q)

所以

c^d=m1+[p'(m2-m1)(mod q)]*p

脚本

from gmpy2 import *
from Crypto.Util.number import *

# dp+dq+p+q+c => m

def rsa(dp,dq,p,q,c):
m1=pow(c,dp,p)
m2=pow(c,dq,q)
p_q=invert(p,q)
m=m1+p_q*((m2-m1)%q)*p
print(long_to_bytes(m))



if __name__ == "__main__":
p = 8637633767257008567099653486541091171320491509433615447539162437911244175885667806398411790524083553445158113502227745206205327690939504032994699902053229
q = 12640674973996472769176047937170883420927050821480010581593137135372473880595613737337630629752577346147039284030082593490776630572584959954205336880228469
dp = 6500795702216834621109042351193261530650043841056252930930949663358625016881832840728066026150264693076109354874099841380454881716097778307268116910582929
dq = 783472263673553449019532580386470672380574033551303889137911760438881683674556098098256795673512201963002175438762767516968043599582527539160811120550041
c = 24722305403887382073567316467649080662631552905960229399079107995602154418176056335800638887527614164073530437657085079676157350205351945222989351316076486573599576041978339872265925062764318536089007310270278526159678937431903862892400747915525118983959970607934142974736675784325993445942031372107342103852

rsa(dp,dq,p,q,c)