Dll Injector

03/28/2012 22:04 _RedBull_#1
Hallo Com, Hallo epvp'er,

Ich wollte fragen ob es irgendwo ein [HowTo] gibt wie man mit VB 2010 einen Injector für warrock o.ä. erstellt..?

danke schon im vorraus.

_RedBull_
03/28/2012 22:05 +Yazzn#2
[Only registered and activated users can see links. Click Here To Register...]
03/29/2012 10:28 _RedBull_#3
-Also genaue Anleitung wie man das anstellt
03/29/2012 11:41 ⁂ AllStars ⁂#4
SuFu benutzen oder Google :).
03/29/2012 11:53 _RedBull_#5
Quote:
Originally Posted by xEnginestar™ View Post
SuFu benutzen oder Google :).
schon probiert finde nichts ... oO
03/29/2012 12:30 .Tiq3reye™#6
Dann bist du wohl einer der zu doof ist zu googlen :facepalm:
03/29/2012 12:43 _RedBull_#7
Quote:
Originally Posted by .Tiq3reye™ View Post
Dann bist du wohl einer der zu doof ist zu googlen :facepalm:
Spam nicht ich suche nach richtigen antworten -.-
03/29/2012 13:09 ⁂ AllStars ⁂#8
In Google wirst du bestimmt etwas finden.
03/29/2012 13:12 hero9910#9
VB->Neues Project->Windows Forms-Anwendung->TextBox reinziehen->Doppelklick auf die Form
->Den ganzen code löschen->[Only registered and activated users can see links. Click Here To Register...]
Fertig
03/29/2012 13:20 theitfan1337#10
Mit WinApi:
OpenProcess -> VirtualAlocEx -> WriteProcessMemory -> CreateRemoteThread -> VirtualFreeEx
Mit diesen Funktionen bekommst du das locker alleine hin. Wenn nicht, dann würde ich mal ganz fix die Grundlagen wiederholen bevor dich an sowas versuchst.
03/29/2012 14:54 _RedBull_#11
Das wollte ich doch nur wissen danke :-)
03/29/2012 15:15 +Yazzn#12
Öffne den WarRock-Prozess, alloziere Speicher in den du den Pfad der .dll haust, Erstelle einen Remote Thread mittels CreateRemoteProcess mit Handle zur WarRock.exe als BaseAddress nimmst du die von LoadLibraryA und als Parameter den allozierten Speicher.
Sollte ich irgendwo Fehler in dieser kurzen und bündigen "Anleitung": Shit happens.
03/30/2012 18:24 Mafia67#13
Tutorial ist für 2008 (ista aber das gleiche wie 2010)

(Tut ist nicht von mir)
Quote:
Neue Form erstellen:
[Only registered and activated users can see links. Click Here To Register...]

Textfeld einfügen:
[Only registered and activated users can see links. Click Here To Register...]

[Only registered and activated users can see links. Click Here To Register...]

Das macht ihr nun 2 Mal...

Timer einfügen (egal wohin):
[Only registered and activated users can see links. Click Here To Register...]

Den Code Markieren:
[Only registered and activated users can see links. Click Here To Register...]

alles löschen was da steht...
und diesen code einfügen:
Code:
Public Class Form1

Private TargetProcessHandle As Integer
Private pfnStartAddr As Integer
Private pszLibFileRemote As String
Private TargetBufferSize As Integer

Public Const PROCESS_VM_READ = &H10
Public Const TH32CS_SNAPPROCESS = &H2
Public Const MEM_COMMIT = 4096
Public Const PAGE_READWRITE = 4
Public Const PROCESS_CREATE_THREAD = (&H2)
Public Const PROCESS_VM_OPERATION = (&H8)
Public Const PROCESS_VM_WRITE = (&H20)

Public Declare Function ReadProcessMemory Lib "kernel32" ( _
ByVal hProcess As Integer, _
ByVal lpBaseAddress As Integer, _
ByVal lpBuffer As String, _
ByVal nSize As Integer, _
ByRef lpNumberOfBytesWritten As Integer) As Integer

Public Declare Function LoadLibrary Lib "kernel32" Alias "LoadLibraryA" ( _
ByVal lpLibFileName As String) As Integer

Public Declare Function VirtualAllocEx Lib "kernel32" ( _
ByVal hProcess As Integer, _
ByVal lpAddress As Integer, _
ByVal dwSize As Integer, _
ByVal flAllocationType As Integer, _
ByVal flProtect As Integer) As Integer

Public Declare Function WriteProcessMemory Lib "kernel32" ( _
ByVal hProcess As Integer, _
ByVal lpBaseAddress As Integer, _
ByVal lpBuffer As String, _
ByVal nSize As Integer, _
ByRef lpNumberOfBytesWritten As Integer) As Integer

Public Declare Function GetProcAddress Lib "kernel32" ( _
ByVal hModule As Integer, ByVal lpProcName As String) As Integer

Private Declare Function GetModuleHandle Lib "Kernel32" Alias "GetModuleHandleA" ( _
ByVal lpModuleName As String) As Integer

Public Declare Function CreateRemoteThread Lib "kernel32" ( _
ByVal hProcess As Integer, _
ByVal lpThreadAttributes As Integer, _
ByVal dwStackSize As Integer, _
ByVal lpStartAddress As Integer, _
ByVal lpParameter As Integer, _
ByVal dwCreationFlags As Integer, _
ByRef lpThreadId As Integer) As Integer

Public Declare Function OpenProcess Lib "kernel32" ( _
ByVal dwDesiredAccess As Integer, _
ByVal bInheritHandle As Integer, _
ByVal dwProcessId As Integer) As Integer

Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" ( _
ByVal lpClassName As String, _
ByVal lpWindowName As String) As Integer

Private Declare Function CloseHandle Lib "kernel32" Alias "CloseHandleA" ( _
ByVal hObject As Integer) As Integer


Dim ExeName As String = IO.Path.GetFileNameWithoutExtension(Application.ExecutablePath)

Private Sub Inject()
On Error GoTo 1 ' If error occurs, app will close without any error messages
Timer1.Stop()
Dim TargetProcess As Process() = Process.GetProcessesByName("WarRock")
TargetProcessHandle = OpenProcess(PROCESS_CREATE_THREAD Or PROCESS_VM_OPERATION Or PROCESS_VM_WRITE, False, TargetProcess(0).Id)
pszLibFileRemote = Application.StartupPath & "" + ExeName + ".dll"
pfnStartAddr = GetProcAddress(GetModuleHandle("Kernel32"), "LoadLibraryA")
TargetBufferSize = 1 + Len(pszLibFileRemote)
Dim Rtn As Integer
Dim LoadLibParamAdr As Integer
LoadLibParamAdr = VirtualAllocEx(TargetProcessHandle, 0, TargetBufferSize, MEM_COMMIT, PAGE_READWRITE)
Rtn = WriteProcessMemory(TargetProcessHandle, LoadLibParamAdr, pszLibFileRemote, TargetBufferSize, 0)
CreateRemoteThread(TargetProcessHandle, 0, 0, pfnStartAddr, LoadLibParamAdr, 0, 0)
CloseHandle(TargetProcessHandle)
1: Me.Close()
End Sub

Private Sub Timer1_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Timer1.Tick
If IO.File.Exists(Application.StartupPath & "" + ExeName + ".dll") Then
Dim TargetProcess As Process() = Process.GetProcessesByName("HSUpdate")
If TargetProcess.Length = 0 Then
Me.TextBox1.Text = ("Waiting for Warrock.exe")
Me.TextBox2.Text = ("Let´s Hack")
Else
Timer1.Stop()
Me.TextBox1.Text = "Done..."
Call Inject()
End If
Else
Me.TextBox1.Text = ("" + ExeName + ".dll not found")
Me.TextBox2.Text = ("Rename the .dll To " + "" + ExeName)
End If
End Sub

Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
Timer1.Interval = 50
Timer1.Start()
End Sub

End Class
das sieht dann so aus:
[Only registered and activated users can see links. Click Here To Register...]

Nun speichern wir:
[Only registered and activated users can see links. Click Here To Register...]

[Only registered and activated users can see links. Click Here To Register...]

Und erstellen exe:
[Only registered and activated users can see links. Click Here To Register...]

Die .exe ist im Pfad Eigene Dateien/Visual Studio 2010/Projects/...

Diese Detei könnt ihr dann umbennen wie ihr wollt und verschieben natürlich auch.
03/30/2012 18:26 _Headsh0t_#14
Hier wurden bereits dutzende Tutorials gepostet.
Mal in der Guide, Tutorial Sektion vorbeischauen und die SuchFunktion nutzen ;)

#closed