首先,先在虚拟机里check easy的保护:
data:image/s3,"s3://crabby-images/bb8af/bb8af7bfb449a74e755b3bf267819ec26cde28f3" alt=""
发现只开了堆栈不可执行。
把文件拖进ida里,打开main函数
data:image/s3,"s3://crabby-images/4d479/4d4792f3654a526f492721f83d2630e6f35753db" alt=""
发现是gets溢出,转到汇编
data:image/s3,"s3://crabby-images/bd0ea/bd0eaaf130d9c20335edd1d1d586cacac66e5e01" alt=""
发现偏移量为0X40
或者在gdb里生成垃圾字符,写入文件。64位的文件,得到爆出来的地址在下图位置,取后八位为地址输入语句 cyclic -l 地址
data:image/s3,"s3://crabby-images/cedf8/cedf8110663925158ef3365893a19bb4d25e0e11" alt=""
data:image/s3,"s3://crabby-images/12797/12797975b488d4cc940483fe786da616e3582d3c" alt=""
可知需要72个垃圾字符(72=0x40+8)
然后我们再倒回去看ida里,我们发现有个system函数
data:image/s3,"s3://crabby-images/46c85/46c85bcdc0074cc035373cda5913263b2802c9e1" alt=""
我们看到有个command,我们选择打开汇编,点击command
data:image/s3,"s3://crabby-images/115ce/115ce7325a921bf90682c0b7335a6c037539ed58" alt=""
发现/bin/sh就在里面,而command是传向system 的,所以我们去找那个赋值语句(将/bin/sh 传入command)的地址0x4006AE
data:image/s3,"s3://crabby-images/90037/900378307eec1fd3697d662375684e6e1cab6ff5" alt=""
我们就以写出脚本啦
data:image/s3,"s3://crabby-images/f724b/f724bca80f15168889f73d496553385ebdfebe35" alt=""
然后就可以交互啦(貌似本地打不出flag,远程的IP也不记得了)
网友评论