| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 网络协议 -> 网络安全实验一,栈溢出更改变量值使得判断通过,so can u find flag -> 正文阅读 |
|
[网络协议]网络安全实验一,栈溢出更改变量值使得判断通过,so can u find flag |
栈溢出修改变量num的值使判断通过虚拟机环境以及IDE
题目代码解析
关于setbuf作用的部分详情请参考 思路从代码分析看来,此题思路清晰,通过对s 的输入,gets不限制输入的长度造成栈溢出从而可以改变num 的值为0x61616161来达到判断通过的效果 实验步骤1.打开虚拟机win-xp,在vc6里把代码输入关于vc6的工程创建以及代码调试具体操作请参考我上一篇文章的内容: 代码附上:
2.调试断点设置由于已经明确了漏洞在foo函数里,我们可以直接跳过main在foo函数里设置断点要方便些 然后就可以进入调试模式了 3.开始调试代码执行到输入的时候按钮会变灰,此时需要调出黑框框进行输入?我们先随便输入一个字符‘a’来看看是啥情况(s是char类型,只占1个字节,但实际上程序里给它分配了4个字节可能是为了补齐),前面已经有result声明了,我们在后面重新加一个
然后重新运行调试并进行变量监视: 我们可以看到result和x两个变量的地址分别是0x0012ff24和0x0012ff1c,把s的0x0012ff20夹在中间的,分别占据4个字节,char占4个字节可能是对齐限制 同时,从上图我们也能看到num的位置处于0x0012ff30,我们可以得知s和num的距离相差16个字节,: 0012FF3C位置存储的是寄存器ebx的值7FFD8000 我们可以退出调试,在输入界面输入28个a进行测试看看是否有影响
我们可以看到,num已经变成了0x61616161,且代码能正常运行,并且我们跳到了flag,作业到此结束,只要num部分全a其他的随意输入(不要太长) 关于result = puts(&s);中result值为0汇编预览,来到该行代码 在执行前result的值还在是初始值,而监控视窗常量puts(&s)的值为0 下图展示了需要注意的几个量 经常调试的话应该知道真正改变result值的汇编命令为最后一行的
前者 dword ptr[ebp-4]为result的位置,后者为eax寄存器的值,那么可以猜测这一步的时候eax的值为0所以赋给result的值也是0, 代码执行前,寄存器eax的地址不为0,可以猜测在中间某个部分的时候eax的值变为了0,在前面gets的汇编命令我们也能看到对eax的修改 可是,在展示出的汇编命令并没有对eax进行修改,我们可以猜测在call部分的调用puts命令的部分里面存在对eax的修改,我们把代码执行到该行然后点击step into:
我们可以看到我们来到了puts的汇编命令部分,命令很多,我们可以一直下一步并监视eax的值知道eax发生改变 我们可以看到,在该行代码执行结束后eax变为了0,发现它对eax进行了对自己的异或,于是eax的值变为了0。但是,后面有没有操作eax我们并不清楚,但可以确定eax是在这一块部分里变化为0导致后面的result的值为0 。 该行结束后eax变为了0000000a。 再次变化。 具体位置就不进行细说了,在加载puts的汇编命令后eax变为了0,导致在最后的mov给result赋值时result为0。 |
|
网络协议 最新文章 |
使用Easyswoole 搭建简单的Websoket服务 |
常见的数据通信方式有哪些? |
Openssl 1024bit RSA算法---公私钥获取和处 |
HTTPS协议的密钥交换流程 |
《小白WEB安全入门》03. 漏洞篇 |
HttpRunner4.x 安装与使用 |
2021-07-04 |
手写RPC学习笔记 |
K8S高可用版本部署 |
mySQL计算IP地址范围 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 20:51:40- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |