[C++][Minimalista] API class, llamadas dinámicas.

  • 1 Respuestas
  • 3641 Vistas

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

Desconectado Karcrack

  • *
  • Underc0der
  • Mensajes: 87
  • Actividad:
    0%
  • Reputación 0
  • Se siente observado ¬¬'
    • Ver Perfil

[C++][Minimalista] API class, llamadas dinámicas.

  • en: Junio 16, 2013, 06:32:36 pm
Código: C++
  1. using namespace std;
  2. #include <Windows.h>
  3. #include <string>
  4.  
  5. class API{
  6. public:
  7.     void* (*call)(...);
  8.     API(string dll, string fnc){
  9.         this->call = (void *(*)(...))GetProcAddress(LoadLibraryA(dll.c_str()), fnc.c_str());
  10.     };
  11. };

Ejemplo de uso:
Código: C++
  1. #pragma comment(linker, "/ENTRY:main")
  2.  
  3. #include "invoke.h"
  4.  
  5. void main(){
  6.     API("URLMON", "URLDownloadToFileA").call(0, "http://goo.gl/veps2", "C:/test.png", 0, 0);
  7.     __asm sub esp, 5*4
  8.     API("KERNEL32","ExitProcess").call(0);
  9.     //__asm sub esp, 4
  10. }
Detección: 2/44
Solo los usuarios pueden ver los links. Registrate o Ingresar

Mucho más compacto a lA hora de llamar al puntero que mis otras versiones, aunque hay que reparar de forma manual el stack hasta que diseñe un template para hacerlo.
I code for $$$.

(PGP ID 0xCC050E77)
ASM, C, C++, VB6... skilled [malware] developer

Desconectado Burnsed

  • *
  • Underc0der
  • Mensajes: 2
  • Actividad:
    0%
  • Reputación 0
  • Skype: paauet
    • Ver Perfil
    • Email
No entiendo esto:
Código: Solo los usuarios pueden ver los links. Registrate o Ingresar
void* (*call)(...);
    API(string dll, string fnc){
        this->call = (void *(*)(...))GetProcAddress(LoadLibraryA(dll.c_str()), fnc.c_str());
    };

el void* (*call) (...);