C - 用户输入崩溃的程序

时间:2012-04-23 06:08:17

标签: c text crash line

这可能被认为是一个奇怪的问题,但我试图找出一种从我提供的输入中崩溃程序的方法。像无限循环或分段错误。

该计划非常标准。它使用get_line从文本文件中读取行,然后计算它们的长度。

我的问题基本上是:有没有人知道在txt文件中加入任何技巧会导致程序在读取文本行时以某种方式崩溃?

如果没有看到代码的所有细节,这是无用的,我道歉。我不知道怎么去问这样的问题。

3 个答案:

答案 0 :(得分:4)

假设代码是天真地编写的,您可以执行以下操作:

  1. 创建一个文本文件,其中的行大于您在get_line中使用的缓冲区。

  2. 更改文件的权限并删除从中读取的权限。

  3. 在阅读中间删除文件。

  4. 将数据放入ASCII字符范围之外的文件中,以查看程序的反应方式。例如让它从二进制可执行文件而不是文本文件中读取。

  5. 在程序读取文件时向程序发送SIGINT,SIGHUP。

  6. 让你的猫躺在键盘上。

  7. 对于结局..如果你想弄清楚为什么你的程序崩溃请使用调试器而不是随机猜测。

答案 1 :(得分:0)

首先,你必须是一位经验丰富的程序员。其次,您必须清楚操作系统和机器的工作原理(选择代码,堆栈等)。然后你可以阅读有关漏洞利用和shellcode的内容。

答案 2 :(得分:0)

这取决于您使用的操作系统和终端以及程序如何处理您的输入。在少数情况下,输入或足够长的输入将导致程序崩溃。