Tratsch rund um Autoit / Autoit Talk | kleinere Fragen

05/21/2013 18:10 WJNeeson#1276
NomadMemory.au3
PHP Code:
#include-once
#region _Memory
;==================================================================================
AutoIt Version:    3.1.127 (beta)
Language:            English
Platform:            All Windows
Author:            Nomad
Requirements:        These functions will only work with beta.
;==================================================================================
Credits:    wOuter These functions are based on his original _Mem() functions.
;            
But they are easier to comprehend and more reliable.  These
;            functions are in no way a direct copy of his functions.  His
;            functions only provided a foundation from which these evolved.
;==================================================================================
;
Functions:
;
;==================================================================================
; Function:            
_MemoryOpen($iv_Pid[, $iv_DesiredAccess[, $iv_InheritHandle]])
Description:        Opens a process and enables all possible access rights to the
;                    process.  The Process ID of the process is used to specify which
;                    process to open.  You must call this function before calling
;                    _MemoryClose(), _MemoryRead(), or _MemoryWrite().
Parameter(s):        $iv_Pid The Process ID of the program you want to open.
;                    
$iv_DesiredAccess - (optionalSet to 0x1F0FFF by default, which
;                                        enables all possible access rights to the
;                                        process specified by the Process ID.
;                    
$iv_InheritHandle - (optional) If this value is TRUEall processes
;                                        created by this process will inherit the access
;                                        handle.  Set to 1 (TRUEby default.  Set to 0
;                                        if you want it FALSE.
Requirement(s):    None.
; Return 
Value(s):     On Success Returns an array containing the Dll handle and an
;                                 open handle to the specified process.
;                    
On Failure Returns 0
;                    @Error No error.
;                             
Invalid $iv_Pid.
;                             
Failed to open Kernel32.dll.
;                             
Failed to open the specified process.
Author(s):        Nomad
Note(s):
;==================================================================================
Func _MemoryOpen($iv_Pid$iv_DesiredAccess 0x1F0FFF$iv_InheritHandle 1)

    If 
Not ProcessExists($iv_PidThen
        SetError
(1)
        Return 
0
    
EndIf

    
Local $ah_Handle[2] = [DllOpen('kernel32.dll')]

    If @
Error Then
        SetError
(2)
        Return 
0
    
EndIf

    
Local $av_OpenProcess DllCall($ah_Handle[0], 'int''OpenProcess''int'$iv_DesiredAccess'int'$iv_InheritHandle'int'$iv_Pid)

    If @
Error Then
        DllClose
($ah_Handle[0])
        
SetError(3)
        Return 
0
    
EndIf

    
$ah_Handle[1] = $av_OpenProcess[0]

    Return 
$ah_Handle

EndFunc

;==================================================================================
; Function:            
_MemoryRead($iv_Address$ah_Handle[, $sv_Type])
Description:        Reads the value located in the memory address specified.
Parameter(s):        $iv_Address The memory address you want to read fromIt must
;                                  be in hex format (0x00000000).
;                    
$ah_Handle An array containing the Dll handle and the handle
;                                 of the open process as returned by _MemoryOpen().
;                    
$sv_Type - (optionalThe "Type" of value you intend to read.
;                                
This is set to 'dword'(32bit(4bytesigned integer)
;                                
by default.  See the help file for DllStructCreate
;                                for all types.  An example: If you want to read a
;                                word that is 15 characters in lengthyou would use
;                                
'char[16]' since a 'char' is 8 bits (1 bytein size.
; Return 
Value(s):    On Success Returns the value located at the specified address.
;                    
On Failure Returns 0
;                    @Error No error.
;                             
Invalid $ah_Handle.
;                             
$sv_Type was not a string.
;                             
$sv_Type is an unknown data type.
;                             
Failed to allocate the memory needed for the DllStructure.
;                             
Error allocating memory for $sv_Type.
;                             
Failed to read from the specified process.
Author(s):        Nomad
Note(s):            Values returned are in Decimal formatunless specified as a
;                    'char' typethen they are returned in ASCII format.  Also note
;                    that size ('char[size]') for all 'char' types should be 1
;                    greater than the actual size.
;==================================================================================
Func _MemoryRead($iv_Address$ah_Handle$sv_Type 'dword')

    If 
Not IsArray($ah_HandleThen
        SetError
(1)
        Return 
0
    
EndIf

    
Local $v_Buffer DllStructCreate($sv_Type)

    If @
Error Then
        SetError
(@Error 1)
        Return 
0
    
EndIf

    
DllCall($ah_Handle[0], 'int''ReadProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')

    If 
Not @Error Then
        Local $v_Value 
DllStructGetData($v_Buffer1)
        Return 
$v_Value
    
Else
        
SetError(6)
        Return 
0
    
EndIf

EndFunc

;==================================================================================
; Function:            
_MemoryWrite($iv_Address$ah_Handle$v_Data[, $sv_Type])
Description:        Writes data to the specified memory address.
Parameter(s):        $iv_Address The memory address which you want to write to.
;                                  
It must be in hex format (0x00000000).
;                    
$ah_Handle An array containing the Dll handle and the handle
;                                 of the open process as returned by _MemoryOpen().
;                    
$v_Data The data to be written.
;                    
$sv_Type - (optionalThe "Type" of value you intend to write.
;                                
This is set to 'dword'(32bit(4bytesigned integer)
;                                
by default.  See the help file for DllStructCreate
;                                for all types.  An example: If you want to write a
;                                word that is 15 characters in lengthyou would use
;                                
'char[16]' since a 'char' is 8 bits (1 bytein size.
; Return 
Value(s):    On Success Returns 1
;                    On Failure Returns 0
;                    @Error No error.
;                             
Invalid $ah_Handle.
;                             
$sv_Type was not a string.
;                             
$sv_Type is an unknown data type.
;                             
Failed to allocate the memory needed for the DllStructure.
;                             
Error allocating memory for $sv_Type.
;                             
$v_Data is not in the proper format to be used with the
;                                 "Type" selected for $sv_Type, or it is out of range.
;                             
Failed to write to the specified process.
Author(s):        Nomad
Note(s):            Values sent must be in Decimal formatunless specified as a
;                    'char' typethen they must be in ASCII format.  Also note
;                    that size ('char[size]') for all 'char' types should be 1
;                    greater than the actual size.
;==================================================================================
Func _MemoryWrite($iv_Address$ah_Handle$v_Data$sv_Type 'dword')

    If 
Not IsArray($ah_HandleThen
        SetError
(1)
        Return 
0
    
EndIf

    
Local $v_Buffer DllStructCreate($sv_Type)

    If @
Error Then
        SetError
(@Error 1)
        Return 
0
    
Else
        
DllStructSetData($v_Buffer1$v_Data)
        If @
Error Then
            SetError
(6)
            Return 
0
        
EndIf
    EndIf

    
DllCall($ah_Handle[0], 'int''WriteProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')

    If 
Not @Error Then
        
Return 1
    
Else
        
SetError(7)
        Return 
0
    
EndIf

EndFunc

;==================================================================================
; Function:            
_MemoryClose($ah_Handle)
Description:        Closes the process handle opened by using _MemoryOpen().
Parameter(s):        $ah_Handle An array containing the Dll handle and the handle
;                                 of the open process as returned by _MemoryOpen().
; Return 
Value(s):    On Success Returns 1
;                    On Failure Returns 0
;                    @Error No error.
;                             
Invalid $ah_Handle.
;                             
Unable to close the process handle.
Author(s):        Nomad
Note(s):
;==================================================================================
Func _MemoryClose($ah_Handle)

    If 
Not IsArray($ah_HandleThen
        SetError
(1)
        Return 
0
    
EndIf

    
DllCall($ah_Handle[0], 'int''CloseHandle''int'$ah_Handle[1])
    If 
Not @Error Then
        DllClose
($ah_Handle[0])
        Return 
1
    
Else
        
DllClose($ah_Handle[0])
        
SetError(2)
        Return 
0
    
EndIf

EndFunc

;==================================================================================
; Function:            
SetPrivilege$privilege$bEnable )
Description:        Enables (or disablesthe $privilege on the current process
;                   (Probablyrequires administrator privileges to run
;
Author(s):        Larry (from autoitscript.coms Forum)
Notes(s):
http://www.autoitscript.com/forum/index.php?s=&showtopic=31248&view=findpost&p=223999
;==================================================================================

Func SetPrivilege$privilege$bEnable )
    Const 
$TOKEN_ADJUST_PRIVILEGES 0x0020
    
Const $TOKEN_QUERY 0x0008
    
Const $SE_PRIVILEGE_ENABLED 0x0002
    Local $hToken
$SP_auxret$SP_ret$hCurrProcess$nTokens$nTokenIndex$priv
    $nTokens 
1
    $LUID 
DLLStructCreate("dword;int")
    If 
IsArray($privilegeThen    $nTokens UBound($privilege)
    
$TOKEN_PRIVILEGES DLLStructCreate("dword;dword[" & ($nTokens) & "]")
    
$NEWTOKEN_PRIVILEGES DLLStructCreate("dword;dword[" & ($nTokens) & "]")
    
$hCurrProcess DLLCall("kernel32.dll","hwnd","GetCurrentProcess")
    
$SP_auxret DLLCall("advapi32.dll","int","OpenProcessToken","hwnd",$hCurrProcess[0],   _
            
"int",BitOR($TOKEN_ADJUST_PRIVILEGES,$TOKEN_QUERY),"int_ptr",0)
    If 
$SP_auxret[0Then
        $hToken 
$SP_auxret[3]
        
DLLStructSetData($TOKEN_PRIVILEGES,1,1)
        
$nTokenIndex 1
        
While $nTokenIndex <= $nTokens
            
If IsArray($privilegeThen
                $priv 
$privilege[$nTokenIndex-1]
            Else
                
$priv $privilege
            
EndIf
            
$ret DLLCall("advapi32.dll","int","LookupPrivilegeValue","str","","str",$priv,   _
                    
"ptr",DLLStructGetPtr($LUID))
            If 
$ret[0Then
                
If $bEnable Then
                    DLLStructSetData
($TOKEN_PRIVILEGES,2,$SE_PRIVILEGE_ENABLED,($nTokenIndex))
                Else
                    
DLLStructSetData($TOKEN_PRIVILEGES,2,0,($nTokenIndex))
                EndIf
                
DLLStructSetData($TOKEN_PRIVILEGES,2,DllStructGetData($LUID,1),(* ($nTokenIndex-1)) + 1)
                
DLLStructSetData($TOKEN_PRIVILEGES,2,DllStructGetData($LUID,2),(* ($nTokenIndex-1)) + 2)
                
DLLStructSetData($LUID,1,0)
                
DLLStructSetData($LUID,2,0)
            EndIf
            
$nTokenIndex += 1
        WEnd
        $ret 
DLLCall("advapi32.dll","int","AdjustTokenPrivileges","hwnd",$hToken,"int",0,   _
                
"ptr",DllStructGetPtr($TOKEN_PRIVILEGES),"int",DllStructGetSize($NEWTOKEN_PRIVILEGES),   _
                
"ptr",DllStructGetPtr($NEWTOKEN_PRIVILEGES),"int_ptr",0)
        
$f DLLCall("kernel32.dll","int","GetLastError")
    EndIf
    
$NEWTOKEN_PRIVILEGES=0
    $TOKEN_PRIVILEGES
=0
    $LUID
=0
    
If $SP_auxret[0] = 0 Then Return 0
    $SP_auxret 
DLLCall("kernel32.dll","int","CloseHandle","hwnd",$hToken)
    If 
Not $ret[0] And Not $SP_auxret[0Then Return 0
    
return $ret[0]
EndFunc   ;==>SetPrivilege

#endregion 
Memory.au3 (Die NomadMemory.au3 mit mehr Funktionen)
PHP Code:
#include-once
#region _Memory
;=================================================================================================
AutoIt Version:    3.1.127 (beta)
Language:            English
Platform:            All Windows
Author:            Nomad
Requirements:        These functions will only work with beta.
;=================================================================================================
Credits:    wOuter These functions are based on his original _Mem() functions.  But they are
;            easier to comprehend and more reliable.  These functions are in no way a direct copy
;            of his functions.  His functions only provided a foundation from which these evolved.
;=================================================================================================
;
Functions:
;
;=================================================================================================
; Function:            
_MemoryOpen($iv_Pid(, $iv_DesiredAccess(, $iv_InheritHandle)))
Description:        Opens a process and enables all possible access rights to the process.  The
;                    Process ID of the process is used to specify which process to open.  You must
;                    call this function before calling _MemoryClose(), _MemoryRead(), or _MemoryWrite().
Parameter(s):        $iv_Pid The Process ID of the program you want to open.
;                    
$iv_DesiredAccess - (optionalSet to 0x1F0FFF by default, which enables all
;                                        possible access rights to the process specified by the
;                                        Process ID.
;                    
$if_InheritHandle - (optional) If this value is TRUEall processes created by
;                                        this process will inherit the access handle.  Set to TRUE
;                                        (1by default.  Set to 0 if you want it to be FALSE.
Requirement(s):    A valid process ID.
; Return 
Value(s):     On Success Returns an array containing the Dll handle and an open handle to
;                                 the specified process.
;                    
On Failure Returns 0
;                    @Error No error.
;                             
Invalid $iv_Pid.
;                             
Failed to open Kernel32.dll.
;                             
Failed to open the specified process.
Author(s):        Nomad
Note(s):
;=================================================================================================
Func _MemoryOpen($iv_Pid$iv_DesiredAccess 0x1F0FFF$if_InheritHandle 1)

    If 
Not ProcessExists($iv_PidThen
        SetError
(1)
        Return 
0
    
EndIf

    
Local $ah_Handle[2] = [DllOpen('kernel32.dll')]

    If @
Error Then
        SetError
(2)
        Return 
0
    
EndIf

    
Local $av_OpenProcess DllCall($ah_Handle[0], 'int''OpenProcess''int'$iv_DesiredAccess'int'$if_InheritHandle'int'$iv_Pid)

    If @
Error Then
        DllClose
($ah_Handle[0])
        
SetError(3)
        Return 
0
    
EndIf

    
$ah_Handle[1] = $av_OpenProcess[0]

    Return 
$ah_Handle

EndFunc

;=================================================================================================
; Function:            
_MemoryRead($iv_Address$ah_Handle(, $sv_Type))
Description:        Reads the value located in the memory address specified.
Parameter(s):        $iv_Address The memory address you want to read fromIt must be in hex
;                                  format (0x00000000).
;                    
$ah_Handle An array containing the Dll handle and the handle of the open
;                                 process as returned by _MemoryOpen().
;                    
$sv_Type - (optionalThe "Type" of value you intend to read.  This is set to
;                                'dword'(32bit(4bytesigned integerby default.  See the help file
;                                for DllStructCreate for all types.
;                                
An example: If you want to read a word that is 15 characters in
;                                lengthyou would use 'char[16]'.
Requirement(s):    The $ah_Handle returned from _MemoryOpen.
; Return 
Value(s):    On Success Returns the value located at the specified address.
;                    
On Failure Returns 0
;                    @Error No error.
;                             
Invalid $ah_Handle.
;                             
$sv_Type was not a string.
;                             
$sv_Type is an unknown data type.
;                             
Failed to allocate the memory needed for the DllStructure.
;                             
Error allocating memory for $sv_Type.
;                             
Failed to read from the specified process.
Author(s):        Nomad
Note(s):            Values returned are in Decimal formatunless specified as 'char' typethen
;                    they are returned in ASCII format.  Also note that size ('char[size]') for all
;                    'char' types should be 1 greater than the actual size.
;=================================================================================================
Func _MemoryRead($iv_Address$ah_Handle$sv_Type 'dword')

    If 
Not IsArray($ah_HandleThen
        SetError
(1)
        Return 
0
    
EndIf

    
Local $v_Buffer DllStructCreate($sv_Type)

    If @
Error Then
        SetError
(@Error 1)
        Return 
0
    
EndIf

    
DllCall($ah_Handle[0], 'int''ReadProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')

    If 
Not @Error Then
        Local $v_Value 
DllStructGetData($v_Buffer1)
        Return 
$v_Value
    
Else
        
SetError(6)
        Return 
0
    
EndIf

EndFunc

;=================================================================================================
; Function:            
_MemoryWrite($iv_Address$ah_Handle$v_Data(, $sv_Type))
Description:        Writes data to the specified memory address.
Parameter(s):        $iv_Address The memory address you want to write to.  It must be in hex
;                                  format (0x00000000).
;                    
$ah_Handle An array containing the Dll handle and the handle of the open
;                                 process as returned by _MemoryOpen().
;                    
$v_Data The data to be written.
;                    
$sv_Type - (optionalThe "Type" of value you intend to write.  This is set to
;                                'dword'(32bit(4bytesigned integerby default.  See the help file
;                                for DllStructCreate for all types.
;                                
An example: If you want to write a word that is 15 characters in
;                                lengthyou would use 'char[16]'.
Requirement(s):    The $ah_Handle returned from _MemoryOpen.
; Return 
Value(s):    On Success Returns 1
;                    On Failure Returns 0
;                    @Error No error.
;                             
Invalid $ah_Handle.
;                             
$sv_Type was not a string.
;                             
$sv_Type is an unknown data type.
;                             
Failed to allocate the memory needed for the DllStructure.
;                             
Error allocating memory for $sv_Type.
;                             
$v_Data is not in the proper format to be used with the "Type"
;                                 selected for $sv_Type, or it is out of range.
;                             
Failed to write to the specified process.
Author(s):        Nomad
Note(s):            Values sent must be in Decimal formatunless specified as 'char' typethen
;                    they must be in ASCII format.  Also note that size ('char[size]') for all
;                    'char' types should be 1 greater than the actual size.
;=================================================================================================
Func _MemoryWrite($iv_Address$ah_Handle$v_Data$sv_Type 'dword')

    If 
Not IsArray($ah_HandleThen
        SetError
(1)
        Return 
0
    
EndIf

    
Local $v_Buffer DllStructCreate($sv_Type)

    If @
Error Then
        SetError
(@Error 1)
        Return 
0
    
Else
        
DllStructSetData($v_Buffer1$v_Data)
        If @
Error Then
            SetError
(6)
            Return 
0
        
EndIf
    EndIf

    
DllCall($ah_Handle[0], 'int''WriteProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')

    If 
Not @Error Then
        
Return 1
    
Else
        
SetError(7)
        Return 
0
    
EndIf

EndFunc

;=================================================================================================
; Function:            
_MemoryClose($ah_Handle)
Description:        Closes the process handle opened by using _MemoryOpen().
Parameter(s):        $ah_Handle An array containing the Dll handle and the handle of the open
;                                 process as returned by _MemoryOpen().
Requirement(s):    The $ah_Handle returned from _MemoryOpen.
; Return 
Value(s):    On Success Returns 1
;                    On Failure Returns 0
;                    @Error No error.
;                             
Invalid $ah_Handle.
;                             
Unable to close the process handle.
Author(s):        Nomad
Note(s):
;=================================================================================================
Func _MemoryClose($ah_Handle)

    If 
Not IsArray($ah_HandleThen
        SetError
(1)
        Return 
0
    
EndIf

    
DllCall($ah_Handle[0], 'int''CloseHandle''int'$ah_Handle[1])
    If 
Not @Error Then
        DllClose
($ah_Handle[0])
        Return 
1
    
Else
        
DllClose($ah_Handle[0])
        
SetError(2)
        Return 
0
    
EndIf

EndFunc

;=================================================================================================
; Function:            
_MemoryPointerRead ($iv_Address$ah_Handle$av_Offset(, $sv_Type))
Description:        Reads a chain of pointers and returns an array containing the destination
;                    address and the data at the address.
Parameter(s):        $iv_Address The static memory address you want to start atIt must be in
;                                  hex format (0x00000000).
;                    
$ah_Handle An array containing the Dll handle and the handle of the open
;                                 process as returned by _MemoryOpen().
;                    
$av_Offset An array of offsets for the pointers.  Each pointer must have an
;                                 offset.  If there is no offset for a pointerenter 0 for that
;                                 array dimension. (Offsets must be in decimal formatNOT hex!)
;                    
$sv_Type - (optionalThe "Type" of data you intend to read at the destination
;                                 address.  This is set to 'dword'(32bit(4bytesigned integerby
;                                 default.  See the help file for DllStructCreate for all types.
Requirement(s):    The $ah_Handle returned from _MemoryOpen.
; Return 
Value(s):    On Success Returns an array containing the destination address and the value
;                                 located at the address.
;                    
On Failure Returns 0
;                    @Error No error.
;                             
$av_Offset is not an array.
;                             
Invalid $ah_Handle.
;                             
$sv_Type is not a string.
;                             
$sv_Type is an unknown data type.
;                             
Failed to allocate the memory needed for the DllStructure.
;                             
Error allocating memory for $sv_Type.
;                             
Failed to read from the specified process.
Author(s):        Nomad
Note(s):            Values returned are in Decimal formatunless a 'char' type is selected.
;                    
Set $av_Offset like this:
;                    
$av_Offset[0] = NULL (not used)
;                    
$av_Offset[1] = Offset for pointer 1 (all offsets must be in Decimal)
;                    
$av_Offset[2] = Offset for pointer 2
;                    etc...
;                    (
The number of array dimensions determines the number of pointers)
;=================================================================================================
Func _MemoryPointerRead ($iv_Address$ah_Handle$av_Offset$sv_Type 'dword')

    If 
IsArray($av_OffsetThen
        
If IsArray($ah_HandleThen
            Local $iv_PointerCount 
UBound($av_Offset) - 1
        
Else
            
SetError(2)
            Return 
0
        
EndIf
    Else
        
SetError(1)
        Return 
0
    
EndIf

    
Local $iv_Data[2], $i
    Local $v_Buffer 
DllStructCreate('dword')

    For 
$i 0 to $iv_PointerCount

        
If $i $iv_PointerCount Then
            $v_Buffer 
DllStructCreate($sv_Type)
            If @
Error Then
                SetError
(@Error 2)
                Return 
0
            
EndIf

            
$iv_Address '0x' hex($iv_Data[1] + $av_Offset[$i])
            
DllCall($ah_Handle[0], 'int''ReadProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')
            If @
Error Then
                SetError
(7)
                Return 
0
            
EndIf

            
$iv_Data[1] = DllStructGetData($v_Buffer1)

        ElseIf 
$i 0 Then
            DllCall
($ah_Handle[0], 'int''ReadProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')
            If @
Error Then
                SetError
(7)
                Return 
0
            
EndIf

            
$iv_Data[1] = DllStructGetData($v_Buffer1)

        Else
            
$iv_Address '0x' hex($iv_Data[1] + $av_Offset[$i])
            
DllCall($ah_Handle[0], 'int''ReadProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')
            If @
Error Then
                SetError
(7)
                Return 
0
            
EndIf

            
$iv_Data[1] = DllStructGetData($v_Buffer1)

        EndIf

    
Next

    $iv_Data
[0] = $iv_Address

    
Return $iv_Data

EndFunc

;=================================================================================================
; Function:            
_MemoryPointerWrite ($iv_Address$ah_Handle$av_Offset$v_Data(, $sv_Type))
Description:        Reads a chain of pointers and writes the data to the destination address.
Parameter(s):        $iv_Address The static memory address you want to start atIt must be in
;                                  hex format (0x00000000).
;                    
$ah_Handle An array containing the Dll handle and the handle of the open
;                                 process as returned by _MemoryOpen().
;                    
$av_Offset An array of offsets for the pointers.  Each pointer must have an
;                                 offset.  If there is no offset for a pointerenter 0 for that
;                                 array dimension.
;                    
$v_Data The data to be written.
;                    
$sv_Type - (optionalThe "Type" of data you intend to write at the destination
;                                 address.  This is set to 'dword'(32bit(4bytesigned integerby
;                                 default.  See the help file for DllStructCreate for all types.
Requirement(s):    The $ah_Handle returned from _MemoryOpen.
; Return 
Value(s):    On Success Returns the destination address.
;                    
On Failure Returns 0.
;                    @Error No error.
;                             
$av_Offset is not an array.
;                             
Invalid $ah_Handle.
;                             
Failed to read from the specified process.
;                             
$sv_Type is not a string.
;                             
$sv_Type is an unknown data type.
;                             
Failed to allocate the memory needed for the DllStructure.
;                             
Error allocating memory for $sv_Type.
;                             
$v_Data is not in the proper format to be used with the
;                                 "Type" selected for $sv_Type, or it is out of range.
;                             
Failed to write to the specified process.
Author(s):        Nomad
Note(s):            Data written is in Decimal formatunless a 'char' type is selected.
;                    
Set $av_Offset like this:
;                    
$av_Offset[0] = NULL (not useddoesn't matter what's entered)
;                    
$av_Offset[1] = Offset for pointer 1 (all offsets must be in Decimal)
;                    
$av_Offset[2] = Offset for pointer 2
;                    etc...
;                    (
The number of array dimensions determines the number of pointers)
;=================================================================================================
Func _MemoryPointerWrite ($iv_Address$ah_Handle$av_Offset$v_Data$sv_Type 'dword')

    If 
IsArray($av_OffsetThen
        
If IsArray($ah_HandleThen
            Local $iv_PointerCount 
UBound($av_Offset) - 1
        
Else
            
SetError(2)
            Return 
0
        
EndIf
    Else
        
SetError(1)
        Return 
0
    
EndIf

    
Local $iv_StructData$i
    Local $v_Buffer 
DllStructCreate('dword')

    For 
$i 0 to $iv_PointerCount
        
If $i $iv_PointerCount Then
            $v_Buffer 
DllStructCreate($sv_Type)
            If @
Error Then
                SetError
(@Error 3)
                Return 
0
            
EndIf

            
DllStructSetData($v_Buffer1$v_Data)
            If @
Error Then
                SetError
(8)
                Return 
0
            
EndIf

            
$iv_Address '0x' hex($iv_StructData $av_Offset[$i])
            
DllCall($ah_Handle[0], 'int''WriteProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')
            If @
Error Then
                SetError
(9)
                Return 
0
            
Else
                Return 
$iv_Address
            
EndIf
        ElseIf 
$i 0 Then
            DllCall
($ah_Handle[0], 'int''ReadProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')
            If @
Error Then
                SetError
(3)
                Return 
0
            
EndIf

            
$iv_StructData DllStructGetData($v_Buffer1)

        Else
            
$iv_Address '0x' hex($iv_StructData $av_Offset[$i])
            
DllCall($ah_Handle[0], 'int''ReadProcessMemory''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer), 'int''')
            If @
Error Then
                SetError
(3)
                Return 
0
            
EndIf

            
$iv_StructData DllStructGetData($v_Buffer1)

        EndIf
    
Next

EndFunc


;==================================================================================
; Function:            
SetPrivilege$privilege$bEnable )
Description:        Enables (or disablesthe $privilege on the current process
;                   (Probablyrequires administrator privileges to run
;
Author(s):        Larry (from autoitscript.coms Forum)
Notes(s):
http://www.autoitscript.com/forum/index.php?s=&showtopic=31248&view=findpost&p=223999
;==================================================================================

Func SetPrivilege$privilege$bEnable )
    Const 
$TOKEN_ADJUST_PRIVILEGES 0x0020
    
Const $TOKEN_QUERY 0x0008
    
Const $SE_PRIVILEGE_ENABLED 0x0002
    Local $hToken
$SP_auxret$SP_ret$hCurrProcess$nTokens$nTokenIndex$priv
    $nTokens 
1
    $LUID 
DLLStructCreate("dword;int")
    If 
IsArray($privilegeThen    $nTokens UBound($privilege)
    
$TOKEN_PRIVILEGES DLLStructCreate("dword;dword[" & ($nTokens) & "]")
    
$NEWTOKEN_PRIVILEGES DLLStructCreate("dword;dword[" & ($nTokens) & "]")
    
$hCurrProcess DLLCall("kernel32.dll","hwnd","GetCurrentProcess")
    
$SP_auxret DLLCall("advapi32.dll","int","OpenProcessToken","hwnd",$hCurrProcess[0],   _
            
"int",BitOR($TOKEN_ADJUST_PRIVILEGES,$TOKEN_QUERY),"int*",0)
    If 
$SP_auxret[0Then
        $hToken 
$SP_auxret[3]
        
DLLStructSetData($TOKEN_PRIVILEGES,1,1)
        
$nTokenIndex 1
        
While $nTokenIndex <= $nTokens
            
If IsArray($privilegeThen
                $ntokenvar
=$ntokenindex-1
                $priv 
$privilege[$ntokenvar]
            Else
                
$priv $privilege
            
EndIf
            
$ret DLLCall("advapi32.dll","int","LookupPrivilegeValue","str","","str",$priv,   _
                    
"ptr",DLLStructGetPtr($LUID))
            If 
$ret[0Then
                
If $bEnable Then
                    DLLStructSetData
($TOKEN_PRIVILEGES,2,$SE_PRIVILEGE_ENABLED,($nTokenIndex))
                Else
                    
DLLStructSetData($TOKEN_PRIVILEGES,2,0,($nTokenIndex))
                EndIf
                
DLLStructSetData($TOKEN_PRIVILEGES,2,DllStructGetData($LUID,1),(* ($nTokenIndex-1)) + 1)
                
DLLStructSetData($TOKEN_PRIVILEGES,2,DllStructGetData($LUID,2),(* ($nTokenIndex-1)) + 2)
                
DLLStructSetData($LUID,1,0)
                
DLLStructSetData($LUID,2,0)
            EndIf
            
$nTokenIndex += 1
        WEnd
        $ret 
DLLCall("advapi32.dll","int","AdjustTokenPrivileges","hwnd",$hToken,"int",0,   _
                
"ptr",DllStructGetPtr($TOKEN_PRIVILEGES),"int",DllStructGetSize($NEWTOKEN_PRIVILEGES),   _
                
"ptr",DllStructGetPtr($NEWTOKEN_PRIVILEGES),"int*",0)
        
$f DLLCall("kernel32.dll","int","GetLastError")
    EndIf
    
$NEWTOKEN_PRIVILEGES=0
    $TOKEN_PRIVILEGES
=0
    $LUID
=0
    
If $SP_auxret[0] = 0 Then Return 0
    $SP_auxret 
DLLCall("kernel32.dll","int","CloseHandle","hwnd",$hToken)
    If 
Not $ret[0] And Not $SP_auxret[0Then Return 0
    
return $ret[0]
EndFunc  ;==>SetPrivilege

;===================================================================================================

; Function........:  
_MemoryGetBaseAddress($ah_Handle$iHD)
;
Description.....:  Reads the 'Allocation Base' from the open process.
;
Parameter(s)....:  $ah_Handle An array containing the Dll handle and the handle of the open
;                               process as returned by _MemoryOpen().
;                    
$iHD - Return type:
;                       |
Hex (Default)
;                       |
Dec
;
Requirement(s)..:  A valid process ID.
;
; Return 
Value(s).:  On Success Returns the 'allocation Base' address and sets @Error to 0.
;                    On Failure Returns 0 and sets @Error to:
;                  |
Invalid $ah_Handle.
;                  |
Failed to find correct allocation address.
;                  |
Failed to read from the specified process.
;
Author(s).......:  NomadSzhlopp.
URL.............:  http://www.autoitscript.com/forum/index.php?showtopic=78834
Note(s).........:  Go to Www.CheatEngine.org for the latest version of CheatEngine.
;===================================================================================================

Func _MemoryGetBaseAddress($ah_Handle$iHexDec 0)

    
Local $iv_Address 0x00100000
    Local $v_Buffer 
DllStructCreate('dword;dword;dword;dword;dword;dword;dword')
    
Local $vData
    Local $vType

    
If Not IsArray($ah_HandleThen
        SetError
(1)
        Return 
0
    
EndIf


    
DllCall($ah_Handle[0], 'int''VirtualQueryEx''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer))

    If 
Not @Error Then

        $vData 
Hex(DllStructGetData($v_Buffer2))
        
$vType Hex(DllStructGetData($v_Buffer3))

        While 
$vType <> "00000080"
            
DllCall($ah_Handle[0], 'int''VirtualQueryEx''int'$ah_Handle[1], 'int'$iv_Address'ptr'DllStructGetPtr($v_Buffer), 'int'DllStructGetSize($v_Buffer))
            
$vData Hex(DllStructGetData($v_Buffer2))
            
$vType Hex(DllStructGetData($v_Buffer3))
            If 
Hex($iv_Address) = "01000000" Then ExitLoop
            $iv_Address 
+= 65536

        WEnd

        
If $vType "00000080" Then
            SetError
(0)
            If 
$iHexDec 1 Then
                
Return Dec($vData)
            Else
                Return 
$vData
            
EndIf

        Else
            
SetError(2)
            Return 
0
        
EndIf

    Else
        
SetError(3)
        Return 
0
    
EndIf

EndFunc   ;==>_MemoryGetBaseAddress

Func _MemoryModuleGetBaseAddress
($iPID$sModule)
    If 
Not ProcessExists($iPIDThen Return SetError(100)

    If 
Not IsString($sModuleThen Return SetError(200)

    
Local   $PSAPI DllOpen("psapi.dll")

    ;
Get Process Handle
    Local   $hProcess
    Local   $PERMISSION 
BitOR(0x00020x04000x00080x00100x0020) ; CREATE_THREADQUERY_INFORMATIONVM_OPERATIONVM_READVM_WRITE

    
If $iPID 0 Then
        Local $hProcess 
DllCall("kernel32.dll""ptr""OpenProcess""dword"$PERMISSION"int"0"dword"$iPID)
        If 
$hProcess[0Then
            $hProcess 
$hProcess[0]
        EndIf
    EndIf

    ;
EnumProcessModules
    Local   $Modules 
DllStructCreate("ptr[1024]")
    
Local   $aCall DllCall($PSAPI"int""EnumProcessModules""ptr"$hProcess"ptr"DllStructGetPtr($Modules), "dword"DllStructGetSize($Modules), "dword*"0)
    If 
$aCall[4] > 0 Then
        Local   $iModnum 
$aCall[4] / 4
        Local   $aTemp
        
For $i 1 To $iModnum
            $aTemp 
=  DllCall($PSAPI"dword""GetModuleBaseNameW""ptr"$hProcess"ptr"Ptr(DllStructGetData($Modules1$i)), "wstr""""dword"260)
            If 
$aTemp[3] = $sModule Then
                DllClose
($PSAPI)
                Return 
Ptr(DllStructGetData($Modules1$i))
            EndIf
        
Next
    
EndIf

    
DllClose($PSAPI)
    Return 
SetError(-100)

EndFunc
#endregion 
funktionen sollten selbsterklärend sein
05/21/2013 18:21 YatoDev#1277
Dankeschön :)

Muss nur noch irgendein Game raussuchen womit ich üben kann CE tutorials und OllyDBG Tuts hab ich schon
05/21/2013 22:19 WJNeeson#1278
versuchs mit AssaultCube oder einem onlinespiel (s4l, metin2, nostale)
05/22/2013 13:44 YatoDev#1279
Quote:
Originally Posted by #System View Post
versuchs mit AssaultCube oder einem onlinespiel (s4l, metin2, nostale)
ich nimm assault cube , kennst bestimmt auch die video tut reihe für c++ in der tut section ?
05/22/2013 14:26 WJNeeson#1280
ja die kenne ich, sehr empfehlenswertes tut bis auf ein paar kleine fehler
05/22/2013 14:35 YatoDev#1281
Ich find die sehr sehr gut und die paar fehler stören doch keinen dafür das man so gut ans gamehacking herrangeführt wird :)
05/23/2013 20:34 WJNeeson#1282
Quote:
Originally Posted by »FlutterShy™ View Post
Ich find die sehr sehr gut und die paar fehler stören doch keinen dafür das man so gut ans gamehacking herrangeführt wird :)
das stimmt
man sollte sich trotzdem vorher mit den grundlagen beschäftigen (was klassen, strukturen und konstruktoren angeht)
05/24/2013 08:21 lolkop#1283
Quote:
Originally Posted by #System View Post
das stimmt
man sollte sich trotzdem vorher mit den grundlagen beschäftigen (was klassen, strukturen und konstruktoren angeht)
In welcher Hinsicht wäre es hilfreich, ein genaues Verständnis von Konstruktoren und deren Funktion zu haben?

Auch wenn die anderen beiden erwähnten Punkte recht nützlich wären, sind fundierte asm Kenntnisse hier weitaus wichtiger (Insbesondere das Zusammenspiel zwischen Code, Registern, Stack und Hexdump).

Erst wenn man über diese Grundkenntnisse verfügt, macht es Sinn, sich mit der Arbeitsweise von Hochsprachen-Compilern zu beschäftigen...
05/24/2013 14:09 WJNeeson#1284
asm kenntnisse sind ohne frage wichtiger, allerdings wird in genanntem tutorial nicht direkt damit gearbeitet.
05/25/2013 00:53 meinselite#1285
Kann man eine. ini Datei passwortschützen, so das nur der jenige der das Passwort weiß die .ini Datei manuell ändern kann. Aber trotzdem AutoIt weiterhin die .ini Datei weiter beschreiben/verändern kann.

meinselite
05/25/2013 01:45 omer36#1286
Quote:
Originally Posted by meinselite View Post
Kann man eine. ini Datei passwortschützen, so das nur der jenige der das Passwort weiß die .ini Datei manuell ändern kann. Aber trotzdem AutoIt weiterhin die .ini Datei weiter beschreiben/verändern kann.

meinselite
verschlüsseln...
[Only registered and activated users can see links. Click Here To Register...]
05/25/2013 07:45 YatoDev#1287
Quote:
Originally Posted by #System View Post
das stimmt
man sollte sich trotzdem vorher mit den grundlagen beschäftigen (was klassen, strukturen und konstruktoren angeht)
Ich habe mir die videos runtergeladen und schau mir die ersten 2 oder 3 an ohne code da ich nur CE und sowas verstehen will und nachher vielleicht mal ein paar wrte in autoit verändern will
05/25/2013 12:59 prog4mermain#1288
leertaste gedrückt halten
alle 5 sec "1" drücken
jede sec "2" drücken

so etwas suche ich ... ist das mit autoit möglich ? :/
05/25/2013 14:03 omer36#1289
ja, ist es.
05/25/2013 14:19 WJNeeson#1290
Quote:
Originally Posted by prog4mermain View Post
leertaste gedrückt halten
alle 5 sec "1" drücken
jede sec "2" drücken

so etwas suche ich ... ist das mit autoit möglich ? :/
Function While, Send, TimerInit, TimerDiff