开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 6386|回复: 20
打印 上一主题 下一主题
收起左侧

[易语言纯源码] 取子程序真实地址

[复制链接]
跳转到指定楼层
楼主
发表于 2017-12-9 20:14:25 | 只看该作者 |只看大图 回帖奖励 |正序浏览 |阅读模式   内蒙古自治区呼和浩特市
分享源码
界面截图:
是否带模块: 纯源码
备注说明: -
本帖最后由 aiksie 于 2017-12-9 21:50 编辑

我百度搜索了下,论坛搜索了下,发现我看到的这些取子程序真实地址   源码,基本上都是有BUG的,不完全适用各种参数的子程序
一个非常简单的方法就能取到 子程序的真实地址,还用啥 汇编、API。。。。。
取子程序地址(&子程序)  这种子程序指针取到的并不是子程序真实的地址。
为啥要取子程序真实地址?  比如我需要 HOOK 某个地址, 如果我用的不是子程序真实地址,堆栈平衡就不好搞了。


原理:
每个子程序开头都是
push ebp
mov ebp,esp
只要判断 前3个字节,就能取到子程序的真实地址,用OD看一下就知道了。




  
子程序名返回值类型公开备 注
取子程序指针整数型 
参数名类 型参考可空数组备 注
子程序指针子程序指针
变量名类 型静态数组备 注
子程序地址整数型 
子程序起始整数型 
偏移整数型 
现行子程序地址整数型 
子程序地址 = 取子程序地址 (子程序指针)
子程序起始 = 子程序地址
判断循环首 ()
如果 (指针到字节集 (子程序起始, 1){ 232 })
子程序起始 = 子程序起始 + 1
偏移 = 指针到整数 (子程序起始)
子程序起始 = 子程序起始 + 4
现行子程序地址 = 子程序起始 + 偏移
如果 (指针到字节集 (现行子程序地址, 3){ 85, 139, 236 })
跳出循环 ()
子程序起始 = 子程序起始 - 4
到循环尾 ()


子程序起始 = 子程序起始 + 1

判断循环尾 ()
返回 (现行子程序地址)


i支持库列表   支持库注释   
spec特殊功能支持库


另一种方法参考:http://bbs.eyuyan.com/read.php?tid=405188&displayMode=1#3226136
原理:没有文本型参数的,子程序真实地址一般是在第一个call,有一个文本型参数的,子程序真实地址是在第二个call,有两个文本型参数的,子程序真实地址是在第3个call,以此类推。
相比较我写的,这种汇编写的 代码就少了很多。。很多
为了方便大家,他的代码我也给贴一下
  
子程序名返回值类型公开备 注
取子程序真实地址整数型 
参数名类 型参考可空数组备 注
子程序子程序指针
文本参数数量整数型
置入代码 ({ 139, 77, 12, 131, 193, 1, 139, 69, 8, 64, 128, 56, 232, 117, 250, 226, 248, 3, 64, 1, 131, 192, 5, 201, 194, 12, 0 })
' mov ecx,[ebp+12]
' add ecx,1
' mov eax,[ebp+8]
' xx:
' inc eax
' cmp byte [eax],232
' jne xx
' loop xx
' add eax,[eax+1]
' add eax,5
' leave
' ret 12
返回 (0)


取子程序指针.e (5.26 KB, 下载次数: 59)







补充内容 (2018-10-29 19:05):
心冷、鱼儿: 取子程序真实地址ASM版
  
子程序名返回值类型公开备 注
_pGetSubAddress整数型 取子程序真实地址
参数名类 型参考可空数组备 注
ptr子程序指针
' _asm{
' push ebx ;保存寄存器以免错误
' push ecx
' mov eax,dword [ebp+08h] ;获取到子程序地址
' do: ;循环标记
' inc eax ;指针+1
' cmp byte [eax],232 ;判断是不是call
' jne do ;不是就继续判断是不是call
' inc eax
' mov ecx,dword [eax] ;如果是call,获取到call的偏移地址
' add eax,04h
' lea ebx,dword [eax+ecx] ;call的地址
' cmp byte [ebx],85 ;判断是不是子程序开头
' jne do
' cmp byte [ebx+01h],139
' jne do
' cmp byte [ebx+02h],236
' jne do
' mov eax,ebx ;把指针复制给eax返回
' jmp exit ;跳出循环
' jmp do ;继续循环
' exit:
' pop ecx
' pop ebx
' leave
' ret 08h
' }end
返回 (-1)

评分

参与人数 3好评 +3 精币 +6 收起 理由
小爬虫 + 1 + 3 支持开源~!感谢分享
呵呵仙 + 1 + 3 下载看下和别的大神源码有何BUG.谢谢分享!!
回忆菌 + 1 支持开源~!感谢分享

查看全部评分


本帖被以下淘专辑推荐:

来自 6楼
 楼主| 发表于 2017-12-9 20:54:04 | 只看该作者   内蒙古自治区呼和浩特市
子程序的地址 不一定是在第一个call 或 第二个call 所以才要判断这3个字节


回复 支持 反对

使用道具 举报

结帖率:67% (2/3)
21
发表于 2019-7-11 16:03:53 | 只看该作者   广西壮族自治区河池市
谢谢,参考一下,可能用到。
子程序地址 = 取子程序地址 (子程序指针)
子程序起始 = 子程序地址
这两行,其实就是:子程序起始 =到整数(子程序指针)
回复 支持 反对

使用道具 举报

20
发表于 2019-6-9 07:32:55 高大上手机用户 | 只看该作者   广东省深圳市
能答到什么效果
回复 支持 反对

使用道具 举报

签到天数: 11 天

19
发表于 2017-12-19 13:29:33 | 只看该作者   广东省东莞市
谢谢支持开源
回复 支持 反对

使用道具 举报

结帖率:83% (5/6)
18
发表于 2017-12-15 15:34:30 | 只看该作者   四川省遂宁市
感谢分享,论坛因你更精彩
回复 支持 反对

使用道具 举报

17
发表于 2017-12-15 08:21:52 | 只看该作者   广东省梅州市
        支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 1 天

16
发表于 2017-12-15 00:13:14 | 只看该作者   江西省南昌市
感谢分享学习学习
回复 支持 反对

使用道具 举报

15
发表于 2017-12-10 11:00:16 | 只看该作者   广东省广州市
用到了,谢谢
回复 支持 反对

使用道具 举报

结帖率:89% (39/44)

签到天数: 18 天

14
发表于 2017-12-10 08:59:27 | 只看该作者   福建省宁德市
aiksie 发表于 2017-12-9 20:34
基本上适用各种子程序, 你大可用OD一观

我的意思是,这个地址同样兼容调用某些api函数传递的子程序地址吗,用作回调的
回复 支持 反对

使用道具 举报

结帖率:100% (4/4)
13
发表于 2017-12-9 22:31:47 | 只看该作者   香港特别行政区*
aiksie 发表于 2017-12-9 22:15
哪个支持库呢?

特殊命令支持库,但这个取文本类型的参数子程序会出问题。
  
子程序名返回值类型公开备 注
取子程序指针整数型 
参数名类 型参考可空数组备 注
子程序指针子程序指针
置入代码 ({ 139, 69, 8, 129, 56, 86, 87, 83, 232, 117, 10, 3, 64, 4, 131, 192, 8, 201, 194, 4, 0 })
置入代码 ({ 81, 82, 139, 77, 8, 139, 209, 139, 1, 61, 86, 87, 83, 141, 117, 97, 65, 139, 1, 61, 91, 95, 94, 194, 117, 16, 129, 121, 251, 232, 0, 0, 0, 117, 5, 139, 81, 252, 3, 209, 235, 68, 61, 86, 81, 80, 232, 116, 247, 37, 255, 255, 255, 0, 61, 243, 165, 232, 0, 117, 10, 131, 193, 7, 139, 81, 252, 3, 209, 235, 225, 37, 255, 255, 0, 0, 61, 171, 232, 0, 0, 117, 5, 131, 193, 6, 235, 15, 37, 255, 0, 0, 0, 61, 232, 0, 0, 0, 117, 8, 131, 193, 5, 139, 81, 252, 3, 209, 235, 162, 137, 85, 8, 90, 89 })
返回 (到整数 (子程序指针))

回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:[email protected]
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

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