pwnable.kr flag
data:image/s3,"s3://crabby-images/26f57/26f57bb040f445c38f8b446dfc70ec9eb5182709" alt=""
题目给了提示,让我们去分析二进制代码。所以我们进 IDA 去看二进制代码来找到相关信息。
data:image/s3,"s3://crabby-images/21368/21368b75090eccc3321d7962d3855279f80ea051" alt=""
在图中我们可以看到这个程序加了 UPX 壳,所以我们先脱壳。脱壳可以用 upx 脱壳工具。
$ sudo apt install upx
$ upx -d flag
Ultimate Packer for eXecutables
Copyright (C) 1996 - 2013
UPX 3.91 Markus Oberhumer, Laszlo Molnar & John Reiser Sep 30th 2013
File size Ratio Format Name
-------------------- ------ ----------- -----------
887219 <- 335288 37.79% linux/ElfAMD flag
Unpacked 1 file.
脱壳完成后,重新导入 IDA 进行分析。
data:image/s3,"s3://crabby-images/e6c19/e6c196daf9f932d487a147cba3701c118a747b57" alt=""
“I will malloc() and strcpy the flag here, take it.”这句提示真的已经很清楚了。意思就是你将会看到 malloc() 和 strcpy 操作。flag 就在后面不远的地方。
data:image/s3,"s3://crabby-images/9c675/9c6755ae86def8b40cd06a82b8755e1aa3a92919" alt=""
我们发现这么大一个 flag 就在这里,双击一下 flag 查看完整的字符串。
data:image/s3,"s3://crabby-images/324a9/324a9aa75fef6e2e2d6336efb88c11201dbbb8d0" alt=""
是的,就是这么简单。flag 就是这个。
**Flag: **UPX...? sounds like a delivery service :)
网友评论