CTF-RSA1(已知p、q、dp、dq、c)

题目来源:buuCTF-crypto-RSA1
题目:

p = 8637633767257008567099653486541091171320491509433615447539162437911244175885667806398411790524083553445158113502227745206205327690939504032994699902053229 
q = 12640674973996472769176047937170883420927050821480010581593137135372473880595613737337630629752577346147039284030082593490776630572584959954205336880228469 
dp = 6500795702216834621109042351193261530650043841056252930930949663358625016881832840728066026150264693076109354874099841380454881716097778307268116910582929 
dq = 783472263673553449019532580386470672380574033551303889137911760438881683674556098098256795673512201963002175438762767516968043599582527539160811120550041 
c = 24722305403887382073567316467649080662631552905960229399079107995602154418176056335800638887527614164073530437657085079676157350205351945222989351316076486573599576041978339872265925062764318536089007310270278526159678937431903862892400747915525118983959970607934142974736675784325993445942031372107342103852

很明显,给了密文c和一些参数,解密求m

一切以解题为目的的抄代码都是耍流氓,我们还是要从数学理论上去解决它,最后再根据数学理论来写代码。

公式推导:

先摆出已知条件:

c≡memodnc≡m^{e} mod ncmemodn
m≡cdmodnm≡c^{d} mod nmcdmodn
ϕ(n)=(p−1)∗(q−1)ϕ(n)=(p−1)∗(q−1)ϕ(n)=(p1)(q1)
d∗e≡1modϕ(n)d∗e≡1 mod ϕ(n)de1modϕ(n)
dp≡dmod(p−1)dp≡d mod (p−1)dpdmod(p1)
dq≡dmod(q−1)dq≡d mod (q−1)dqdmod(q1)

目的很明确,要想得到m,就要得到cdc^{d}cd

利用中国剩余定理,我们可以得到
m1≡cdmodp,m2≡cdmodqm1≡c^{d} mod p,m2≡c^{d} mod qm1cdmodp,m2cdm

评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值