UNCTF2022考后学习记录(萌新)
写在前面
博主本人萌新,只入门了Re,这次比赛只会签到题。所以本篇博客也不叫WP,只是算是我赛后复盘的学习记录。真正的WP可以看官方WP或者看看Re大佬的WP。因为现在还没有学习其他方向,所以其他方向的题目我会留个坑,等以后接触了有空再写吧(大概率咕咕了而且大概率也只会签到题)。
Reverse
whereisyourkey-广东海洋大学
这题是我觉得最没难度的
首先丢进exeinfoPE内看看
很好无壳32位,接下来直接丢进32位ida中找到main函数F5反编译
简单阅读一下就知道加密逻辑很好理解,就是将V5通过ooooo函数加密后即为Flag
通过转换知道V5如下
接下来只需知道ooooo函数在干什么即可双击ooooo函数
很好理解字母小于等于n的替换成前两位字母,m,o不变,大于o的替换成后三位字母。这样我们就可以通过运算直接解出Flag,没必要写脚本。
Flag:UNCTF{yesiamflag}
ezzzzre-广东海洋大学
这题当时起初没放进exeinfoPE内看看,结果因为加壳导致一直解不出来,学习了一下脱壳就解决了。
这题我就详细写一下脱壳过程(大佬们请忽略)
可以看到是一个UPX壳,我们首先下载UPX
接下来打开cmd,cd进入UPX所在文件夹
接着输入UPX -d 目标文件地址
完成脱壳后下方显示“Unpacked 1 file.”,表示脱壳成功。
脱壳后可以看到是64位
64位ida打开,可以看到Flag逻辑即为2 * aHelloctf[i] - 69
而双击aHelloctf可以找到该串字符为’HELLOCTF’,写个简单脚本可解出Flag
思考后再点击查看代码哦
1 | #include <bits/stdc++.h> |
Flag:UNCTF{KESSYAcG}
Sudoku-陆军工程大学
听名字很唬人,看起来像是解数独,但其实简单阅读main函数可知这题是要你输入V11这个矩阵
若与他给出的V12矩阵一样就用V11中每一行的数减去V13中每一行的数求和最后加上50对应一个字符
(题中有个vme50的小彩蛋)八行八个字符就是Flag。
现在问题就是怎么得到V12和V13,我们采用动态调试。
首先第60行设置断点
F9选择Local Windows debugger
之后再次F9
F5回到源码页
之后分别双击V12和V13可以得到二者的值,注意用鼠标滚轮滚动查看值,因为每四行是一个值,将二者的值记录,注意别抄错,抄漏。最后写个脚本解决。
思考后再点击查看代码哦
1 | #include <bits/stdc++.h> |
Flag:UNCTF{OAOJYKOFR}