elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Los 10 CVE más críticos (peligrosos) de 2020


+  Foro de elhacker.net
|-+  Programación
| |-+  Programación General
| | |-+  [Tutorial] Programado un viewbot en pascal usando APIS
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] Ir Abajo Respuesta Imprimir
Autor Tema: [Tutorial] Programado un viewbot en pascal usando APIS  (Leído 2,485 veces)
WarZ0n3

Desconectado Desconectado

Mensajes: 22


Ver Perfil
[Tutorial] Programado un viewbot en pascal usando APIS
« en: 3 Agosto 2013, 18:50 pm »

Lo prometido es deuda, hace un tiempo había echo un pequeño Viewbot, y al parecer a la gente le ha gustado, hoy les traigo algunas de las técnicas para programarlo lo más eficiente posible.. claro que lo haremos con las APIS WinInet, Winsock y más...


===============================

0)¿Por que Pascal?.
1)Introducción.
2)Conocimientos previos.
3)Desarrollando con la libreria WinInet.
4)Hablando de “Return” y “Result” en Pascal.
5)Probando nuestro robot por primera vez.
6)Convirtiendo nuestra PC en un servidor web de pruebas.
7)Creando un contador de visitas en PHP y algo más...
8)Hashes mixtos para nuestra maquina.
9)Un vistazo a la programación monolítica.
10)Limpiando variables en memoria(Apartado de optimizacion 1º parte).
11) Probando nuestro viewbot por 2º vez.
12) Usando el API Winsock para obtener Ips.
13)Finalizando.
14) Probando nuestro viewbot por 3º vez!.
15)Usando StripReloc para hacer el ejecutable mas pequeño y su relación con .reloc(Apartado de optimizacion 2º parte).
16)Mirando en LordPe la sección .reloc.
17)Viendo el Stack y el Heap con WinDbg.
18)Despedida.

===============================


0)¿Por que Pascal?:
Porque es un lenguaje muy potente, sin dudarlo a la altura de C++, que lo supera en algunos aspectos y como comentario personal,
se puede decir que en pascal se han programado grandes troyanos y/o herramientas de hacking.
Pascal tanto como C, lamentablemente son tomados por los novatos de la programación como “lenguajes de alto nivel”,
pero esto es completamente falso, ambos son LENGUAJES DE PROPOSITO GENERAL,
esto quiere decir que podemos programar tanto a alto nivel, como a medio nivel, o bajo nivel(asm y mas, incluso se pueden hacer drivers).
Por ejemplo, el FPC compila 10% mas rapido que el GCC,
pueden encontrar mas información acerca de este lenguaje aquí: http://es.wikipedia.org/wiki/Pascal_(lenguaje_de_programaci%C3%B3n)

1)Introduccion:
Antes de comenzar con el tutorial les pido que si deciden distribuir este material,
mencionen al autor por respeto y por que seria(en mi opinión) la forma mas sumisa de darme las gracias si te ha servido,
mi nombre es WarZ0n3 y me puedes encontrar en el los foros de http://foro.elhacker.net o http://www.indetectables.net.

El uso de Wininet no esta muy documentado, no he encontrado demasiada información al respecto,
y es un hecho que gran parte de los códigos que se pueden encontrar en la red fueron hechos como ejemplos,
por lo que realmente pasare a decir que lo aquí explicado, se comentara lo mas posible. Ademas el uso de robots,
spamers publicitario etc.. no es un tema nuevo(aunque nunca vi un tutorial de como programar uno),
por esto se me ocurrió hablar sobre este tema, pero cuando se saben usar APIS como winsock, wininet, etc..
sea en C++ o pascal y usando tu sentido común podrás desarrollar un viewer,
lo suficientemente poderoso y profesional para el mercado.
Pero RECUERDEN que este es un tutorial para aquellos iniciados en el tema de las APIS. Así que basta de rodeos y a empezar.

2)Conocimientos previos:
Si no sabes usar APIS, o eres un iniciado en pascal, no debes preocuparte, ya que este tutorial
se enfoca en las personas que recién empiezan.
No sondeare sobre como desensamblar código para hacer las funciones en asm puro
y se ejecuten mas rápido (esto por si lo ven en códigos futuros míos), tal vez para otro tutorial,
eso puede aprenderse en shellcoding (de hecho así lo aprendí yo).

3)Desarrollando con la librería WinInet:
Wininet es una dll que puedes encontrar en System32 de tu windows, y es la encargada de las funciones de internet.
La importancia de usarla es que, como toda API, se pueden hacer cosas muy profesionales arbitrariamente hablando, también tomar en cuenta la optimización de código, y que siempre es mejor usar apis, en vez de componentes externos o indys. No tengo nada contra de estos, incluso hay veces que debo recurrir a ellos.

Lo primero sera agregarla en USES para poder usarla, y para ello abrimos delphi 7 nos vamos a
file->new->other y elejimos console application.


Ahora crearemos una función la cual se encargara de hacer peticiones a una pagina que nosotros le pasemos como argumento:
Código
  1. // Uses: Requerimientos para usar la librería wininet y otras funciones de las que nos provee pascal
  2. uses
  3.  WinInet,
  4.  Windows,
  5.  SysUtils;
  6.  
  7. // aplicación de tipo consola
  8. {$APPTYPE CONSOLE}
  9.  
  10. // directiva del compilador usada para añadir un símbolo especifico en la cabecera de C++ generada
  11. {$HPPEMIT '#include <wininet.h>'}
  12. // otro ejemplo {$HPPEMIT 'struct myVar'}, obviamente generada desde la cabecera de C++
  13.  
  14. // constantes que usaremos como parámetros en las funciones de wininet
  15. (* recordemos que podemos usar valores hexadecimal para las definiciones, de echo
  16.  muchas se proveen de esta forma (por lo que yo recomiendo mucho esto),
  17. también tengan presente que deben ser 8 dígitos (1 octeto), si no saben hexa usen la calculadora de windows en modo científico.
  18. NOTA RAPIDA: en pascal los valores hexadecimales son definidos con el simbolo $ adelante *)
  19.  
  20. const
  21.  INTERNET_OPEN_TYPE_PRECONFIG        = $00000000; (* Usa la configuracion del registro(por defecto) *)
  22.  {$EXTERNALSYM INTERNET_OPEN_TYPE_PRECONFIG}
  23.  INTERNET_OPEN_TYPE_DIRECT           = $00000001;  (* Acceso directo a la red *)
  24.  {$EXTERNALSYM INTERNET_OPEN_TYPE_DIRECT}
  25.  INTERNET_OPEN_TYPE_PROXY            = $00000003; (* Acceso via proxy *)
  26.  {$EXTERNALSYM INTERNET_OPEN_TYPE_PROXY}
  27. INTERNET_FLAGS_MASK         = INTERNET_FLAG_RELOAD      or
  28.                                INTERNET_FLAG_NO_COOKIES;
  29.  {$EXTERNALSYM INTERNET_FLAGS_MASK}
  30.  ZERO                                = $00000000;
  31.  HTTP                                = 'http://';

 En pascal existen 3 tipos de comentarios:
Código
  1. // comentario 1(inline)
  2. {comentario 2 equivalente a /**/ en c++}
  3. (* comentario 3 equivalente a /**/ en c++ *)

NOTA: No es  lo mismo hacer {} que {$}, cuando hacemos esto {$} en realidad hablamos  de directivas del compilador,
si saben c++ deberían entender a que me refiero. #define ...
Código
  1. // Esta directiva impide a pascal que se sobrecarguen rutinas, ya definidas en los headers de C++
  2. // ejemplo: {$EXTERNALSYM <VARIABLE_O_FUNCIÓN>}
Creando la función:
Código
  1. function
  2. RequestInternet(url:string): BOOL;
  3. var
  4.  hInet,
  5.  hUrl        : hInternet;
  6.  
  7. begin
  8.  hInet:= InternetOpen('USER AGENT: ROBOT', INTERNET_OPEN_TYPE_PRECONFIG, nil, nil, ZERO);
  9.  if assigned(hInet) then
  10.  begin
  11.    hUrl:= InternetOpenUrl(hInet, pChar(HTTP+url), nil, INTERNET_FLAG_NO_COOKIES,
  12.      INTERNET_FLAG_RELOAD,INTERNET_SERVICE_HTTP);
  13.    if assigned(hUrl) then begin
  14.      Result:= true; end
  15.    else begin Result:= false; end;
  16.  end;
  17.  
  18.  InternetCloseHandle(hInet);
  19.  InternetCloseHandle(hUrl);
  20. end;

“if assigned”: esta función chequea si la referencia no es de tipo nula (NIL), si lo es retorna FALSE y si no es nula retorna TRUE
ej: if assigned(Puntero) then begin … <codigo> … end;

Código
  1. hInet:= InternetOpen('USER AGENT: ROBOT', INTERNET_OPEN_TYPE_PRECONFIG, nil, nil, 0);
Básicamente inicializa el uso de las funciones de Wininet.
Pueden encontrar mas información al respecto en : http://msdn.microsoft.com/en-us/library/windows/desktop/aa385096(v=vs.85).aspx

msdn nos dice que los parámetros son:
Código
  1. HINTERNET InternetOpen(
  2.  LPCTSTR lpszAgent, // USER-AGENT del protocolo HTTP (luego lo cambiaremos)
  3.  DWORD dwAccessType, // Tipo de acceso, es este caso el pre-configurado.
  4.  LPCTSTR lpszProxyName, // Usados para proxys
  5.  LPCTSTR lpszProxyBypass,
  6.  DWORD dwFlags
  7. );
Código
  1. hUrl:= InternetOpenUrl(hInet, pChar(HTTP+url), nil, INTERNET_FLAG_NO_COOKIES, INTERNET_FLAG_RELOAD,INTERNET_SERVICE_HTTP);
Usada para el acceso a internet (también puede usarse para el protocolo FTP). Y el HTTP+url,
es el definido en las constantes mas el parámetro de la función.
Los demás parámetros según la msdn:
Código
  1. HINTERNET InternetOpenUrl(
  2.  HINTERNET hInternet, // Handler a OpenInternet(que inicializamos previamente)
  3.  LPCTSTR lpszUrl, // Url pasada como argumento (ej: http://www.youtube.com&#38;#38;#41;
  4.  LPCTSTR lpszHeaders, // tipo de lectura en HTTP, FTP, o HTPPS (son soportados)
  5.  DWORD dwHeadersLength,
  6.  DWORD dwFlags,
  7.  DWORD_PTR dwContext
  8. );
Y nos retorna un NULL si la conexión ha fallado. Otra cosa es que podríamos haber usado InternetConnect,
no entrare en detalles, tal ves para otra entrega y otro tipo de spamer,
pero me limitare a decir que esto puede ser en caso de querer logearnos automáticamente(con autentificación ) a un sitio web,
y seria cuestión de saltarse los captchas, si es que los tiene, por esto solo utilizaremos “openurl”,
ya que solo queremos generar visitas y nada más.
Código
  1. InternetCloseHandle(hInet); InternetCloseHandle(hUrl);
Cierra el/los manejadores de internet... mas información aquí: http://msdn.microsoft.com/en-us/library/windows/desktop/aa384350&#38;#40;v=vs.85&#38;#41;.aspx
(Recordemos siempre liberar memoria, cerrando  handlers correctamente, y variables (mas si son de tipo puntero).

NOTA: Hinternet según wininet.pas son de tipo punteros, así que podríamos haber echo lo mismo de la
siguiente forma:
Código
  1. hInet,
  2.  hUrl        : Pointer;
Si lo hacen así recomiendo usar FreeMemory(hInet), etc...

4)Hablando de return y result en Pascal:
En pascal no hay return como tal, pero alternativamente nos valemos de Result,
el cual se crea (automáticamente) cuando se inicia la función en memoria,
este contiene el resultado de dicha función y puede ser usada a lo largo del programa.
Para este ejemplo se uso un booleano que nos devuelve true si la sesión fue exitosa y false si no lo fue.

Entonces el código hasta el momento nos debe quedar así:
Código
  1. program rweb;
  2.  
  3. uses
  4.  WinInet,
  5.  Windows,
  6.  SysUtils;
  7.  
  8. {$APPTYPE CONSOLE}
  9.  
  10. {$HPPEMIT '#include <wininet.h>'}
  11.  
  12. const
  13.  INTERNET_OPEN_TYPE_PRECONFIG        = $00000000; (* Usa la configuracion del registro(por defecto) *)
  14.  {$EXTERNALSYM INTERNET_OPEN_TYPE_PRECONFIG}
  15.  INTERNET_OPEN_TYPE_DIRECT           = $00000001;  (* Acceso directo a la red *)
  16.  {$EXTERNALSYM INTERNET_OPEN_TYPE_DIRECT}
  17.  INTERNET_OPEN_TYPE_PROXY            = $00000003; (* Acceso via proxy *)
  18.  {$EXTERNALSYM INTERNET_OPEN_TYPE_PROXY}
  19.  INTERNET_FLAGS_MASK         = INTERNET_FLAG_RELOAD      or
  20.                                INTERNET_FLAG_NO_COOKIES;
  21.  {$EXTERNALSYM INTERNET_FLAGS_MASK}
  22.  ZERO                                = $00000000;
  23.  HTTP                                = 'http://';
  24.  
  25. function
  26. RequestInternet(url:string): BOOL;
  27. var
  28.  hInet,
  29.  hUrl        : hInternet;
  30.  
  31. begin
  32.  hInet:= InternetOpen('USER AGENT: ROBOT', INTERNET_OPEN_TYPE_PRECONFIG, nil, nil, ZERO);
  33.  if assigned(hInet) then
  34.  begin
  35.    hUrl:= InternetOpenUrl(hInet, pChar(HTTP+url), nil, INTERNET_FLAG_NO_COOKIES,
  36.      INTERNET_FLAG_RELOAD,INTERNET_SERVICE_HTTP);
  37.    if assigned(hUrl) then begin
  38.      Result:= true; end
  39.    else begin Result:= false; end;
  40.  end;
  41.  
  42.  InternetCloseHandle(hInet);
  43.  InternetCloseHandle(hUrl);
  44. end;
  45.  
  46. // inicializamos el programa con la funcion
  47. begin
  48. if RequestInternet( string(ParamStr(1)) ) then
  49.  begin
  50.    writeLn('Sesion exitosa'); end
  51.  else begin
  52.    writeLn('Ha surgido un problema en la conexion...'); end;
  53. end.

Dentro de begin y end. (no end;), se inicia el programa, y el end. (con punto) remarca la finalización del código.
ParamStr(1) es el argumentos de la aplicación (el que le pasaremos como parámetro cuando la ejecutemos).
Osease rweb 'pagina a visitar'.

5)Probando nuestro robot por primera vez:
Simple y eficaz, luego agregaremos más características, como user agents hasheados en una variable random,
que dará como resultado user-agents falsos, pero por ahora el código esta bien y es necesario  probarlo antes de continuar.

Entonces naveguemos hasta el directorio de nuestro projecto y hagan lo que se muestra en la imagen (yo copie mi rweb.exe en C:/ )



Como vemos en el primer ejemplo “rweb localhost”(por si no ves la imagen),
nos indica que la sesión fue exitosa (ya que tengo xampp corriendo).


Y en el segundo ejemplo vemos “ha surgido un problema en la conexión” ya que visitamos una web no existente,
el http:// adelante no lo agregamos por que en nuestro código previo ya lo habíamos hecho.

6) Convirtiendo nuestra PC en un servidor web de pruebas:
Si no sabes que es xampp, wampp, etc.. te recomiendo que te pases por aca: http://es.wikipedia.org/wiki/XAMPP
no entraremos en este tema, por que es irrelevante, ya que este es un tutorial sobre desarrollo de viewbots,
pero básicamente esto convierte tu maquina en un servidor web (y es necesario para hacer las pruebas locales),
lo puedes descargar de acá: http://www.apachefriends.org/es/xampp.html y para instalarlo
te dejo esta guía: http://vagabundia.blogspot.com/2012/07/como-instalar-xampp-en-windows.html
Eso sera suficiente para entrar en “localhost” o lo que es lo mismo “127.0.0.1” .

7)Creando un contador de visitas en PHP y algo más... :
En el ejemplo anterior vimos que nuestro pequeño bot funciona, y hasta nos avisa que la sesión fue exitosa,
¿pero realmente como sabemos que así fue?, y mas importante aun, como podemos tener un control de ello,
antes de adelantarnos a agregar mas en nuestro código haremos un simple contador de visitas en PHP
y ademas haremos que nos diga nuestra IP y USER-AGENT(navegador), también lo guardaremos en un archivo .txt .

NOTA RAPIDA: en Xampp la carpeta para entrar al index y agregar nuestra pagina es
C:/xampp/htdocs en otros servicios es probable encontrar la carpeta en /www .

Código en PHP (crea un archivo con la extensión .php que se llame contador y guardala en htdocs):

Código
  1. <?php
  2. // Encargada de capturar la ip (o ip remota en el caso de que sea en la web).
  3. $ip=$_SERVER['REMOTE_ADDR'];
  4. // Captura el navegador.
  5. $user_agent=$_SERVER['HTTP_USER_AGENT'];
  6. echo "Tu ip real es: ".$ip;
  7. echo "<br>Y tu navegador es: ".$user_agent;
  8.  
  9. // Archivo en donde se acumulará el numero de visitas
  10. $contador = "contador.txt";
  11. // Archivo en donde se guardara tu ip y navegador.
  12. $info  = "ips.txt";
  13.  
  14. // Abrimos el archivo para solamente leerlo (r de read)
  15. $abre_visitas = fopen($contador, "r");
  16. // Leemos el contenido del archivo
  17. $total = fread($abre_visitas, filesize($contador));
  18. // Cerramos el archivo
  19. fclose($abre_visitas);
  20.  
  21. // Abrimos nuevamente el archivo
  22. $abre_visitas = fopen($contador, "w");
  23. // Sumamos 1 nueva visita
  24. $total = $total + 1;
  25.  
  26. // Y reemplazamos por la nueva cantidad de visitas
  27. $grabar_visitas = fwrite($abre_visitas, $total);
  28. // Cerramos la conexión al archivo
  29. fclose($abre_visitas);
  30.  
  31. // Imprimimos el total de visitas dándole un formato
  32. echo "<br><br><i>Total de visitas: ".$total;
  33. // abrimos el segundo archivo donde ira la ip y navegador.
  34. $abre_datos= fopen($info, "a+");
  35. // lo escribimos (PHP_EOL es un salto de linea).
  36. $grabar_datos = fwrite($abre_datos, PHP_EOL ."Tu ip es: ".$ip.PHP_EOL ."Tu navegador es: ".$user_agent);
  37. fclose($abre_datos);
  38. ?>

Como vemos el código es bastante básico, pero la idea no es mala y con esto bastara para saber
el navegador con el que se loguea nuestro bot y cuantas veces lo hace.

Haremos otra visita, pero esta ves al “contador.php”


En la imagen podemos observar el total de visitas, 5 que hice comúnmente, y la numero 6 del bot,
vamos a la carpeta xampp/htdocs y veamos los ficheros formados y que contienen.

Muy bien, tenemos “contador.txt” con el numero 6, y “ips.txt” con los navegadores visitados y la ip,
en la imagen podemos observar que el ultimo (el remarcado con azul) dice:
Tu navegador es: USER-AGENT: ROBOT
Exelente! Esto quiere decir que nuestro pequeño bot dio resultado. ¿Recuerdan esto?:
Código
  1. hInet:= InternetOpen('USER AGENT: ROBOT', INTERNET_OPEN_TYPE_PRECONFIG, nil, nil, ZERO);

Pues hay lo tienen!.

8)Hashes mixtos para nuestra maquina:
Nuestro próximo objetivo es hacer hashes que se generen automáticamente, y con una llamado de “Ramdom” se creen al azar,
crearemos una nueva función llamada RandomHashes arriba de RequestInternet, entonces nuestro código sera el siguiente:
Código
  1. const:
  2. BUFFSIZE                            = $00000041;  // 65d
  3. function
  4.  RandomHashes(LenDict:integer):string;
  5. const
  6.  BuffHash    : Array[0..BUFFSIZE] of Char= (
  7.    'a', 'b', 'c', 'd', 'e', 'f', 'g',
  8.    'h', 'i', 'j', 'k', 'l', 'm', 'n',
  9.    'o', 'p', 'q', 'r', 's', 't', 'u',
  10.    'u', 'v', 'w', 'x', 'y', 'z', 'A',
  11.    'B', 'C', 'D', 'E', 'F', 'G', 'H',
  12.    'I', 'J', 'K', 'L', 'M', 'N', 'O',
  13.    'P', 'Q', 'R', 'S', 'T', 'U', 'V',
  14.    'W', 'X', 'Y', 'Z', '0', '1', '2',
  15.    '3', '4', '5', '6', '7', '8', '9',
  16.    '=', '?', '-'
  17.  );

Creamos 2 constantes, la primera llamada BUFFSIZE fuera de la función, que tendrá la longitud de nuestro diccionario ,
y la segunda constante(dentro de la función) tendrá nuestro diccionario de letras que se generaran al azar.
NOTA: $00000041(hex) en decimal es 65, osea que nuestro diccionario tiene 66 de longitud real (por que el array se inicializa
en zero y también es contado como lugar).

Ahora lo que haremos sera generar el hash, y lo imprimiremos en pantalla,
esto es para asegurarnos de que la función esta haciendo su trabajo correctamente.
Código
  1. var
  2.  iHash         : Integer;
  3.  PBuffHash     : Char;
  4. repeat
  5.  iHash:= Length(BuffHash)-LenDict;
  6.  repeat
  7.    Randomize;
  8.    PBuffHash:= BuffHash[Random(Length(BuffHash))];
  9.    asm
  10.      @@StartUp:
  11.        DEC(iHash);
  12.    end;
  13.    Result:= Result+PBuffHash;
  14.  until (iHash<ZERO);
  15.  Result:= Result;
  16.  
  17.  ZeroMemory(Addr(iHash), SizeOf(iHash));
  18.  ZeroMemory(Addr(PBuffHash), SizeOf(PBuffHash));

Tranquilos que esto es muy fácil, solo hay que desmenuzar el código y analizarlo con tranquilidad.
Código
  1. iHash: sera la longitud de la variable “BuffHash” que como vimos anteriormente es la que contiene nuestro diccionario.
Código
  1. PbuffHash: Sera de tipo Char y contendrá como dato nustro hash.
Código
  1. Randomize: es un procedimiento(procedure), NO! una función.
y básicamente genera números al azar en conjunción con la función Ramdom, que ya veremos.
Código
  1. PBuffHash:= BuffHash[Random(Length(BuffHash))];
Acá lo que estamos haciendo es decirle a PbuffHash, que almacene nuestro diccionario,
que es de tipo char(por esto te comentaba que ambas variables deben ser de tipo Char).
Código
  1. Random();
es una función que genera números al azar y
Código
  1. length(BuffHash);
repito de nuevo, sera la longitud de nuestro diccionario en la que se generara el hash.
Código
  1. asm
  2.      @@StartUp:
  3.        DEC(iHash);
  4. end;
Recordemos que siempre el código en ensamblador se ejecuta mas rápido, y así de alguna manera estamos pre-optimizando nuestro código.

9)Un vistazo a la programación monolítica:
Aquellos que sean programadores de la vieja escuela sabrán que antes no existía la programación estructurada como tal,
por lo que se hacía con labels, o etiquetas, por esto usar gotos es una mala manera de programar aun que en algunos casos
no queda remedio...
Código
  1. @@Startup: Sera nuestra etiqueta de comienzo algo así como una referencia en el código,
  2. y DEC lo que hace es decrementar en 1 la variable pasada como argumento, mas adelante explicare por que.

Código
  1. Repeat y until (iHash<ZERO);
Repite nuestro código(generando char por char en PbuffHash) hasta que se cumpla una condición,
por ejemplo lo que vimos anteriormente es que estamos decrementando
iHash(contenedor de la longitud de nuestro diccionario) en 1,
osea que nuestro until se dejara de ejecutar cuando este llegue a zero, y la variable que le pase “ZERO” es la constante definida anteriormente.
Código
  1. Result:= Result+PBuffHash;
¿Recuerdan lo de los Results que les había explicado?, pues es tiempo de darles uso,
y aquí lo que hacemos es sumar el valor en cada repetición, en este caso  “PbuffHash” el cual es nuestro hash generandose.
Ahora le decimos a que sea igual al resultado ya generado, osease Result:= Result;

10)Limpiando variables en memoria:
Código
  1. ZeroMemory(Addr(iHash), SizeOf(iHash));
Esta función es el equivalente a FillChar y es muy útil para limpiar una variable en memoria(también para incializarla en $00000000),
en realidad si hubiera inicializado otro tipo de array (ya sea de punteros especialmente),
haría algo como
Código
  1. ZeroMemory(HandlerArrayOPuntero, SizeOf(HandlerArrayOPuntero))
pero lo del Addr,  es para limpiar fuera de la memoria nuestra variable, ademas es Addr quien contiene la dirección.

Y para terminar la explicación, nuestra función recibe un parámetro “LenDict” de tipo integro,
esta será la longitud total que queremos que tenga nuestro diccionario,
habíamos dicho que 66 en decimal, pero la verdad que es un valor MUY largo para nuestro bot,
entonces lo restaremos en nuestra función prorroga.

Probemos la funcion (en begin comente lo anterior hecho para la pruebita):
Código
  1. begin
  2. (*
  3.   if RequestInternet( string(ParamStr(1)), 40) then
  4.   begin
  5.     writeLn(#13#10+'Sesion exitosa'); end
  6.   else begin
  7.     writeLn(#13#10+'Ha surgido un problema en la conexion...'); end;
  8. *)
  9.  
  10.  WriteLn('Hash formado: ', RandomHashes(45));
  11.  Sleep($500);
  12. end.

Pueden observar que le pasamos el número 45 osea 66-45=21, pero la longitud total es 22 por que inicializamos el array en 0.

Y ahora es tiempo de tocar RequestInternet, es tan facil como agregar nuestra nueva función:
Código
  1. function
  2. RequestInternet(url:string; Hashes: integer): BOOL;
  3. var
  4.  hInet,
  5.  hUrl        : hInternet;
  6.  NHash       : Pchar; // Creamos otra variable
  7. begin
  8.  NHash:= Pchar(RandomHashes(Hashes)); // Llamamos nuestra función generadora de hashes
  9.  hInet:= InternetOpen(NHash, INTERNET_OPEN_TYPE_PRECONFIG, nil, nil, ZERO);
  10.  if assigned(hInet) then
  11.  begin
  12.    hUrl:= InternetOpenUrl(hInet, pChar(HTTP+url), nil, INTERNET_FLAG_NO_COOKIES,
  13.      INTERNET_FLAG_RELOAD,INTERNET_SERVICE_HTTP);
  14.    if assigned(hUrl) then begin
  15.      Result:= true;
  16.      WriteLn('Hash generado: '+NHash); end // mostramos el hash generado.
  17.    else begin Result:= false; end;
  18.  end;
  19.  
  20.  InternetCloseHandle(hInet);
  21.  InternetCloseHandle(hUrl);
  22.  FreeMemory(NHash); // liberamos nuestra variable de tipo puntero.
  23. End;
Código
  1. NHash:= Pchar(RandomHashes(Hashes));
Entonces Nhash contendrá nuestro hash generado en la longitud de 22 y lo pondremos en InternetOpen para que cambie nuestro USER-AGENT,
terminemos el código(por ahora).
Entonces si todo va bien te debería quedar de la siguiente manera:
Código
  1. program rweb;
  2.  
  3. uses
  4.  WinInet,
  5.  Windows,
  6.  SysUtils;
  7.  
  8. {$APPTYPE CONSOLE}
  9.  
  10. {$HPPEMIT '#include <wininet.h>'}
  11.  
  12. const
  13.  INTERNET_OPEN_TYPE_PRECONFIG        = $00000000; (* Usa la configuracion del registro(por defecto) *)
  14.  {$EXTERNALSYM INTERNET_OPEN_TYPE_PRECONFIG}
  15.  INTERNET_OPEN_TYPE_DIRECT           = $00000001;  (* Acceso directo a la red *)
  16.  {$EXTERNALSYM INTERNET_OPEN_TYPE_DIRECT}
  17.  INTERNET_OPEN_TYPE_PROXY            = $00000003; (* Acceso via proxy *)
  18.  {$EXTERNALSYM INTERNET_OPEN_TYPE_PROXY}
  19.  INTERNET_FLAGS_MASK                 = INTERNET_FLAG_RELOAD      or
  20.                                        INTERNET_FLAG_NO_COOKIES;
  21.  {$EXTERNALSYM INTERNET_FLAGS_MASK}
  22.  
  23.  ZERO                                = $00000000;
  24.  BUFFSIZE                            = $00000041;  // 66d
  25.  HTTP                                = 'http://';
  26.  
  27. function
  28.  RandomHashes(LenDict:integer):string;
  29. const
  30.  BuffHash    : Array[0..BUFFSIZE] of Char= (
  31.    'a', 'b', 'c', 'd', 'e', 'f', 'g',
  32.    'h', 'i', 'j', 'k', 'l', 'm', 'n',
  33.    'o', 'p', 'q', 'r', 's', 't', 'u',
  34.    'u', 'v', 'w', 'x', 'y', 'z', 'A',
  35.    'B', 'C', 'D', 'E', 'F', 'G', 'H',
  36.    'I', 'J', 'K', 'L', 'M', 'N', 'O',
  37.    'P', 'Q', 'R', 'S', 'T', 'U', 'V',
  38.    'W', 'X', 'Y', 'Z', '0', '1', '2',
  39.    '3', '4', '5', '6', '7', '8', '9',
  40.    '=', '?', '-'
  41.  );
  42. var
  43.  iHash         : Integer;
  44.  PBuffHash     : Char;
  45. begin
  46.  iHash:= Length(BuffHash)-LenDict;
  47.  repeat
  48.    Randomize;
  49.    PBuffHash:= BuffHash[Random(Length(BuffHash))];
  50.    asm
  51.      @@StartUp:
  52.        DEC(iHash);
  53.    end;
  54.    Result:= Result+PBuffHash;
  55.  until (iHash<ZERO);
  56.  Result:= Result;
  57.  
  58.  ZeroMemory(Addr(iHash), SizeOf(iHash));
  59.  ZeroMemory(Addr(PBuffHash), SizeOf(PBuffHash));
  60. end;
  61.  
  62. function
  63. RequestInternet(url:string; Hashes: integer): BOOL;
  64. var
  65.  hInet,
  66.  hUrl        : hInternet;
  67.  NHash       : PChar;
  68. begin
  69.  NHash:= PChar(RandomHashes(Hashes));
  70.  hInet:= InternetOpen(NHash, INTERNET_OPEN_TYPE_PRECONFIG, nil, nil, ZERO);
  71.  if assigned(hInet) then
  72.  begin
  73.    hUrl:= InternetOpenUrl(hInet, pChar(HTTP+url), nil, INTERNET_FLAG_NO_COOKIES,
  74.      INTERNET_FLAG_RELOAD,INTERNET_SERVICE_HTTP);
  75.    if assigned(hUrl) then begin
  76.      Result:= true;
  77.      WriteLn('Hash generado: '+NHash); end
  78.    else begin Result:= false; end;
  79.  end;
  80.  
  81.  InternetCloseHandle(hInet);
  82.  InternetCloseHandle(hUrl);
  83.  FreeMemory(NHash);
  84. end;
  85.  
  86. begin
  87.  if RequestInternet( string(ParamStr(1)), 40) then
  88.  begin
  89.    writeLn(#13#10+'Sesion exitosa'); end
  90.  else begin
  91.    writeLn(#13#10+'Ha surgido un problema en la conexion...'); end;
  92.  Sleep($500);
  93. end.
Y listo!, hora de probar nuestro robot:

11) Probando nuestro viewbot por 2º vez:
Parámetro : rweb localhost/contador.php


¿Que tal he? Va tomando color.
Vamos a automatizarlo para que mientras visite nuestro sitio deseado, nosotros no tengamos que hacer nadas mas que
esperar viéndonos un capitulo de los simpson mientras comemos helado.

Agregamos los siguiente:
Código
  1. /en const:
  2. F5KEY                               = $00000074;  // 116decimal = F5
  3. var
  4.  Init        : BOOL = True;
  5.  
  6. begin
  7.  while Init do begin
  8.    WriteLn('Apreta (F5) para salir de Rbot. ');
  9.    if RequestInternet( string(ParamStr(1)), 40) then
  10.    begin
  11.      writeLn(#13#10+'Sesion exitosa!'); end
  12.    else begin
  13.      writeLn(#13#10+'Ha surgido un problema en la conexion...'); end;
  14.  
  15.    if GetasyncKeyState(F5KEY)<>ZERO then begin
  16.      Init:= false;
  17.      WriteLn(#13#10+'Opcion salida por el usuario.');
  18.    end;
  19.  end;
  20.  
  21.  Sleep($500);
  22. end.
Aun mas fácil!, en constante definimos “F5KEY” el cual es un valor hexa de 74 osea traducido en decimal 116 que es la tecla F5
var Init : BOOL = True, lo dejaremos para mas adelante, ya que esto inicializar el loop en true.
Código
  1. while Init do begin: el bucle while permanecerá repitiéndose mientras sea True de otro modo se rompe y salimos de la aplicación .
Código
  1. if GetasyncKeyState(F5KEY)<>ZERO then begin  Init:= false; ...
GetasyncKeyState es un función de windows, el cual nos permitirá registrar lo que escribamos,
es muy intuitiva y fácil(también usada para keyloggers, aunque nada como hooks).
Como parámetro recibe la tecla presionada, osease F5 que es la que usaremos para salir, y <>
ZERO nos dice que mientras sea distinto a zero no igualara Init a False lo que pondrá fin a nuestro bucle.

El parámetro según la msdn:
Código
  1. SHORT WINAPI GetAsyncKeyState(
  2.  int vKey
  3. );
para mas información consultalo aquí: http://msdn.microsoft.com/en-us/library/windows/desktop/ms646293(v=vs.85).aspx

12) Usando el API Winsock para obtener IPs:
Bueno este paso es opcional, pero lo recomiendo mucho, ya que ayudara a entender(un poco) la librería WinSock,
tal ves mas adelante(en otro tuto), hablaremos de ello y enseñare a como usarla, incluso si se quiere programar un troyano,
yo por mi parte la aprendía a usar con este objetivo, y hace poco había echo un troyano con tal funciones,
aun que le queda mucho por optimizar, pero ya, dejemos lo ahí...
Crearemos otra función llamada GetIp, la cual nos dirá la IP del servidor pasado como paramentro,
Entonces el código es el siguiente (vamos que queda poquísimo y es fácil):
Código
  1. const:
  2. INADDRSIZE                          = $0000000A;
  3. var:
  4.  IRobot         : Integer = 0;
  5.  WSData      : WsaData;
  6. function
  7.  GetIP(): PChar;
  8. type
  9.  aIn_addr      = array [0..INADDRSIZE] of pInAddr;
  10.  pIn_addr      = ^aIn_addr;
  11. var
  12.  Hostent     : PHostEnt;
  13.  HostAddr    : pIn_addr;
  14. begin
  15.  WSAStartup($1, WSData);
  16.  Hostent:= GetHostBYName( PChar(ParamStr(1)) );
  17.  HostAddr:= pIn_addr(Hostent^.h_addr_list);
  18.  Result:= inet_ntoa(HostAddr^[ZERO]^);
  19.  
  20.  FreeMemory(HostAddr);
  21.  WSACleanUp;
  22. end;
Código
  1. const: INADDRSIZE = $0000000A;
Acuérdense, esto va en constantes(fuera de la función),
y el valor es el que tendrá nuestro Array “A” en hexa es el equivalente a 10 en decimal.
Código
  1. aIn_addr = array [0..INADDRSIZE] of pInAddr;
Esto va en constantes(dentro de la función), pInAddr es un puntero de ^TinAddr que ha su vez termina en “in_addr”
Código
  1. pIn_addr      = ^aIn_addr;
Puntero a “aIn_addr” nuestro array.
Código
  1. Hostent : PhostEnt;
Es el “result”(recuerde que explique esto anteriormente) de la función “gethostbyname” por
medio de stdcall.
Código
  1. HostAddr : pIn_addr;
Puntero a “pIn_addr” que a su vez es un puntero de “aIn_addr” que contiene otro array de punteros
(puede sonar confuso..)
Código
  1. WSData : WsaData; y WSAStartup($1, WSData);
Para ello nos vamos a la bendita msdn, los parámetros son los siguientes:
Código
  1. int WSAStartup(
  2.  WORD wVersionRequested, // Versión de sockets que se usaran
  3.  LPWSADATA lpWSAData // Puntero a WsaData el que definimos en las variables
  4. );
Mas información puede encontrarse aquí: http://msdn.microsoft.com/en-us/library/windows/desktop/ms742213(v=vs.85).aspx
Código
  1. Hostent:= GetHostByName( PChar(ParamStr(1)) );
Ya había mencionado que PhostEnt era el resultado de esta función, así
que obviamente al definirla la usaremos, (paramstr 1 es el sitio web que
visitemos ej:www.youtube.com)
Código
  1. HostAddr:= pIn_addr(Hostent^.h_addr_list);
Y no podía faltar el puntero de puntero de punteros...
Ejemplo:
Código
  1. function GetHostByName(name: PChar): PHostEnt; stdcall;
Para entender esta función debemos recurrir de nuevo a la msdn, luego daré un ejemplo
Entonces los parámetros son los siguientes:
Código
  1. struct hostent* FAR gethostbyname(
  2.  const char *name // Puntero al nombre del host a traducir a IP
  3. );
Código
  1. h_addr_list;
lista de direcciones IP para el servidor pasado como parametro.
Mas info en: http://msdn.microsoft.com/en-us/library/windows/desktop/ms738524(v=vs.85).aspx

Si quieren saber mas sobre gethostbyname y gethostbyaddr: http://beej.us/guide/bgnet/output/html/multipage/gethostbynameman.html

Por ahora no es necesario que lo comprendan un 100%, pero seria bueno, ahora lo que sigue es:
Código
  1. Result:= inet_ntoa(HostAddr^[ZERO]^);
Otra vez por la msdn: http://msdn.microsoft.com/en-us/library/windows/desktop/ms738564(v=vs.85).aspx

De todos modos lo explicare, esta función convierte una dirección de red de tipo Ipv4 en un ASCII
Ejemplo:
Código
  1. char* FAR inet_ntoa(
  2.  struct   in_addr in // Representa un dirección de internet
  3. );

Y como no un record. Aquí lo pondré mas claro, nada como un ejemplo(de Winsock.pas):
Código
  1. PInAddr = ^TInAddr;
  2.  {$EXTERNALSYM in_addr}
  3.  in_addr = record
  4.    case integer of
  5.      0: (S_un_b: SunB);
  6.      1: (S_un_w: SunW);
  7.      2: (S_addr: u_long);
  8.  end;
  9.  TInAddr = in_addr; // Puntero a in_addr.
  10.  
  11. FreeMemory(HostAddr); // Libera el array de punteros
  12. WSACleanUp; // Limpia el socket.

13)Finalizando:
Y para finalizar nuestra primer entrega(y espero que no sea la ultima), eso sí, si a la gente le gusta.
Haremos un pequeño timer para que el tiempo en visitar una pagina no sea demasiado grande,
recordemos que el bucle while se genera muy rapido,
y con tan solo decirles que ejecutado así nada mas en menos de 30 segundos hice casi 100 visitas a mi pagina y esto
puede ser realmente muy molesto (y obvio), por esto ademas veremos cuantas visitas hacemos en un rango de X segundos:

Agregaremos lo siguiente al begin principal:
Código
  1. agrega en constantes
  2. HASHKEY                             = $00000028; // 40 decimal
  3. begin
  4.  WriteLn('Apreta (F5) para salir de Rbot. ');
  5.  while Init do begin
  6.    if RequestInternet( string(ParamStr(1)), HASHKEY, StrToInt(ParamStr(2))) then
  7.    begin
  8.      asm
  9.        @@StartUp:
  10.          Inc(IRobot)
  11.      end;
  12.      writeLn(
  13.        '[Servidor visitado]: ', ParamStr(1),
  14.        #13#10+'[Ip]: ', PChar(GetIP()), #13#10+'[Numero de veces]: ', IRobot,
  15.        #13#10+'Sesion exitosa!'+#13#10
  16.        +'============================'
  17.      );
  18.    end
  19.    else begin
  20.      writeLn(#13#10+'Ha surgido un problema en la conexion...'); end;
  21.  
  22.    if GetasyncKeyState(F5KEY)<>ZERO then begin
  23.      Init:= false;
  24.      WriteLn(#13#10+'Opcion salida por el usuario.');
  25.    end;
  26.  end;
  27.  ZeroMemory(Addr(IRobot), sizeof(IRobot));
  28. end.

Bien, HASHKEY es 40 en decimal, que sera la longitud del hash que restaremos(con 66 el total de nuestro diccionario en la función RandomHashes),
y Como 3º parámetro recibirá los segundos que tardara en hacer la repetición,  por ultimo retocaremos la función  RequestInternet.
Código
  1. function
  2. RequestInternet(url:string; Hashes, Secs: integer): BOOL; // Secs: segundos pasados
  3. var
  4.  hInet,
  5.  hUrl        : hInternet;
  6.  NHash       : PChar;
  7. begin
  8.  NHash:= PChar(RandomHashes(Hashes));
  9.  hInet:= InternetOpen(NHash, INTERNET_OPEN_TYPE_PRECONFIG, nil, nil, ZERO);
  10.  if assigned(hInet) then
  11.  begin
  12.    hUrl:= InternetOpenUrl(hInet, pChar(HTTP+url), nil, INTERNET_FLAG_NO_COOKIES,
  13.      INTERNET_FLAG_RELOAD,INTERNET_SERVICE_HTTP);
  14.    if assigned(hUrl) then begin
  15.      Result:= true;
  16.      WriteLn('Hash generado: '+NHash); end
  17.    else begin Result:= false; end;
  18.  end;
  19.  Sleep(Secs*1000); // Delay del tiempo en hacer la repetición
  20.  InternetCloseHandle(hInet);
  21.  InternetCloseHandle(hUrl);
  22.  FreeMemory(NHash);
  23. end;

TERMINAMOS!!! Entonces el código final te debería quedar así..
Código
  1. program rweb;
  2. uses
  3.  WinInet,
  4.  WinSock,
  5.  Windows,
  6.  SysUtils;
  7.  
  8. {$APPTYPE CONSOLE}
  9.  
  10. {$HPPEMIT '#include <wininet.h>'}
  11.  
  12. const
  13.  INTERNET_OPEN_TYPE_PRECONFIG        = $00000000; (* Usa la configuracion del registro(por defecto) *)
  14.  {$EXTERNALSYM INTERNET_OPEN_TYPE_PRECONFIG}
  15.  INTERNET_OPEN_TYPE_DIRECT           = $00000001;  (* Acceso directo a la red *)
  16.  {$EXTERNALSYM INTERNET_OPEN_TYPE_DIRECT}
  17.  INTERNET_OPEN_TYPE_PROXY            = $00000003; (* Acceso via proxy *)
  18.  {$EXTERNALSYM INTERNET_OPEN_TYPE_PROXY}
  19.  INTERNET_FLAGS_MASK                 = INTERNET_FLAG_RELOAD      or
  20.                                        INTERNET_FLAG_NO_COOKIES;
  21.  {$EXTERNALSYM INTERNET_FLAGS_MASK}
  22.  
  23.  ZERO                                = $00000000;
  24.  BUFFSIZE                            = $00000041; // 65d
  25.  F5KEY                               = $00000074; // 116d (F5)
  26.  HASHKEY                             = $00000028; // 40d
  27.  INADDRSIZE                          = $0000000A; // 10d
  28.  
  29.  HTTP                                = 'http://';
  30.  
  31. var
  32.  Init        : BOOL    = True;
  33.  IRobot      : Integer = 0;
  34.  WSData      : WsaData;
  35.  
  36. function
  37.  RandomHashes(LenDict:integer):string;
  38. const
  39.  BuffHash    : Array[0..BUFFSIZE] of Char= (
  40.    'a', 'b', 'c', 'd', 'e', 'f', 'g',
  41.    'h', 'i', 'j', 'k', 'l', 'm', 'n',
  42.    'o', 'p', 'q', 'r', 's', 't', 'u',
  43.    'u', 'v', 'w', 'x', 'y', 'z', 'A',
  44.    'B', 'C', 'D', 'E', 'F', 'G', 'H',
  45.    'I', 'J', 'K', 'L', 'M', 'N', 'O',
  46.    'P', 'Q', 'R', 'S', 'T', 'U', 'V',
  47.    'W', 'X', 'Y', 'Z', '0', '1', '2',
  48.    '3', '4', '5', '6', '7', '8', '9',
  49.    '=', '?', '-'
  50.  );
  51. var
  52.  iHash         : Integer;
  53.  PBuffHash     : Char;
  54. begin
  55.  iHash:= Length(BuffHash)-LenDict;
  56.  repeat
  57.    Randomize;
  58.    PBuffHash:= BuffHash[Random(Length(BuffHash))];
  59.    asm
  60.      @@StartUp:
  61.        DEC(iHash);
  62.    end;
  63.    Result:= Result+PBuffHash;
  64.  until (iHash<ZERO);
  65.  Result:= Result;
  66.  
  67.  ZeroMemory(Addr(iHash), SizeOf(iHash));
  68.  ZeroMemory(Addr(PBuffHash), SizeOf(PBuffHash));
  69. end;
  70.  
  71. function
  72. RequestInternet(url:string; Hashes, Secs: integer): BOOL;
  73. var
  74.  hInet,
  75.  hUrl        : hInternet;
  76.  NHash       : PChar;
  77. begin
  78.  NHash:= PChar(RandomHashes(Hashes));
  79.  hInet:= InternetOpen(NHash, INTERNET_OPEN_TYPE_PRECONFIG, nil, nil, ZERO);
  80.  if assigned(hInet) then
  81.  begin
  82.    hUrl:= InternetOpenUrl(hInet, pChar(HTTP+url), nil, INTERNET_FLAG_NO_COOKIES,
  83.      INTERNET_FLAG_RELOAD,INTERNET_SERVICE_HTTP);
  84.    if assigned(hUrl) then begin
  85.      Result:= true;
  86.      WriteLn('Hash generado: '+NHash); end
  87.    else begin Result:= false; end;
  88.  end;
  89.  Sleep(Secs*1000);
  90.  InternetCloseHandle(hInet);
  91.  InternetCloseHandle(hUrl);
  92.  FreeMemory(NHash);
  93. end;
  94.  
  95. function
  96.  GetIP(): PChar;
  97. type
  98.  aIn_addr      = array [0..INADDRSIZE] of pInAddr;
  99.  pIn_addr      = ^aIn_addr;
  100. var
  101.  Hostent     : PHostEnt;
  102.  HostAddr    : pIn_addr;
  103. begin
  104.  WSAStartup($1, WSData);
  105.  Hostent:= GetHostBYName( PChar(ParamStr(1)) );
  106.  HostAddr:= pIn_addr(Hostent^.h_addr_list);
  107.  Result:= inet_ntoa(HostAddr^[ZERO]^);
  108.  
  109.  FreeMemory(HostAddr);
  110.  WSACleanUp;
  111. end;
  112.  
  113. begin
  114. {$O+} // Directiva para optimización
  115.  WriteLn('Apreta (F5) para salir de Rweb. ');
  116.  while Init do begin
  117.    if RequestInternet( string(ParamStr(1)), HASHKEY, StrToInt(ParamStr(2))) then
  118.    begin
  119.      asm
  120.        @@StartUp:
  121.          Inc(IRobot)
  122.      end;
  123.      writeLn(
  124.        '[Servidor visitado]: ', ParamStr(1),
  125.        #13#10+'[Ip]: ', PChar(GetIP()), #13#10+'[Numero de veces]: ', IRobot,
  126.        #13#10+'Sesion exitosa!'+#13#10
  127.        +'============================'
  128.      );
  129.    end
  130.    else begin
  131.      writeLn(#13#10+'Ha surgido un problema en la conexion...'); end;
  132.  
  133.    if GetasyncKeyState(F5KEY)<>ZERO then begin
  134.      Init:= false;
  135.      WriteLn(#13#10+'Opcion salida por el usuario.');
  136.    end;
  137.  end;
  138.  ZeroMemory(Addr(IRobot), sizeof(IRobot));
  139. {$0-}
  140. end.

14)Probando nuestro viewbot por 3º vez!:
Hora de probarlo!!!.

Y como ven los argumentos usados son:  <sitio_web> <intervalo en tiempo>
Nota: Para aumentar un vídeo en especifico debes usar la url del sitio mas el enlancé,
Ej: http://www.youtube.com/mi_video_a_aumentar

Claro, youtube cuenta una vez por IP, como algunos sitios pero a no preocuparse que en la próxima entrega veremos
como soluciónar ese problema, y lo mismo de siempre, si comentan y les gusta, si no, no hay problema...

15)Usando StripReloc para hacer el ejecutable mas pequeño y su relación con .reloc:
StripReloc se encarga de eliminar una parte de la sección que windows agrega por defecto a los PE(Portable ejecutable) “.reloc”,
(no toda), sino aquella que los compiladores como delphi 7 agregan y
son inútiles, de esta manera reduce el ejecutable moderadamente.
puedes encontrar mas documentación acerca de estas cabeceras acá: http://es.wikipedia.org/wiki/Portable_Executable
tambien  pueden encontrar StripReloc en el siguiente link: http://www.jrsoftware.org/striprlc.php
Para usarlo debemos descargarnos el .zip de la pagina que les pase. Una vez descomprimido,
obtendremos un .exe llamado “StripReloc”.
Naveguemos hasta la ruta del exe, y los parámetros son: “StripReloc <EXE_A_REDUCIR>”

La reducción ha sido considerable, veamoslo:


16)Mirando en LordPe la sección .reloc:
¿Y si miramos en el LordPe?:

Repito!, esto no quita la sección, solo remueve lo innecesario que generan los compiladores

17)Viendo el Stack y el Heap con WinDbg(este paso solo es demostrativo):
Por ultimo usare windbg para ver el stack y los heaps asignados, es una aplicación pequeña pero es algo que siempre tengo en cuenta,
tómenlo como un detalle de mi parte:


18)Despedida:
Y bueno gente, se despide WarZ0n3, espero que les haya servido y aprendido algo acerca del mundo de las APIS,
y lo poderosas que son,  junto con la imaginación se puede hacer cualquier cosa,
también vimos como reducir un ejecutable, y optimizar código liberando variables en memoria y pequeño
uso de asm.
Ahora usando tu criterio y si has estudiado e investigado al respecto ya podrás hacer tu propio viewbot,
y mandármelo por PM o publicarlo en el foro dándome las gracias.
Saludos!.


« Última modificación: 3 Agosto 2013, 20:05 pm por WarZ0n3 » En línea

Páginas: [1] Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
hay alguna forma de renombrar una carpeta usando pascal ?
Ejercicios
7U15MK 1 5,264 Último mensaje 27 Enero 2006, 08:44 am
por jvchino
[Tutorial] Crear un servidor para WoW usando ArcEmu y NCDB [Tutorial] « 1 2 ... 210 211 »
Juegos y Consolas
Ariath 2,101 927,584 Último mensaje 2 Junio 2009, 22:54 pm
por Ariath
[Tutorial] Usando el calendario JS (EpochPrime)
Desarrollo Web
dimitrix 0 2,043 Último mensaje 21 Mayo 2012, 18:43 pm
por dimitrix
tutorial sql usando visual c++
Programación C/C++
flony 0 1,671 Último mensaje 24 Octubre 2012, 14:24 pm
por flony
Problema en mi videojuego programado en JAVA, usando librerias Swing/AWT
Java
DarkSorcerer 2 5,056 Último mensaje 15 Marzo 2013, 05:52 am
por Kenkox
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines