实验课写写之前做过的题叭
Guess-the-Number
下载文件,得到一个jar包,解压得到一个class文件
data:image/s3,"s3://crabby-images/f3624/f36246acbd4ca6853bdc90eb312c6fca9d29677c" alt=""
这个地方要用到一个反编译插件jadclipse,得到guess.class文件的源代码如下(全部)。
data:image/s3,"s3://crabby-images/59e55/59e55a66d4dc843dcacbdb3c8b978480cad87dd2" alt=""
if (my_number / 5 == guess_number) {//可求得guess_number为309137378,
输入命令java -jar guess.jar 309137378
data:image/s3,"s3://crabby-images/e24f3/e24f3e0b095765a53701a550d872f036a5dd9f62" alt=""
Shuffle
查看是32位文件,拖入ida查看,F5
data:image/s3,"s3://crabby-images/59ada/59adae5d9f099de6d620ffaebf57b301add76616" alt=""
按R查看字符串得到flag
data:image/s3,"s3://crabby-images/2455a/2455abf38da1e4177438d2cd3f71d9103fac4f8a" alt=""
re-for-50-plz-50
data:image/s3,"s3://crabby-images/876a9/876a9f70f82f8c2f099dfc40c19e207594095dd8" alt=""
打开ida,发现这是MIPS代码。本来准备安装RetDec,哎…还是恶补MIPS指令知识吧:https://www.cnblogs.com/thoupin/p/4018455.html
分析重点
data:image/s3,"s3://crabby-images/92a1a/92a1a01ed5ada540c0ffe52e5a9610d25dcce6d8" alt=""
这实际上就是一个对字符串的异或操作
str1 = 'cbtcqLUBChERV[[Nh@_X^D]X_YPV[CJ' |
dmd-50
data:image/s3,"s3://crabby-images/ef8e7/ef8e7fc415d0aa5de3ecc3aef6b3309b6c39ed72" alt=""
可以看到是ELF64位文件,需要在linux环境运行
data:image/s3,"s3://crabby-images/e6233/e6233f652a4eb78002b0f9e8bda627073e23f296" alt=""
可以看到需要输入正确的key
F5查看伪代码,发现是md5加密。
data:image/s3,"s3://crabby-images/ba7be/ba7be0f35e40da8e1e588d288a8b1570f283e265" alt=""
然后我们继续往下看,从if判断条件中,可以得知加密后的密文
data:image/s3,"s3://crabby-images/08f81/08f81e8d796410434d599ddd5d419c20715a6472" alt=""
编写脚本
data:image/s3,"s3://crabby-images/8d5c2/8d5c248eac79b1e2c16606d895f40a31f4a9a623" alt=""
parallel-comparator-200
C文件
|
粗略看一遍,发现 pthread_t
以及pthread_join
pthread_create
函数看不懂,于是网上查资料,得知
pthread_t
typedef unsigned __int64 uintptr_t |
pthread_create :作用为创建新线程,如果创建成功则返回
0,否则返回
error number``
int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine)(void*), void *arg); |
pthread_t *thread
是线程的标识符pthread_attr_t *attr
用来设置线程属性(如果为NULL,则为默认属性}void *(*start_routine)(void*)
是运行函数的起始地址void *arg
运行函数的参数
prhread_join : 作用为等待一个线程的结束,如果成功则返回
0,否则返回
error number``
int pthread_join(pthread_t thread, void **value_ptr); |
pthread_t thread
线程标识符void **value_ptr
存储被等待线程的返回值
有了以上知识,可以很容易可以知道user_string[20] (输入数组)的每个元素加上first_letter(经调试为固定值108),然后再与 differences[20]的元素异或,最后与just_a_string[20]的元素进行比较,用代码描述就是:
strcmp( ( user_string[i] + first_letter ) ^ differences[i] , just_a_string[i] ) |
脚本:
1 a = [0, 9, -9, -1, 13, -13, -4, -11, -9, -1, -7, 6, -13, 13, 3, 9, -13, -11, 6, -7] |
secret-galaxy-300
运行程序
data:image/s3,"s3://crabby-images/1d8f5/1d8f54a5d72025d68064a9967ca8a8e8b73da0b1" alt=""
ida查看字符串
data:image/s3,"s3://crabby-images/4f471/4f471c937bc964224ee84787af669b19f682b4b3" alt=""
动态调试,看运行后内存信息
data:image/s3,"s3://crabby-images/7a286/7a2867f86bbc084cac52bc17b4b34e472ca0f5da" alt=""
发现了一串字符 aliens_are_around_us提交,成功。
srm-50
exe文件
data:image/s3,"s3://crabby-images/55237/55237db1d9a3ee47c012fec5a67f00375785058c" alt=""
运行程序,可知是 MFC 框架的对话框程序,随便输入数据,显示注册失败。IDA 静态分析 IDA 分析,找到 winmain,是 MFC 的主函数
data:image/s3,"s3://crabby-images/5ea05/5ea05366985f439628910b784d5ecb57e9703fbe" alt=""
读程序可知先是验证邮箱的合法性,然后验证 v11,可推测 flag 长度为 16,但是 v11 是 一个长度为 4 的 char 数组 CHAR v11[4],如果输入超过四位就到 v12-v23,刚好 16 个。
编写程序
data:image/s3,"s3://crabby-images/20343/203433558aeaddb19464f89d2a9dca7c92316456" alt=""
得到flag
data:image/s3,"s3://crabby-images/30ea2/30ea24426831a615548a2525ff17f4c074f1abe3" alt=""
simple-check-100
这道题值得记录一下,因为这道题让我第一次接触peda。
1 int __cdecl main(int argc, const char **argv, const char **envp) |
很明显只要绕过第76行代码,我们就能够获取我们需要的flag,而且v8还是已知的
将Linux下的那个文件放入Linux调试。
task9_x86_64_46d01fe312d35ecf69c4ff8ab8ace75d080891dc
命令
gdb |
data:image/s3,"s3://crabby-images/0b1dc/0b1dc0d055e1c2f378c8a37f5b532b88b4e8fdd3" alt=""
然后一直执行命令next,运行到check_key函数处
data:image/s3,"s3://crabby-images/bc761/bc761f67272967b94b0cedd23c84ba7f4d899533" alt=""
把test eax,eax改为真就行,也就是把eax改为1。
data:image/s3,"s3://crabby-images/99558/9955853e964abc881a10bf20702869a35dac834b" alt=""
修改eax
set $eax=1 |
data:image/s3,"s3://crabby-images/33566/33566aa256c4277be2b5c047ef37cf7de8e232a5" alt=""
Mysterious
int __stdcall sub_401090(HWND hWnd, int a2, int a3, int a4) |
data:image/s3,"s3://crabby-images/25669/256696e4729e740ee4a879d070887e9985c378e5" alt=""
data:image/s3,"s3://crabby-images/7b7b9/7b7b901d9a5b756ea35a5f849b34f049f0752ac0" alt=""
flag{123_Buff3r_0v3rf|0w}
Newbie_calculations
题目名百度翻译成新手计算,那我猜应该是个实现计算器的题目。。。。
IDA打开程序,发现一长串的函数反复调用,而且程序没有输入,只有输出。额,那这样的话程序运行就应该输出flag,但程序中肯定会有垃圾循环操作,就让你跑不出来。
这种题目就要分析函数作用,简化,自己实现算法。
for ( i = 0; i < 32; ++i ) |
这道题目的关键就在于如何识别出上面这些函数的作用
_DWORD *__cdecl mul_401100(_DWORD *a1, int a2) |
1 int *__cdecl add_401000(int *a1, int a2) |
_DWORD *__cdecl sub_401220(_DWORD *a1, int a2) |
WP
def mul_401100(a,b): |
re1-100
这题竟然放在了高手区
1 if ( numRead ) |
主要分析confuseKey(bufParentRead, 42)函数
1 bool __cdecl confuseKey(char *szKey, int iKeyLength) |
exp
1 s1=‘53fc275d81‘ |
answer_to_everything
main.exe 打开
data:image/s3,"s3://crabby-images/263a8/263a8764f8f0d33b1e885969de0f8f64e7983e3e" alt="image-20201124165527869"
查壳
data:image/s3,"s3://crabby-images/869ca/869ca6e30fe68a4c4c8e416f3d5570906d1ea889" alt="image-20201124165540233"
不是有效的PE文件 即不是window 平台运行的软件 猜测是linux
将main.exe拖入ida 32
data:image/s3,"s3://crabby-images/784f4/784f4430d27433abf910391b33cf7746d1f6db3f" alt="image-20201124165553289"
得到信息 ELF64 for x86-64 elf即代表是在linux下运行的软件 64 代表 ida 32 分析不了这个 程序 得用ida 64 分析
所以现在拖入linux里 (ubuntu 64)
打开终端
然后查看 main.exe的权限 ls -a main.exe 然后显示
chmod a+x main.exe//变为可执行 //如果权限不够的话执行改命令 发现 -rwxrwxrwx此时有权限执行main.exe
data:image/s3,"s3://crabby-images/a147f/a147ff6c36c11a2f8b2499dd2cb150cc9286c56e" alt="000000"
然后输入命令 ./main.exe
显示
data:image/s3,"s3://crabby-images/61739/6173927ec92d13514664cfed084cf7cf94326028" alt=""
然后随便输入
然后提示 YOUSUCK//你真笨 猜测 这个程序 先输出一句话 Gimme 然后又输入东西 错误的话 输出 YOUFUCK 正确的话 输出我们想要的信息
接下来 将main.exe 拖入ida 64 查找 关键字符串 Gimme//因为很少直接看到了就不用再搜索了
data:image/s3,"s3://crabby-images/c3b41/c3b410b6fdf3d1d81b4e166dd190fd63e8db3edd" alt=""
双击 进去与之对应的代码段 可以看到
data:image/s3,"s3://crabby-images/58e5c/58e5ccdfcc62d16762e9aafcece1364ece3979ef" alt=""
然后敲击键盘上的x键可查看那几个引用它了 敲击 X 键
data:image/s3,"s3://crabby-images/ac498/ac49800bd16f37b01571e547e652b499770a62e9" alt=""
点进去为一个函数
tab 反汇编
data:image/s3,"s3://crabby-images/8a60a/8a60a9439443590211900b2ff8bc05d8f5ef157b" alt=""
即明白了 我们在linux中应该输入42
然后他输出 Cipher from Bill \nSubmit without any tags\n#kdudpeh 猜测 kdudpeh 是我们想要的flag ISCC{kdudpeh} 提交错误 看题目注意到 sha1 以为是 sha1碰撞 后来发现是 shi1加密 获得flag为: flag{80ee2a3fe31da904c596d993f7f1de4827c1450a}