V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Nullplus
V2EX  ›  汇编

如何解决 ShellCode 中 call 所产生的 \x00

  •  
  •   Nullplus · 2020-01-18 05:48:45 +08:00 · 7209 次点击
    这是一个创建于 1814 天前的主题,其中的信息可能已经有所发展或是发生改变。

    各位大佬好,想问一个关于汇编和 ShellCode 中零字节的问题。

    在学习缓冲溢出时,我根据要求写了一段取得程序 PID 的汇编来构造 ShellCode,其中一段调用了 C 中的 printf 来输出结果:

    lea    rdi, [rel message]
    mov    rsi, rax
    call   printf
    

    反汇编后的结果如下:

      13:	48 8d 3d e8 ff ff ff 	lea    -0x18(%rip),%rdi        # 2 <message>
      1a:	48 89 c6             	mov    %rax,%rsi
      1d:	e8 00 00 00 00       	callq  22 <code+0x19>
    

    如上面代码第三行所示,opcode 出现了 \x00, 我搜索了一圈都没有合适的能把 \x00 替换掉的方案,于是想来 V 站问问各位大佬们~

    4 条回复    2020-01-18 14:44:12 +08:00
    codehz
        1
    codehz  
       2020-01-18 09:12:47 +08:00 via Android
    Ummm 这个 00 不是表示 obj 还没被链接,然后留 0 等链接器填值么
    ThirdFlame
        3
    ThirdFlame  
       2020-01-18 11:08:02 +08:00
    1 楼正解。 因为不是绝对地址,是相对地址。
    zk8802
        4
    zk8802  
       2020-01-18 14:44:12 +08:00 via iPhone
    Shellcode 不会被系统的 loader 加载,因此不能进行重定位。如果要用进程中的其它函数(例如库函数),需要自己找到固定地址的调用指令(例如主程序的 PLT entry )然后在 shellcode 中把固定地址硬编码进去,或者在 shellcode 里面加上解析函数地址的功能。遇到 ASLR 的话,解析函数地址很麻烦。一般而言,shellcode 只调用系统调用。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2784 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 07:40 · PVG 15:40 · LAX 23:40 · JFK 02:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.