OldSchoolHack

Registrieren / Anmelden Deutsch

C++ Find Pattern Frage!

icon Thema: C++ Find Pattern Frage!

Anmeldungsdatum: Jan 2010

Beiträge: 4

Hey,

also ich würde gerne einen FindPattern schreiben, der die .exe Datei in mein Programm lädt und anschließend auf den bestimmten Adressen verweißt. Weiß ich nicht, wie ich die FindPattern Funktion auf ein Programm anwende, welches ich in mein Programm lade, aber mit einer .dll Injektion funktioniert es. Jetzt würde ich gerne fragen, wie ich das schaffe.
Ich würde gerne eine Konsole benutzen und keine .dll.
Wenn ich jetzt mithilfe des fstream Header die .exe im Binary Mode lade, wie kann ich dann dadrin die Adressen suchen? Hier sind die beiden Pattern Funktionen, die ich benutze.
CPP Code:
  1. bool bDataCompare(const unsigned char* pData, const unsigned char* bMask, const char* szMask)
  2.  
  3. {
  4.  
  5. for(;*szMask;++szMask,++pData,++bMask)
  6.  
  7. if(*szMask=='x' && *pData!=*bMask )
  8.  
  9. return false;
  10.  
  11. return (*szMask) == 0;
  12.  
  13. }
  14.  
  15. unsigned long dwFindPattern( unsigned char *bMask,char * szMask, unsigned long dw_Address, unsigned long dw_Len)
  16.  
  17. {
  18.  
  19. for(unsigned long i=0; i < dw_Len; i++)
  20.  
  21. if( bDataCompare( (unsigned char*)( dw_Address+i ),bMask,szMask) )
  22.  
  23. return (unsigned long)(dw_Address+i);
  24.  
  25. return 0;
  26.  
  27. }

Bis jetzt sieht mein Code so aus:
CPP Code:
  1. ifstream::pos_type size;
  2. char* memblock;
  3. char test[20];
  4. int warte;
  5. DWORD Offset;
  6.  
  7. int main()
  8. {
  9. ifstream file("Spiel.exe", ios::out | ios::app | ios::binary);
  10. if(file.is_open())
  11. {
  12. size = file.tellg();
  13. memblock = new char [size];
  14. file.seekg(0, ios::beg);
  15. file.read(memblock, size);
  16. //Offset = dwFindPattern((PBYTE)"\x55\x8B\xEC\x6A\xFF\x68\x00\x00\x00\x00\x64\xA1\x00\x00\x00\x00\x50\x64\x89\x25\x00\x00\x00\x00\x51\x8B\x4D\x08\x53\x56\x8B\x35\x00\x00\x00\x00", "xxxxxx????xx????xxxx????xxxxxxxx????", 0x401000, 0x29e000);
  17.  
  18. }
  19. else
  20. {
  21. cout << "Datei konnte nicht geoeffnet werden!";
  22. cin >> warte;
  23. }
  24.  
  25. Offset = *(DWORD*) Offset;
  26. //sprintf(test, "Adresse: %x", Offset);
  27. cout << "Adresseee: %x" << Offset;
  28. cin >> warte;
  29. file.close();
  30. return 0;
  31. }

Ich hoffe einer kann mir helfen.
Gruß