【问题标题】:sys_read will "spill" characters when buffer overflowssys_read 将在缓冲区溢出时“溢出”字符
【发布时间】:2013-04-12 03:36:40
【问题描述】:

在 Linux x86 上使用 NASM

mov ecx,eax
mov edx,ebx
mov eax,3
mov ebx,0
int 80h
ret

EAX 最初有一个mov'd db 常量,EBX 有缓冲区的长度

这是我用来从控制台读取的代码。它工作正常,除了一个问题......我要求 2 个字符,如果我超过 2 个字符并按 Enter,下次我要求输入时,那些“溢出”/额外字符将立即输入该请求,没有用户交互。如果我再次请求输入失败,这些额外的字符将立即被 shell 解释为命令。

例子:

对该读取例程的 2 次后续调用将产生:

2345

第二个输入请求不会阻塞也不会提示用户输入任何内容,它只需要它可以使用的任何字符。在这两种情况下,我都要求在一个用零填充的 3 字节缓冲区上正好两个字符。

1 次调用阅读例程:

2345
$> 45: command not found

关于如何解决这个问题的任何想法?我应该使用不同的系统调用吗?

【问题讨论】:

    标签: linux assembly x86 nasm system-calls


    【解决方案1】:

    读取输入后,您需要刷新缓冲区以避免将多余的输入传递到下一个输入读取。不过,这不是缓冲区溢出。

    我也问过同样的问题,但对于 x86-64 Linux,它并不完全重复: How to avoid stdin input that does not fit in buffer be sent to the shell in Linux 64-bit Intel (x86-64) assembly

    无论如何,按照 GunnerInc 的优秀教程(适用于 x86 Linux)应该可以解决您的问题: http://www.dreamincode.net/forums/topic/286248-nasm-linux-terminal-inputoutput-wint-80h/

    【讨论】:

      猜你喜欢
      • 2010-11-11
      • 2013-11-06
      • 2022-11-30
      • 2015-12-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-10-22
      • 2012-03-03
      相关资源
      最近更新 更多