gpt4 book ai didi

linux - nasm 程序集 sys_execve/bin/sh

转载 作者:太空宇宙 更新时间:2023-11-04 09:20:16 26 4
gpt4 key购买 nike

我正在尝试触发 sys_execve (X86_64)。

section .data
file db "/bin/sh",0

section .text
global _start

_start:

mov rax, 59
mov rdi, file
lea rsi, [file]
mov rdx, 0
syscall

它给出段错误

我做错了什么?

我什至尝试将其放入 C 源代码中:

int main(void)
{
char shellcode[] =
"\xb8\x3b\x00\x00\x00"
"\x48\xbf\xd0\x00\x60\x00\x00"
"\x00\x00\x00"
"\x48\x8d\x34\x25\xd0\x00\x60"
"\x00"
"\xba\x00\x00\x00\x00"
"\x0f\x05";

(*(void (*)()) shellcode)();

return 0;
}

这也给我一个段错误...

最佳答案

您通过将字符串 /bin/sh 的地址加载到 rsi 中,导致内核将字符串 /bin/sh 取消引用。

只需将 dxsi 设置为 0 即可传递空环境和参数。

section .text
global _start

_start:
mov rax, 59
mov rdi, file // *filename
mov rsi, 0 // *argv
mov rdx, 0 // *envp
syscall

section .data
file db "/bin/sh",0

关于linux - nasm 程序集 sys_execve/bin/sh,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42741276/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com