亚洲春色中文字幕久久久-三上亚,一吻二脱三床四吻胸,国产真实伦对白视频全集,在线毛片观看,精品成品入口黄网,国产毛aⅴ片久久久,亚洲AV色香蕉一区二区三区老师,萧皇后A级艳片,色情日本视频更新,99久久亚洲精品日本无码

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 2725|回復(fù): 0
收起左側(cè)

VB寫(xiě)的查找特征碼的模塊

[復(fù)制鏈接]
ID:108531 發(fā)表于 2016-3-12 16:02 | 顯示全部樓層 |閱讀模式
示例:
'定義游戲路徑,以及各種特征碼
Private Const Game_Path = "D:\Game\7fgame\7FGameApp.dll"
Private Const Game_Base_Feature_Codes = "90909081EC780500008B0D"
Private Const Code_Check_Feature_Codes = "50518BCBE86C0200008B4C242C"
Private Const Code_Check1_Feature_Codes = "50518BCBE8A80100008B4C2428"
Private Const Date_Check_Feature_Codes = "83C41485C07414FFD3"
Private Const Date_Check1_Feature_Codes = "03C283C41C3BC874"
Private Const Date_Check2_Feature_Codes = "0F858700000033DB3BD3895C"
Private Const Room_On_Feature_Codes = "85C07408C74424100000"
Private Const Hall_Check_Feature_Codes = "C744242C140000008B48"
Private Const Room_Check_Feature_Codes = "8D94244E040000C1E902F3"
Private Const Game_Check_Feature_Codes = "8954242E894424328D93"
Private Const Date_Lock_Feature_Codes = "66ABAA8B45103BC80F"
Private Const Date_Lock1_Feature_Codes = "8B531033ED85D2C744241401"
'定義SCO結(jié)構(gòu)體變量
Private SCO As Sanguo_Check_Offset
'過(guò)程搜索游戲個(gè)特征碼的偏移
Private Sub Call_Search_Offset()
Dim FileBin() As Byte
    ReadFileBin FileBin, Game_Path
    SCO.Game_Base_offset = Find_Location(FileBin, Game_Base_Feature_Codes, 1)
    SCO.Code_Check_offset = Find_Location(FileBin, Code_Check_Feature_Codes, 7)
    SCO.Code_Check1_offset = Find_Location(FileBin, Code_Check1_Feature_Codes, 7)
    SCO.Date_Check_offset = Find_Location(FileBin, Date_Check_Feature_Codes, -3)
    SCO.Date_Check1_offset = Find_Location(FileBin, Date_Check1_Feature_Codes)
    SCO.Date_Check2_offset = Find_Location(FileBin, Date_Check2_Feature_Codes, 3)
    SCO.Room_On_offset = Find_Location(FileBin, Room_On_Feature_Codes, -1)
    SCO.Hall_Check_offset = Find_Location(FileBin, Hall_Check_Feature_Codes, 8)
    SCO.Room_Check_offset = Find_Location(FileBin, Room_Check_Feature_Codes, &H16D)
    SCO.Game_Check_offset = Find_Location(FileBin, Game_Check_Feature_Codes, -&HF)
    SCO.Date_Lock_offset = Find_Location(FileBin, Date_Lock_Feature_Codes, 0)
    SCO.Date_Lock1_offset = Find_Location(FileBin, Date_Lock1_Feature_Codes, 4)
    Show_List_Result
    Label1.Caption = "掃描完畢!"
End Sub
以下是模塊:

Option Explicit
Private Declare Function OpenProcess Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
Private Declare Function ReadProcessMemory Lib "kernel32.dll" (ByVal hProcess As Long, ByVal lpBaseAddress As Long, ByRef lpBuffer As Any, ByVal nSize As Long, ByRef lpNumberOfBytesWritten As Long) As Long
Private Const PROCESS_ALL_ACCESS = &H1F0FFF
'以二進(jìn)制形式讀取文件存放在FileBin()數(shù)組中
Public Sub ReadFileBin(FileBin() As Byte, FilePath As String)
    Open FilePath For Binary As #1
    ReDim FileBin(FileLen(FilePath))
    While Not EOF(1)
        Get #1, , FileBin
    DoEvents
    Wend
    Close #1
End Sub
'讀取內(nèi)存進(jìn)程代碼存放在FileBin()數(shù)組中
Public Sub ReadExeBin(FileBin() As Byte, Pid As Long)
Dim Hand As Long
    Hand = OpenProcess(PROCESS_ALL_ACCESS, False, Pid)
        If Hand Then
            ReDim FileBin(61440) As Byte
            ReadProcessMemory Hand, &H971000, FileBin(0), 61440, 0&
        End If
    CloseHandle Hand
End Sub
'將要比較的特征碼轉(zhuǎn)化為Byte數(shù)組并存放在s2中
Private Sub StrBin(ByVal s1 As String, s2() As Byte)
Dim i As Long
    ReDim s2(Len(s1) / 2 - 1) As Byte
    For i = 0 To UBound(s2)
        s2(i) = CByte("&H" & Mid(s1, i * 2 + 1, 2))
    Next i
End Sub
'從s1中查找出特征碼,并返回該特征碼的首位置
Private Function StrStr(ByRef s1() As Byte, ByRef s2() As Byte) As Long
Dim c1 As Long, c2 As Long, i As Long, j As Long
    c1 = UBound(s1): c2 = UBound(s2)
    If c2 > c1 Then StrStr = -1: Exit Function
    For i = 0 To c1 - c2
        For j = 0 To c2 - 1
            If (s1(i + j) <> s2(j)) Then Exit For
            If (j = c2 - 1) Then StrStr = i: Exit Function
        Next j
    Next i
    StrStr = -1
End Function
'Location:位置
'此函數(shù)的功能:返回特征碼最后一個(gè)位置+j偏移的位置
Public Function Find_Location(ByRef FileBin() As Byte, s1 As String, Optional j As Long = 0) As Long
Dim i As Long, Str As String, s2() As Byte
        StrBin s1, s2
        i = StrStr(FileBin, s2)
        If i = -1 Then
            Find_Location = -1: Exit Function
        End If
        Find_Location = i + UBound(s2) + j
End Function


相關(guān)帖子

回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表