请选择 进入手机版 | 继续访问电脑版

 找回密码
 立即注册
查看: 172|回复: 0

【易语言 源码】 通过特征码搜索内存地址源码

[复制链接]

48

主题

9

回帖

206

积分

管理员

积分
206
发表于 2024-12-16 09:21:02 | 显示全部楼层 |阅读模式
  1. .版本 2
  2. .支持库 spec

  3. .程序集 窗口程序集_启动窗口
  4. .程序集变量 进程句柄, 整数型

  5. .子程序 __启动窗口_创建完毕


  6. 进程句柄 = 0  ' ???没有句柄?我搜什么?

  7. .子程序 搜索, 整数型
  8. .参数 通配符, 文本型
  9. .局部变量 搜索内容, 字节集, , , 欲搜索的内容  其他类型-需自行转换为字节集类型
  10. .局部变量 字节集段, 通配符集, , "0"
  11. .局部变量 长度, 整数型
  12. .局部变量 内存地址, 整数型
  13. .局部变量 内存块信息, MEMORY_BASIC_INFORMATION
  14. .局部变量 数据缓冲区, 字节集
  15. .局部变量 找到位置, 整数型
  16. .局部变量 计次, 整数型
  17. .局部变量 算偏移, 整数型
  18. .局部变量 完全匹配, 逻辑型

  19. .如果真 (进程句柄 = 0)
  20.     返回 (0)
  21. .如果真结束
  22. 搜索内容 = 通配符处理 (通配符, 字节集段, 算偏移)
  23. 长度 = 取字节集长度 (搜索内容)
  24. .判断循环首 (VirtualQueryEx (进程句柄, 内存地址, 内存块信息, 28) ≠ 0)
  25.     .如果真 (内存块信息.Protect = 4 且 内存块信息.Type = 131072)
  26.         数据缓冲区 = 取空白字节集 (内存块信息.RegionSize)
  27.         .如果真 (ReadProcessMemory (进程句柄, 内存地址, 数据缓冲区, 内存块信息.RegionSize, 0))
  28.             找到位置 = 寻找字节集 (数据缓冲区, 搜索内容, )
  29.             .判断循环首 (找到位置 ≠ -1)
  30.                 完全匹配 = 真
  31.                 .计次循环首 (取数组成员数 (字节集段), 计次)
  32.                     .如果 (数据匹配 (数据缓冲区, 找到位置, 字节集段 [计次]))

  33.                     .否则
  34.                         完全匹配 = 假
  35.                     .如果结束

  36.                 .计次循环尾 ()
  37.                 .如果真 (完全匹配)
  38.                     调试输出 (“找到了一个地址 > ” + 取文本右边 (“0000000” + 取十六进制文本 (内存地址 + 找到位置 - 算偏移), 8))
  39.                 .如果真结束
  40.                 找到位置 = 寻找字节集 (数据缓冲区, 搜索内容, 找到位置 + 长度)
  41.             .判断循环尾 ()
  42.         .如果真结束

  43.     .如果真结束
  44.     内存地址 = 内存地址 + 内存块信息.RegionSize
  45.     处理事件 ()
  46. .判断循环尾 ()
  47. 返回 (0)

  48. .子程序 数据匹配, 逻辑型
  49. .参数 缓冲区数据, 字节集
  50. .参数 找到位置, 整数型
  51. .参数 字节集段, 通配符集
  52. .局部变量 长度, 整数型

  53. 长度 = 取字节集长度 (字节集段.数据)
  54. 返回 (取字节集中间 (缓冲区数据, 字节集段.位置 + 找到位置, 长度) = 字节集段.数据)

  55. .子程序 通配符处理, 字节集
  56. .参数 通配符, 文本型
  57. .参数 处理好的字节集组, 通配符集, 参考 数组
  58. .参数 计算偏移用的, 整数型, 参考
  59. .局部变量 待处理文本, 文本型
  60. .局部变量 文本位置, 整数型
  61. .局部变量 任何字节, 逻辑型
  62. .局部变量 当前字节, 文本型
  63. .局部变量 临时, 通配符集
  64. .局部变量 数组, 通配符集, , "0"
  65. .局部变量 寻找的内容, 字节集
  66. .局部变量 计次, 整数型
  67. .局部变量 最长长度, 整数型
  68. .局部变量 当前长度, 整数型
  69. .局部变量 数组位置, 整数型

  70. ' 先把通配符转为字节集并记录位置
  71. 待处理文本 = 删全部空 (通配符)
  72. .变量循环首 (1, 取文本长度 (待处理文本), 2, 文本位置)
  73.     当前字节 = 取文本中间 (待处理文本, 文本位置, 2)
  74.     .如果 (当前字节 = “??”)
  75.         .如果真 (临时.数据 ≠ {  })
  76.             临时.位置 = 文本位置 ÷ 2 - 取字节集长度 (临时.数据) + 1
  77.             加入成员 (数组, 临时)
  78.             临时.数据 = {  }
  79.         .如果真结束

  80.     .否则
  81.         临时.数据 = 临时.数据 + 到十进制 (当前字节)
  82.     .如果结束

  83. .变量循环尾 ()
  84. .如果真 (临时.数据 ≠ {  })
  85.     临时.位置 = 文本位置 ÷ 2 - 取字节集长度 (临时.数据) + 1
  86.     加入成员 (数组, 临时)
  87. .如果真结束


  88. ' 然后筛选最少结果的字节集段,只是简单演示我知道我这种方法有时候会拖累搜索的速度
  89. ' 但只是做个例子而已,之后你们可以自己优化
  90. .计次循环首 (取数组成员数 (数组), 计次)
  91.     当前长度 = 取字节集长度 (数组 [计次].数据)
  92.     .如果真 (最长长度 ≤ 当前长度)
  93.         .如果 (最长长度 = 当前长度)
  94.             .判断开始 (当前长度 ≥ 4)
  95.                 .如果真 (到整数 (数组 [计次].数据) > 到整数 (寻找的内容))
  96.                     寻找的内容 = 数组 [计次].数据
  97.                     数组位置 = 计次
  98.                 .如果真结束

  99.             .判断 (当前长度 ≥ 2)
  100.                 .如果真 (到短数 (数组 [计次].数据) > 到短数 (寻找的内容))
  101.                     寻找的内容 = 数组 [计次].数据
  102.                     数组位置 = 计次
  103.                 .如果真结束

  104.             .默认
  105.                 .如果真 (数组 [计次].数据 [1] > 寻找的内容 [1])
  106.                     寻找的内容 = 数组 [计次].数据
  107.                     数组位置 = 计次
  108.                 .如果真结束

  109.             .判断结束

  110.         .否则
  111.             寻找的内容 = 数组 [计次].数据
  112.             最长长度 = 取字节集长度 (数组 [计次].数据)
  113.             数组位置 = 计次
  114.         .如果结束

  115.     .如果真结束

  116. .计次循环尾 ()
  117. .如果真 (数组位置 ≠ 0)
  118.     计算偏移用的 = 数组 [数组位置].位置
  119.     删除成员 (数组, 数组位置, 1)
  120. .如果真结束
  121. ' 后面还有几段过滤的,上面的代码是减少搜索得到的结果 简单粗暴
  122. ' 至于下面怎么过滤优化自己看着办吧 | 第一个 万一遇到最长的字节集 全部是0怎么办? 第二个 最长的不一定结果最少的(同上) 第三个 最长的搜索效率不一定是最快的



  123. ' 接下来就是调整好其他字节集段的位置
  124. .计次循环首 (取数组成员数 (数组), 计次)
  125.     数组 [计次].位置 = 数组 [计次].位置 - 计算偏移用的
  126. .计次循环尾 ()
  127. ' 完毕!
  128. 处理好的字节集组 = 数组
  129. 返回 (寻找的内容)

  130. .子程序 到十进制, 字节集
  131. .参数 str, 文本型
  132. .局部变量 a, 文本型
  133. .局部变量 b, 文本型
  134. .局部变量 c, 文本型

  135. a = 到大写 (str)
  136. b = 取文本中间 (a, 2, 1)
  137. .如果 (b = “”)
  138.     b = 取文本左边 (a, 1)
  139. .否则
  140.     c = 取文本左边 (a, 1)
  141. .如果结束
  142. 返回 (到字节集 (到字节 ((寻找文本 (“0123456789ABCDEF”, c, , 真) - 1) × 16 + 寻找文本 (“0123456789ABCDEF”, b, , 真) - 1)))

  143. .子程序 到整数, 整数型
  144. .参数 字节集, 字节集

  145. 返回 (取字节集数据 (取字节集左边 (字节集, 4), #整数型, ))

  146. .子程序 到短数, 整数型
  147. .参数 字节集, 字节集

  148. 返回 (取字节集数据 (取字节集左边 (字节集, 2), #短整数型, ))

  149. .子程序 _按钮1_被单击

  150. 搜索 (编辑框1.内容)  ' 编辑框,按钮自行创建!
复制代码


您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|叶子资源网

GMT+8, 2025-4-27 11:01 , Processed in 0.094225 second(s), 30 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表