IndeksSelamat DatangPendaftaranLogin
Forum
Similar topics
December 2017
MonTueWedThuFriSatSun
    123
45678910
11121314151617
18192021222324
25262728293031
CalendarCalendar
Clock

Share | 
 

 [Tutorial] Membuat File Dll Injection (C++)

Topik sebelumnya Topik selanjutnya Go down 
PengirimMessage
Admin [B0C4H]
Administrator
Administrator
avatar

Jumlah posting : 201
Join date : 19.10.10
Age : 27
Lokasi : Padang

PostSubyek: [Tutorial] Membuat File Dll Injection (C++)   Wed Oct 27, 2010 9:13 am

Kali ini ane coba sampaikan tutorial membuat file DLL untuk keperluan game hacking dengan menggunakan Visual C++ 2008 Express secara sederhana.

Adapun software yang diperlukan sebagai berikut, yang belum punya silakan download:
# Visual C++ 2008 Express Edition (free)
Injector, dalam tutorial ini tool injector favorit ane adalah * x1nject


Adapun target game yang ada dalam tutorial ini adalah Point Blank, dengan contoh hack misi mayor.

Silakan ikuti langkah-langah di bawah ini:

Jalankan Visual C++ 2008 Express Edition, buat sebuah project dengan cara akses menu File - New - Project atau dengan menekan tombol CTRL + SHIFT + N.

Screenshot:


Pada jendela New Project, pilih Empty Project (1) pada bagian Templates, kemudian pada kolom Name masukkan nama project (2) dan klik tombol OK (3)
Screenshot:


Project telah berhasil dibuat. Pada bagian Solution Explorer, klik kanan pada nama project (1), kemudian pilih menu Properties (2).

Screenshot:



Jendela project properties akan tampil. Pada tree menu sebelah kiri, pilih Configuration Properties (1), kemudian bagian opsi Project Defaults, ubah opsi Configuration Type menjadi Dynamic Library (.dll) (2), kemudian tekan tombol OK (3) untuk melakukan perubahan.

Screenshot:


Pada jendela Add New Item yang tampil, pada bagian templates pilih C++ File (.cpp) (1), beri nama 'Main.cpp' (2) pada bagian kolom Name, kemudian tekan tombol OK (3).

Screenshot:


Sebuah file bernama 'Main.cpp' berhasil dibuat. Silakan masukkan kode-kode di bawah ini pada file tersebut, kemudian simpan (save).

Screenshot:


Berikutnya adalah membuat sebuah file bernama Main.cpp untuk memasukkan kode-kode utama, dengan cara pilih direktori Source Files (1) pada bagian Solution Explorer, kemudian klik menu Project - Add New Item (2) atau dengan menekan tombol CTRL + SHIFT + A.

#define _CRT_SECURE_NO_WARNINGS
#include
#include

// definisikan variable dengan 'window title', 'window classname' dan modul
char *pProcessWindowTitle = "Point Blank";
char *pProcessWindowClass = "I3VIEWER";
char *pProcessModuleName = "PointBlank.i3Exec";

// etc...
UINT_PTR uipUserRankValue = 35; // major?
UINT_PTR uipUserPointsValue = 999999; // OMG!

UINT_PTR uiptrFinalRank, uiptrFinalPoints;

bool isInitMmhMemory = true;

DWORD dwProcessID;
UINT_PTR uipMmhBaseAddress;
HANDLE hProcess;

DWORD GetModuleBase(LPSTR lpModuleName, DWORD dwProcessId)
{
MODULEENTRY32 lpModuleEntry = {0};
HANDLE hSnapShot = CreateToolhelp32Snapshot(TH32CS_SNAPMODULE, dwProcessId);

if(!hSnapShot)
return NULL;
lpModuleEntry.dwSize = sizeof(lpModuleEntry);
BOOL bModule = Module32First( hSnapShot, &lpModuleEntry );
while(bModule)
{
if(!strcmp( lpModuleEntry.szModule, lpModuleName ) )
{
CloseHandle(hSnapShot);
return (DWORD)lpModuleEntry.modBaseAddr;
}
bModule = Module32Next( hSnapShot, &lpModuleEntry );
}
CloseHandle( hSnapShot );
return NULL;
}

// DeRef() = credit L. Spiro (MHS)
UINT_PTR DeRef( UINT_PTR _uiptrPointer ) {
UINT_PTR uiptrRet;
if (!::ReadProcessMemory(hProcess, reinterpret_cast(_uiptrPointer), &uiptrRet, sizeof(uiptrRet), NULL)) { return 0UL; }
return uiptrRet;
}

// inisialisasi proses
void InitApplicationProcess()
{
bool isFindWindow = true;
HWND hWnd = NULL;

while(isFindWindow)
{
if((hWnd = FindWindowA(pProcessWindowClass, pProcessWindowTitle)) != NULL) // jika window ditemukan
{
isFindWindow = false;
}
Sleep(500);
}

GetWindowThreadProcessId(hWnd, &dwProcessID);
hProcess = OpenProcess(PROCESS_ALL_ACCESS|PROCESS_VM_OPERATION|PROCESS_VM_READ|PROCESS_VM_WRITE|PROCESS_QUERY_INFORMATION, FALSE, dwProcessID);
}

void MajorMissionHack()
{
if(isInitMmhMemory)
{
uipMmhBaseAddress = GetModuleBase(pProcessModuleName, dwProcessID);

// misal: pointer yang didapat = PointBlank.i3Exec+00471234 dengan offset 0xA12, tuliskan seperti di bawah!
uiptrFinalRank = DeRef(uipMmhBaseAddress + 0x4XXXXX) + 0xXXX; // User rank pointer - masked, sorry!
uiptrFinalPoints = DeRef(uipMmhBaseAddress + 0x4XXXXX) + 0xXXX; // User points pointer - masked, sorry!

isInitMmhMemory = false;
}

// WriteProcessMemory pada pointer 'rank', berikan nilai uipUserRankValue (35)
::WriteProcessMemory(hProcess, reinterpret_cast(uiptrFinalRank), &uipUserRankValue, sizeof(uipUserRankValue), NULL);

// WriteProcessMemory pada pointer 'points', berikan nilai uipUserPointsValue (999999) LOL!
::WriteProcessMemory(hProcess, reinterpret_cast(uiptrFinalPoints), &uipUserPointsValue, sizeof(uipUserPointsValue), NULL);
}

void LovelyLoopy()
{
// ok, berikan salam dulu!
MessageBox(0, "DLL berhasil di-inject. Lanjutkan!", "Hello World", MB_OK + MB_ICONASTERISK);

InitApplicationProcess();

while(1) // loop selamanya
{
if(GetAsyncKeyState(VK_F12)&1) // jika F12 ditekan
{
MajorMissionHack(); // panggil fungsi 'MajorMissionHack()'
Sleep(500);
}

Sleep(1);
}
}

BOOL WINAPI DllMain(HMODULE hDll, DWORD dwReason, LPVOID lpReserved)
{
DisableThreadLibraryCalls(hDll);

if(dwReason == DLL_PROCESS_ATTACH)
{
CreateThread(NULL, NULL, (LPTHREAD_START_ROUTINE)LovelyLoopy, NULL, NULL, NULL);
}
else if(dwReason == DLL_PROCESS_DETACH)
{
CloseHandle(hProcess);
}

return TRUE;
}
Screenshot:


Jika kode sudah disimpan (save), langkah berikutnya adalah membentuk file DLL-nya dengan cara klik menu Build - Build Solution atau dengan menekan tombol F7.

Screenshot:


Setelah proses build solution, pada jendela Output akan menampilkan hasil dari proses compile/build tersebut, jika tidak ada kesalahan (error) berarti kode-kode sudah benar dan file DLL sudah terbentuk. Jika ternyata ada kesalahan (error), silakan periksa langkah-langkah sebelumnya jika ada yang terlewatkan.

Screenshot:


Kemudian buka direktori tempat project anda disimpan, dalam tutorial ini ane simpan di direktori D:\!PROJECTS!\SukaSukaEnte dan buka direktori yang bernama Debug di dalamnya (sesuaikan letak direktori anda).

Screenshot:



Bisa kita lihat ada beberapa file yang terbentuk, namun yang kita perlukan hanyalah file yang berekstensi .dll, karena file tersebut yang akan kita injeksikan ke proses program/game. Agar tidak membingungkan, sekaligus ane copy-kan file injector-nya (x1nject.exe) ke direktori tersebut.




Kemudian jalankan injector (x1nject.exe), ubah pada kolom 'What to inject' dengan nama proses program/game, (contoh: PointBlank.exe), pada bagian 'Add to injection list' tambahkan file .dll yang telah kita buat dengan menekan tombol Browse dan cari pada direktori Debug project kita.

Screenshot:


Jalankan program/game yang akan kita injeksikan dengan .dll yang kita buat, dan apabila program/game telah berjalan, injector x1nject.exe otomatis menginjeksikan file .dll tersebut.

Screenshot:


dan hasilnya adalah:

Screenshot:


Berikutnya kita coba hack misi mayor yang telah kita buat (lihat fungsi LovelyLoopy() dan MajorMissionHack() pada kode untuk lebih jelas), dengan menekan tombol F12 pada keyboard, kita lihat hasilnya pada gambar di bawah ini:
bukti 1 :
Enlarge this image



bukti 2:
Enlarge this image



DLL Injection kita telah bekerja!

Semoga bisa membantu teman-teman semua, jika berguna...!

Happy cheating!


NB: Pointer & offset pada fungsi MajorMissionHack() sengaja saya tidak tampilkan. Silakan dimodifikasi jika ingin menambahkan fungsi-fungsi lainnya (unlimited ammo, grenade dsb).

Credits: L. Spiro (MHS) for DeRef() function, jonita aka l0l1c0n (inspirasi & F12 Misi Mayor-nya )

_____________________________________________________________________________
About me klik:
 


KALO BERGUNA TOLONG DI

sundul sundul sundul

ga nolak juga loh di kasih ++

cendol cendol cendol






†F.K.B† TEAM

Kembali Ke Atas Go down
http://padangonly.n-stars.org
am4ra
Moderator
Moderator
avatar

Jumlah posting : 15
Join date : 23.10.10

PostSubyek: Re: [Tutorial] Membuat File Dll Injection (C++)   Thu Oct 28, 2010 8:47 am

BUATIN .dll nya damage 100 ,akurasi 100,range 100 wan we tunggu ya
Kembali Ke Atas Go down
Admin [B0C4H]
Administrator
Administrator
avatar

Jumlah posting : 201
Join date : 19.10.10
Age : 27
Lokasi : Padang

PostSubyek: Re: [Tutorial] Membuat File Dll Injection (C++)   Fri Oct 29, 2010 11:23 pm

wah lo itu resikonya gede cak.....

langsung BANED tuh.......

sasarannya langsung ke database

_____________________________________________________________________________
About me klik:
 


KALO BERGUNA TOLONG DI

sundul sundul sundul

ga nolak juga loh di kasih ++

cendol cendol cendol






†F.K.B† TEAM

Kembali Ke Atas Go down
http://padangonly.n-stars.org
subma
Moderator
Moderator
avatar

Jumlah posting : 141
Join date : 01.11.10
Age : 27
Lokasi : medan

PostSubyek: Re: [Tutorial] Membuat File Dll Injection (C++)   Mon Nov 01, 2010 1:41 am

tolong sertakan credit atau bypass agar tidak terjadi konflik terhadap forum lain maaf bukan sok ngatur
Kembali Ke Atas Go down
http://juliyantie.blogspot.com
Sponsored content




PostSubyek: Re: [Tutorial] Membuat File Dll Injection (C++)   

Kembali Ke Atas Go down
 
[Tutorial] Membuat File Dll Injection (C++)
Topik sebelumnya Topik selanjutnya Kembali Ke Atas 
Halaman 1 dari 1
 Similar topics
-
» Cara Membuat Aplikasi Facebook
» Makanan yang Bisa Membuat Mood Bagus
» Aplikasi Untuk Membuat Ebook
» Berbagai Manfaat Kunyit
» 30 Hal yg Membuat Pacarmu Tersenyum

Permissions in this forum:Anda tidak dapat menjawab topik
 :: F.K.B |Dunia Teknologi :: Software/Hadware-
Navigasi: