这可能被认为是一个奇怪的问题,但我试图找出一种从我提供的输入中崩溃程序的方法。像无限循环或分段错误。
该计划非常标准。它使用get_line从文本文件中读取行,然后计算它们的长度。
我的问题基本上是:有没有人知道在txt文件中加入任何技巧会导致程序在读取文本行时以某种方式崩溃?
如果没有看到代码的所有细节,这是无用的,我道歉。我不知道怎么去问这样的问题。
答案 0 :(得分:4)
假设代码是天真地编写的,您可以执行以下操作:
创建一个文本文件,其中的行大于您在get_line中使用的缓冲区。
更改文件的权限并删除从中读取的权限。
在阅读中间删除文件。
将数据放入ASCII字符范围之外的文件中,以查看程序的反应方式。例如让它从二进制可执行文件而不是文本文件中读取。
在程序读取文件时向程序发送SIGINT,SIGHUP。
让你的猫躺在键盘上。
对于结局..如果你想弄清楚为什么你的程序崩溃请使用调试器而不是随机猜测。
答案 1 :(得分:0)
首先,你必须是一位经验丰富的程序员。其次,您必须清楚操作系统和机器的工作原理(选择代码,堆栈等)。然后你可以阅读有关漏洞利用和shellcode的内容。
答案 2 :(得分:0)
这取决于您使用的操作系统和终端以及程序如何处理您的输入。在少数情况下,空输入或足够长的输入将导致程序崩溃。