设为首页收藏本站淘宝杂货铺

从F到0 - From F to 0

 找回密码
 注册已关闭
搜索
查看: 2541|回复: 2
收起左侧

易语言置入代码实现的文本型变量的数据恢复,字符串指针地址反方向移动查询取值实现

[复制链接]
发表于 2018-9-23 19:06:19 | 显示全部楼层 |阅读模式

  1. .版本 2
  2. .支持库 spec
  3. .程序集 程序集1
  4. .子程序 _启动子程序, 整数型, , 请在本子程序中放置易模块初始化代码

  5. _临时子程序 ()  ' 在初始化代码执行完毕后调用测试代码
  6. 返回 (0)  ' 可以根据您的需要返回任意数值
  7. .子程序 _临时子程序
  8. .局部变量 文本, 文本型
  9. ' 本名称子程序用作测试程序用,仅在开发及调试环境中有效,编译发布程序前将被系统自动清空,请将所有用作测试的临时代码放在本子程序中。 ***注意不要修改本子程序的名称、参数及返回值类型。
  10. 文本 = “Hello World! 中文测试”
  11. 置文本指针 (文本, 取变量数据地址 (文本) + 6)
  12. 调试输出 (“恢复前”, 文本)
  13. 输出调试文本 (文本数据恢复 (文本))


  14. 调试输出 (“恢复后”, 文本)

  15. .子程序 文本数据恢复, 逻辑型, 公开, 对文本数据指针地址循环减小访问,直到遇到0则修改文本指针为该指针的+1,成功返回真失败返回假。
  16. .参数 欲恢复的字符串, 文本型, 参考, 仅适用于被其他置入代码修改文本指针实现删除的字符串开头的一部分,不一定能找回,找回的部分可能是其他数据,向该指针写入可能会崩溃。
  17. 置入代码 ({ 139, 69, 8, 139, 24, 139, 211, 138, 11, 10, 201, 117, 5, 67, 137, 24, 235, 3, 75, 235, 242, 59, 218, 115, 7, 184, 1, 0, 0, 0, 235, 5, 184, 0, 0, 0, 0, 201, 194, 4, 0 })
  18. ' mov eax,[ebp+8]
  19. ' mov ebx,[eax]
  20. ' mov edx,ebx
  21. ' START:
  22. ' mov cl,[ebx]
  23. ' .if cl == 0
  24. ' inc ebx
  25. ' mov [eax],ebx
  26. ' jmp ASM_END
  27. ' .endif
  28. ' dec ebx
  29. ' JMP START
  30. ' ASM_END:
  31. ' .if  ebx < edx
  32. ' mov eax,1
  33. ' .elseif
  34. ' mov eax,0
  35. ' .endif
  36. ' leave
  37. ' retn 4
  38. 返回 (假)
  39. .子程序 置文本指针, , 公开, 修改文本字符串的内存地址指针
  40. .参数 文本, 文本型, 参考, 文本可以为空
  41. .参数 指针, 整数型, , 地址必须真实有效,否则程序可能会崩溃。
  42. 置入代码 ({ 139, 69, 8, 139, 93, 12, 137, 24, 201, 194, 8, 0 })
  43. ' mov eax,[ebp+8]
  44. ' mov ebx,[ebp+12]
  45. ' mov [eax],ebx
  46. ' leave
  47. ' retn 8
复制代码

相关帖子

发表于 2018-9-23 23:19:40 | 显示全部楼层
这也可以???6666....
您需要登录后才可以回帖 登录 | 注册已关闭

本版积分规则

QQ|手机版|Archiver|从F到0 ( 蒙ICP备17002595号-1 )
蒙公网安备15010402000325号

腾讯云安全认证

GMT+8, 2024-4-28 19:41 , Processed in 1.283074 second(s), 20 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2021, Tencent Cloud.

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