Projecto EvilBruteforce

Iniciado por Garfield07, 14 Septiembre 2010, 18:33 PM

0 Miembros y 1 Visitante están viendo este tema.

Garfield07

Buenas, estoy trabajando en un bruteforce de Telnet, llamado Evil Bruteforce. El caso es que para hacerlo primero hice un server telnet, solo que en el port 31337, pues es una prueba. Sin embargo, tengo dos problemillas con el server:
1. Presentación: Este, aunque es un fallo sin importancia, me mosquea. Despues del listening, deberia aparecer un letrerito "
  • Esperando cliente...", pero no sale hasta que alguien se conecta. El segundo fallo tiene mas importancia, pero me gustaria saber pork no va...
    2. Fallos continuos: Si compilan mi server, este va la primera vez. Solo hay que meter la contraseña para que el bruteforce sea sencillo, pero luego lo  perfeccionare xD. Sin embargo, al correr la segunda vez, suelta un fallo en Binding. Estos fallos se producen porque no se tienen privilegios para hacer el binding (puertos bajos), o que el port esta usado. Si el port esta usado es porque: o no cerre bien el port cuando acabe el primer programa, o otro programa lo esta usando (el primero no se ha cerrado y sigue operativo). Para resolver estas dos cuestiones cree una funcion de acabado de programa, y quite el bucle for () infinito. Aun asi, no va.

    Alguien me puede ayudar???
    #include <stdio.h>

    #include <stdlib.h>

    #include <string.h>

    #include <sys/socket.h>

    #include <arpa/inet.h>



    int sockfd, newsock;



    int finalizar (int state)

    {

       printf("[+] Finalizando...");

       close (sockfd);

           close (newsock);

       printf("\t[OK]\n\n");

       exit (1);

    }



    int main ()

    {

    printf ("\n");

    printf ("#*************************************#\n");

    printf ("# -[ EvilBruteforce.0 - by Sagrini ]- #\n");

    printf ("#  ---------------------------------  #\n");

    printf ("#          Telnet Bruteforce          #\n");

    printf ("#*************************************#\n\n\n");


       struct sockaddr_in host, client;

       int a=sizeof (struct sockaddr);

       char pass [30];



       printf("[+] Creando el Socket...");

       if ((sockfd=socket (2, 1, 0))!=-1)

           printf ("[OK]\n");

       else

       {

           printf("[FAIL]\n");

           finalizar (1);

       }

       host.sin_port=htons(31337);

       host.sin_family=AF_INET;

       host.sin_addr.s_addr=0;

       memset (host.sin_zero, 0, 8);



       printf ("[+] Bindeando...");

       if(bind(sockfd,(struct sockaddr*)&host,sizeof(host))==-1)

       {

           printf("\t[FAIL]\n");

           finalizar (1);

       }

       printf ("\t[OK]\n");



       printf ("[+] Listening...");

       if(listen(sockfd,5)==-1)

       {

           printf("\t[FAIL]\n");

           finalizar (1);

       }

       else

           printf("\t[OK]\n");



       printf("[+] Esperando cliente...");

       if((newsock=accept(sockfd, (struct sockaddr*)&client, &a))==-1)

       {

           printf("[FAIL]\n");

           finalizar (1);

       }

       else

           printf("[OK]\n\n");



       printf("[+] Conexion establecida.\n");

       send (newsock, "Password: ", 11, 0);

       recv (newsock, &pass, 30, 0);

       if (strcmp (pass, "strike\n")==1)

       {

           printf (" ==> Access granted\n\n");

           send (newsock, " ==> Access granted.\n\n", 23, 0);

       }

       else

       {

           printf (" ==> Access denied.\n\n");

           send (newsock, " ==> Access denied.\n\n", 22, 0);

       }

       finalizar (0);

    }



    Evidentemente, este code es bastante simple, pero no funciona como deberia. Pueden ayudarme?
    Saludos y muchas gracias.


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo

Jeypestylerz

Hola te recomiendo borrar el server que has creado y hacer uno en el puerto 23
Espero que alguien te ayude, tu programa me parece interesante pero soy wannabe, solo programo archivos por lotes (batch) xD

Jaixon Jax

  pAra la primera, deberia aparecer el letrero a no ser que exista un error al crear socket ...

  La segunda accept debe estar en un Bucle asi despues que alguien se conecta vuelve a espeerar conexion sino despues que acepte la primera conexion sale del main

Garfield07

#3
Jaja les respondo: el server era algo simple, de pruebas... no queria usar el 23 para no estar todo el rato con el sudo xD... y a mi no me aparece el letrero aunque sea correcto.. estoy extrañado. Compilen, y diganme sobre que. Por cierto, en Windows si va el code y sale el letrero, pero en Linux Ubuntu 10.04 no...
Y otra cosa.. ya lo se, es un server de pruebas. Quite el accept para que no hubiese errores al desconectarse: si cerraba el programa dentro de un bucle infinito con los sockets abiertos, podria ser que no se cerrasen bien... por eso quite el bucle. Asi cierro conex. , cierro sockets y return... es una cuestion insignificante...

PD: muchisimas gracias por contestar, veran, este tema ya se estaba llendo y como coincidio con varios mensajes mas, el mio directamente se fue al quinto puesto, y nadie lo miro. Ya casi era un post viejo muchas gracias pues sigo con la duda...

Bueno, añado, use el mismo code para otro programa, y tenia los mismos problemas... las funciones estan mal... en que?


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo