这一系列文章为pwnable.krToddlr’s Bottle的全部题解,其中有三道题目相对而言稍难或者说比较经典,单独成篇,其他题目的题解放在一起发出来。
0x02fd
Ssh连接
看一下目录
我们需要执行flag,或者查看flag的内容
看题目的提示就知道这题和文件描述符有关
看看源码
在代码中我们可以看到要通过strcmp()比较后会输出
查看strcmp的用法
可知,strcmp()中,若参数s1和s2字符串相同则返回0,s1大于s2则返回大于0的值,s1小于s2则返回小于0的值。
代码中要cat flag执行的话if语句应满足strcmp返回0,即buf的内容应为LETMEWIN
那么buf的值哪来的呢
man read可知
buffer的值由read控制,从fd读入count个字节内容
fd在代码中的值为atoi(argv[1])-0x1234
atoi()用于把字符串转换为整数
由linux下文件描述符可知(源码在/usr/include/unistd.h)
即文件描述符0表示标准输入,也就是我们可以从命令行中控制的。
Atoi接收的参数我们可以控制,只要令argv[1]为0x1234(argv[0]为程序名称,argv[1]为输入参数),0x1234十进制为4660,经过运算最后赋值给fd的就是0,然后再传入read(),由于fd为0,所以我们在命令行中输入什么,则在buffer中写入的就是什么,只要输入LETMEWIN就可以了
分析完毕,接下来测试一下
通过,logout关闭ssh连接
0x02collision
看题目描述应和哈希碰撞相关
看看源代码
在main()中看到传入的argv[1]需要满足条件:
长度为20字节,传给check_password后的返回值为硬编码的0x21dd09ec
那么我们需要来看一下check_password的逻辑
可以看到传参为char型指针,在逻辑中被强制类型转换为int型指针
从大小的角度来看即1字节转换为4字节,一共20字节,20/4=5,刚好对应for循环里的5次,for循环是做了个累加的操作,即累加和等于0x21DD09EC即可
emmm简单理解,就是说输入20字节,每4字节一组,共5组,5组相加后等于0x21dd09ec即可。
这就很简单了
我设16个字节为0x1,那么另外的4字节应为差值0x1dd905e8,又因为小端序,所以写的时候倒过来写即可,如下所示
0x03bof
根据题目描述这是一道缓冲区溢出的题目
下载bof及其代码
看看源码
看到main中调用了func,传参为0xdeadbeef
而func()中可以看到需要传参为0xcafebabe才可以getshell
我们注意到func中我们可以通过gets控制输入,gets像本题的这种用法是非常危险的,容易造成缓冲区溢出攻击,这次我们就来pwn掉它
我们尝试输入写字符看看
那么基本的思路有了,就是找到确定的偏移,然后使用0xcafebabe覆盖0xdeadbeef。
偏移是多少呢
配合gdb来看看
在main下断点
输入r启动
在断点处停下了
我们反汇编func看看比较key和0xcafebabe指令在哪儿
看到上图的红框中的cmp指令了,这就是关键
可以看到地址是0x56555654
在这里下个断点
按c继续执行
命中第二个断点后,我们来看看栈的布局
可以看到0xdeadbeef在0xffffd330,而我们输入的A是从0xffffd2fc开始
emmm,数一下,从最开始的0x41到0xdeadbeef之前查了13*4=52个字节,在53-56处写入0xcafebabe覆盖掉原有的0xdeadbeef即可
编写pwntools脚本
测试如图,打回了一个shell
面向超等用户,春暖花开。可是也要让普通用户感知到阳光与花瓣的样子,让他们能以他们最习惯的方法,找到“春暖花开”的门。 2017年罗振宇跨年演讲中,提到了一个问题: 在中国市场,假如你是一个新选手,如何...
ppap是什么意思(这篇终于把PPAP说的通俗易懂了)PPAP简直是个很不错的对象。它让各人对付产物,零部件的品质尺度,追溯,都有了一个统一的“语言”。 对付批量出产的企业来说,PPAP绝对值得僵持做...
犯法吗怎么找黑客 1、网上黑客你说的没错,犯法吗接单事成付款码,信得过,单独下载WIN10安装镜像在一个独立的分区中进行安装,接单黑客猿族在战斗找黑客中遭遇了前所未有的重创,邪魔入侵。等杂志。经互联网...
1、黑死病(1347 – 1351) 黑死病在人类历史上是最致命的瘟疫之一。普遍认为是由一种名为鼠疫的细菌造成的。但最近有人认为是由其它一些疾病引起的。关于鼠疫的起源在专家中引起了广泛的争议。一些历史...
最近微博热搜被NINE PERCENT的新专辑主打歌《创新者》音源泄露事件所占领,本应该在11月9号宣布的新专辑歌曲中的部门音源及相似音频,早在刊行日前已经在网上传播。在这里照旧支持NINE维权,做音...
做产物设计和运营时,虽然要以用户为中心,因为产物是给用户利用的,这没什么可接头的。但不便是要百分之百听用户的话,不是用户说什么都对。 运营人员和用户打仗的最多,也是职责和代价地址,必定不能抵触或嫌弃用...