我是靠谱客的博主 直率毛豆,最近开发中收集的这篇文章主要介绍2022赣育杯CTF---Wilson wp,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

文章目录

      • 题目
      • 题目分析
        • 第一步
        • 第二步
      • 解题代码

题目

from os import urandom
from gmpy2 import next_prime
from Crypto.Util.number import getPrime, bytes_to_long

p = getPrime(512)
q = next_prime(p)
f = open('flag.txt', 'rb')
flag = bytes_to_long(f.read() + urandom(80))
f.close()

N = 1
a = p * q
for i in range(1, p):
    N = (N * i) % a
e = 65537
m = N * flag % a
c = pow(m, e, a)
f = open('Encode.txt', 'w')
f.write(f'a = {a}n')
f.write(f'c = {c}n')
f.close()


a = 156853895847604116708242664263151514811095704969640303272039451331791888050995073274981545693518063639560286348739938318495685137088495867703518198511200409009953879436648706837731243061114851474801565873584183542649886358523850682697732574913523360866915083642887238043256280849100274825940626065115676325169
c = 3459715117165130065996389169943285249501133832272446001239391765859259811270526185228996906338576254353123756173289118671028939933226544773197852424767051933844004667155191851195814295922794480300237399956789038592856532530692732011427288405114650955620859282144504446058845961744702163836107847961388150810

题目分析

第一步

由题目可知,pq是相邻的素数,所以可以直接对n进行开二次方,得到的值q_near,其范围为p<q_near<q。然后不断的进行循环取q_near的下一个素数,直到能被n整除为止,此时的q_near即为q,进而得到pn//q

第二步

接下利用威尔逊定理
( p − 1 ) ! ≡ − 1   m o d   p (p−1)!equiv−1space mod space p (p1)!1 mod p

由于flag = bytes_to_long(f.read() + urandom(80)),其中在flag的基础上随机添加了80个字节的字符串,长度已经超过了512bit长度的p,所以我们在mod p情况下求出来的flag实际上是flag mod p的结果,也就是低位部分。
所以需要在mod q一次求得对应的 flag mod q,然后再利用crt处理得到m
已知 m = f l a g ⋅ ( p − 1 ) !   m o d   n m = flagcdot(p-1)! space mod space n m=flag(p1)! mod n,如果给m依次乘上 p , p + 1 , . . . , q − 1 p,p+1,...,q-1 p,p+1,...,q1就有 m 1 = f l a g ⋅ ( q − 1 ) !   m o d   n m1 = flagcdot(q-1)! space mod space n m1=flag(q1)! mod n,此时对m1模q,即 m 1   m o d   q ≡ f l a g ⋅ ( − 1 ) ≡ m 1   m o d   q m1 space mod space q equiv flagcdot(-1)equiv m1 space mod space q m1 mod qflag(1)m1 mod q。之后对m1求模逆得到flag mod q,最后用中国剩余定理crt组合一下即可求得原m

解题代码

import gmpy2
from Crypto.Util.number import *
from sympy.ntheory.modular import *

n = 156853895847604116708242664263151514811095704969640303272039451331791888050995073274981545693518063639560286348739938318495685137088495867703518198511200409009953879436648706837731243061114851474801565873584183542649886358523850682697732574913523360866915083642887238043256280849100274825940626065115676325169
c = 3459715117165130065996389169943285249501133832272446001239391765859259811270526185228996906338576254353123756173289118671028939933226544773197852424767051933844004667155191851195814295922794480300237399956789038592856532530692732011427288405114650955620859282144504446058845961744702163836107847961388150810
e = 65537

q_near = gmpy2.iroot(n,2)[0]
while n%q_near!=0:
    q_near=gmpy2.next_prime(q_near)
q = q_near
p = n//q
print(f"p={p}")
print(f"q={q}")

phi = (p-1)*(q-1)
d = gmpy2.invert(e,phi)
m = pow(c,d,n)
m1= m*gmpy2.invert(-1,p)%p
for i in range(p,q):
    m = m*i%q
m2 = m * gmpy2.invert(-1,q) %q
flag = crt([p,q],[m1,m2])[0]
print(long_to_bytes(flag))

flag:

Sangfor{51083a96-13b4-00c4-36c0-2025c1b46a63}

【真正爱一个人,就算把自己的全世界都给了她,却依然担心给的不够多,不够好。】

最后

以上就是直率毛豆为你收集整理的2022赣育杯CTF---Wilson wp的全部内容,希望文章能够帮你解决2022赣育杯CTF---Wilson wp所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(79)

评论列表共有 0 条评论

立即
投稿
返回
顶部