吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 113|回复: 3
收起左侧

[经验求助] 定向求助

[复制链接]
朱朱你堕落了 发表于 2024-4-15 02:42
66吾爱币
原程序中汇编:



把这行代码跳到DLL里,



直接这么写,编译都不通过。

但是如何这么写,就可以通过了:
[C++] 纯文本查看 复制代码
DWORD dwCallData = 0x00401004;
DWORD dwRetAddr = 0x004010D8;

__declspec(naked) void __stdcall Asm_Code()
{
	__asm
	{
		call dwCallData
		push dwRetAddr
		ret
	}
}


但是这样的话,在OD中再看汇编代码,就成了如下图


虽然这么也行,但是我想问的是,有没有办法,实现原汁原味的,
即在DLL中还是还是和原程序中一样:CALL 00401004,
而非CALL [xxx]这种二次中转实现。

有没有办法呢?如果有的话,代码要怎么写?  求助solly老师 @solly

最佳答案

查看完整内容

call 立即数地址要计算偏移量,所以直接写不合适吧,间接调用更好,不然就要加到EXE中一个动态地址表中,在加载时由操作系统计算并动态修正。

免费评分

参与人数 1热心值 +1 收起 理由
董督秀 + 1 路过,学习一下。

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

solly 发表于 2024-4-15 02:42
call 立即数地址要计算偏移量,所以直接写不合适吧,间接调用更好,不然就要加到EXE中一个动态地址表中,在加载时由操作系统计算并动态修正。
solly 发表于 2024-4-15 06:18
本帖最后由 solly 于 2024-4-15 06:20 编辑

push地址变量,是要加Dword ptr [ ],立即数就不用加,用#define定义的才是立即数。
solly 发表于 2024-4-15 06:31
或者用DB定义RAW数据当指令也是可以实现你要的效果,只是看着不方便,而且自己要计算好偏移量。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则 警告:本版块禁止灌水或回复与主题无关内容,违者重罚!

快速回复 收藏帖子 返回列表 搜索

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-5-1 16:02

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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