[MRCTF]baby_RSA

題目

import sympy
import random
from gmpy2 import gcd, invert
from Crypto.Util.number import getPrime, isPrime, getRandomNBitInteger, bytes_to_long, long_to_bytes
from z3 import *
flag = b"MRCTF{xxxx}"
base = 65537


def GCD(A):
    B = 1
    for i in range(1, len(A)):
        B = gcd(A[i-1], A[i])
    return B


def gen_p():
    P = [0 for i in range(17)]
    P[0] = getPrime(128)
    for i in range(1, 17):
        P[i] = sympy.nextprime(P[i-1])
    print("P_p :", P[9])
    n = 1
    for i in range(17):
        n *= P[i]
    p = getPrime(1024)
    factor = pow(p, base, n)
    print("P_factor :", factor)
    return sympy.nextprime(p)


def gen_q():
    sub_Q = getPrime(1024)
    Q_1 = getPrime(1024)
    Q_2 = getPrime(1024)
    Q = sub_Q ** Q_2 % Q_1
    print("Q_1: ", Q_1)
    print("Q_2: ", Q_2)
    print("sub_Q: ", sub_Q)
    return sympy.nextprime(Q)


if __name__ == "__main__":
    _E = base
    _P = gen_p()
    _Q = gen_q()
    assert (gcd(_E, (_P - 1) * (_Q - 1)) == 1)
    _M = bytes_to_long(flag)
    _C = pow(_M, _E, _P * _Q)
    print("Ciphertext = ", _C)
'''
P_p : 206027926847308612719677572554991143421
P_factor : 213671742765908980787116579976289600595864704574134469173111790965233629909513884704158446946409910475727584342641848597858942209151114627306286393390259700239698869487469080881267182803062488043469138252786381822646126962323295676431679988602406971858136496624861228526070581338082202663895710929460596143281673761666804565161435963957655012011051936180536581488499059517946308650135300428672486819645279969693519039407892941672784362868653243632727928279698588177694171797254644864554162848696210763681197279758130811723700154618280764123396312330032986093579531909363210692564988076206283296967165522152288770019720928264542910922693728918198338839
Q_1:  103766439849465588084625049495793857634556517064563488433148224524638105971161051763127718438062862548184814747601299494052813662851459740127499557785398714481909461631996020048315790167967699932967974484481209879664173009585231469785141628982021847883945871201430155071257803163523612863113967495969578605521
Q_2:  151010734276916939790591461278981486442548035032350797306496105136358723586953123484087860176438629843688462671681777513652947555325607414858514566053513243083627810686084890261120641161987614435114887565491866120507844566210561620503961205851409386041194326728437073995372322433035153519757017396063066469743
sub_Q:  168992529793593315757895995101430241994953638330919314800130536809801824971112039572562389449584350643924391984800978193707795909956472992631004290479273525116959461856227262232600089176950810729475058260332177626961286009876630340945093629959302803189668904123890991069113826241497783666995751391361028949651
Ciphertext =  1709187240516367141460862187749451047644094885791761673574674330840842792189795049968394122216854491757922647656430908587059997070488674220330847871811836724541907666983042376216411561826640060734307013458794925025684062804589439843027290282034999617915124231838524593607080377300985152179828199569474241678651559771763395596697140206072537688129790126472053987391538280007082203006348029125729650207661362371936196789562658458778312533505938858959644541233578654340925901963957980047639114170033936570060250438906130591377904182111622236567507022711176457301476543461600524993045300728432815672077399879668276471832
'''

分析

gen_q()中sub_Q,Q_1,Q_2都已給出,唯一注意的一點是Q = sub_Q ** Q_2 % Q_1,大數(shù)乘方計算量太大驯妄,應(yīng)該改為模運算Q=pow(sub_ Q,Q_2,Q_1)
gen_p()給出第十個素數(shù)合砂,使用sympy.nextprime()和sympy.prevprime()向前向后推就行翩伪,由于n由17個小素數(shù)相乘得到缘屹,對應(yīng)的φ(n)分別用小素數(shù)-1相乘得到轻姿,然后進(jìn)行一次普通的RSA,得到P

解題

from gmpy2 import *
from Crypto.Util.number import *
import sympy
C=  1709187240516367141460862187749451047644094885791761673574674330840842792189795049968394122216854491757922647656430908587059997070488674220330847871811836724541907666983042376216411561826640060734307013458794925025684062804589439843027290282034999617915124231838524593607080377300985152179828199569474241678651559771763395596697140206072537688129790126472053987391538280007082203006348029125729650207661362371936196789562658458778312533505938858959644541233578654340925901963957980047639114170033936570060250438906130591377904182111622236567507022711176457301476543461600524993045300728432815672077399879668276471832
def gen_q():
    Q_1=103766439849465588084625049495793857634556517064563488433148224524638105971161051763127718438062862548184814747601299494052813662851459740127499557785398714481909461631996020048315790167967699932967974484481209879664173009585231469785141628982021847883945871201430155071257803163523612863113967495969578605521
    Q_2=151010734276916939790591461278981486442548035032350797306496105136358723586953123484087860176438629843688462671681777513652947555325607414858514566053513243083627810686084890261120641161987614435114887565491866120507844566210561620503961205851409386041194326728437073995372322433035153519757017396063066469743
    sub_Q=168992529793593315757895995101430241994953638330919314800130536809801824971112039572562389449584350643924391984800978193707795909956472992631004290479273525116959461856227262232600089176950810729475058260332177626961286009876630340945093629959302803189668904123890991069113826241497783666995751391361028949651
    Q =pow(sub_Q,Q_2,Q_1)
    return sympy.nextprime(Q)
def gen_p():
    n=1
    phin=1
    P=[0 for i in range(17)]
    P[9]=206027926847308612719677572554991143421
    P_factor =213671742765908980787116579976289600595864704574134469173111790965233629909513884704158446946409910475727584342641848597858942209151114627306286393390259700239698869487469080881267182803062488043469138252786381822646126962323295676431679988602406971858136496624861228526070581338082202663895710929460596143281673761666804565161435963957655012011051936180536581488499059517946308650135300428672486819645279969693519039407892941672784362868653243632727928279698588177694171797254644864554162848696210763681197279758130811723700154618280764123396312330032986093579531909363210692564988076206283296967165522152288770019720928264542910922693728918198338839
    for i in range(8,-1,-1):
        P[i]=sympy.prevprime(P[i+1])
    for i in range(10,17):
        P[i]=sympy.nextprime(P[i-1])
    for i in range(17):
        n*=P[i]
    for i in range(17):
        phin*=P[i]-1
    d=invert(65537,phin)
    p=pow(P_factor,d,n)
    return sympy.nextprime(p)
P=gen_p()
Q=gen_q()
D=invert(65537,(P-1)*(Q-1))
M=pow(C,D,P*Q)
print(long_to_bytes(M))

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末豹休,一起剝皮案震驚了整個濱河市威根,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌洛搀,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件彰檬,死亡現(xiàn)場離奇詭異独榴,居然都是意外死亡棺榔,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進(jìn)店門郎笆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宛蚓,“玉大人设塔,你說我怎么就攤上這事⊥及兀” “怎么了任连?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵蚤吹,是天一觀的道長。 經(jīng)常有香客問我随抠,道長裁着,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任拱她,我火速辦了婚禮二驰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘椭懊。我一直安慰自己诸蚕,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布氧猬。 她就那樣靜靜地躺著背犯,像睡著了一般。 火紅的嫁衣襯著肌膚如雪盅抚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天禁熏,我揣著相機(jī)與錄音瞧毙,去河邊找鬼。 笑死释漆,一個胖子當(dāng)著我的面吹牛示姿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼堰乔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了韵卤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后父款,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鲫构,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡湿镀,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年蒸矛,在試婚紗的時候發(fā)現(xiàn)自己被綠了雏掠。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片耳奕。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡谓晌,死狀恐怖溺欧,靈堂內(nèi)的尸體忽然破棺而出烦味,到底是詐尸還是另有隱情柏靶,我是刑警寧澤,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站驻啤,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏沐旨。R本人自食惡果不足惜褒侧,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一歪脏、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧哩照,春花似錦次伶、人聲如沸秧骑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽侥蒙。三九已至论衍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工代承, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓瞒窒,卻偏偏與公主長得像葛峻,于是被迫代替她去往敵國和親采记。 傳聞我的和親對象是個殘疾皇子既棺,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 前言 本文的RSA例子代碼更新在我的github上。 RSA算法是最重要算法之一洪己,它是計算機(jī)通信安全的基石,保證了...
    game3108閱讀 11,661評論 2 53
  • 關(guān)于使用python實現(xiàn)RSA加密解密 一、非對稱加密算法 1艘款、乙方生成兩把密鑰(公鑰和私鑰)益眉。公鑰是公開的展鸡,任何...
    ttaymm閱讀 938評論 0 0
  • 轉(zhuǎn):https://www.cnblogs.com/gwind/p/8013116.html 一、基礎(chǔ)數(shù)論 1、互...
    right_33cb閱讀 410評論 0 0
  • 有一種深情叫凝望 有一種距離叫遙望 有一種愛情叫遺忘 有一種未來叫希望
    箬蒴笥閱讀 166評論 0 2
  • 說是新知,其實不是中狂,是因為自己執(zhí)行的不夠好凫碌,因此撰寫此文自己提醒自己。 新知是啥胃榕?能量充足的人的主要特征——1)睡...
    像話讀書爻閱讀 96評論 0 1