writeup: 实验吧 CTF模拟试题 解密关-RSARSA

两种解法:

- java

  要加载security包的一系列子包,用到一大串base64加解密函数,太麻烦

 

- python

  首先要安装python gmpy2模块,windows下安装一直没成功,在kali linux下安装的。

  【在gmpy2模块下,有很多针对大数的高精度计算的函数,可以一步计算欧拉函数、求1 modphi。】

  脚本如下:

importgmpy2

 

p =  9648423029010515676590551740010426534945737639235739800643989352039852507298491399561035009163427050370107570733633350911691280297777160200625281665378483

q = 11874843837980297032092405848653656852760910154543380907650040190704283358909208578251063047732443992230647903887510065547947313543299303261986053486569407

e =  65537

c = 83208298995174604174773590298203639360540024871256126892889661345742403314929861939100492666605647316646576486526217457006376842280869728581726746401583705899941768214138742259689334840735633553053887641847651173776251820293087212885670180367406807406765923638973161375817392737747832762751690104423869019034

 

phi = (p- 1) * (q - 1)

d =long(gmpy2.invert(e, phi))

n = p *q

printpow(c, d, n)

最终结果是:

flag{5577446633554466577768879988}}

你可能感兴趣的:(writeup: 实验吧 CTF模拟试题 解密关-RSARSA)