用这个工具可以很简单地生成中间DLL的源代码,在源代码里调用Windows标准DLL的显示函数之前,替换英语字符串为中文,可能是实现汉化的一种新方法。
/ w" K4 f0 Y( ]& L! t- K) s9 W7 @+ j中间DLL里的替换逻辑可以写成查找外置字符串替换表的形式,即发现送给显示函数为Hello,到字符串替换表查找后,发现Hello的对应中文为:你好,就把 你好这2个字送给显示函数,对不同的游戏,准备不同的替换表就行了。
2 a! {3 W& M% b8 N
) ^, Z& @! X2 J% ]
* o- [( {8 V& y; O
6 D3 ]# m" J- P" Q) z一、简介 ) \! ` E; f2 U( }. J/ X7 g. q# t Z
3 O; E, W& l+ s AheadLib 是用来生成一个特洛伊DLL的工具,用于分析DLL中的函数参数调用(比如记录Socket send了什么等等)、更改函数功能(随心所欲了:)、更改界面功能(比如在Hook里面生成一个按钮,截获事件等等)。 ! M2 g6 x4 ]$ [) I/ h
! ^. @- A9 d+ e5 z
二、使用 6 z) m8 r8 r: I. Z$ G/ u' t" r6 q8 ~3 d
5 B1 f l5 B/ Z
1.用 AheadLib 打开要模拟的 DLL,生成一个 CPP 文件。
; b. l* M) M: M 2.用 Visual Studio 6.0/.NET 建立一个 DLL 工程,把这个 CPP 文件加入到项目中。 h0 C$ @, u; b* A/ j
3.使用 Release 方式编译,生成的 DLL 将和原来的 DLL 具有一模一样的导出函数,并且能顺利把这些函数转发到原来的函数中。 & J# ~ ~9 e6 Q4 ~& a* i
4.AheadLib 还可以生成 Hook 代码,用于截取当前进程的所有消息,这样就可以随心所欲地处理各种消息了 (修改第三方程序界面功能的好助手)。
9 [1 e( i/ r7 [- w8 h% z- x% x9 S+ p5 T. w
三、备注 7 w" X& N. N# C$ Q$ _0 o
% \* F% [& m H( X& W 1.如果导出函数过多,在 Visual Studio 6.0 中,如果出现编译错误,请在项目属性关闭与编译头功能。
M: }4 q" c+ q; W4 |; h( X& S 2.如果是 C++ 、C __stdcall、C __fastcall 的方式导出的话,生成的函数声明将会还原成原代码级别(可能需要修改才能编译,比如导出C++类的情况)。此时使用 __declspec(dllexport) 导出 ——不能指定导出序号。 7 Y7 d9 Y/ S3 ]4 q! x$ U) Y% u# X
3.如果是 NONAME 或者 C _CDECL 方式导出(比如 DEF 导出,大多数Windows DLL都是这种情况,比如WS2_32等等),则使用#pragma comment(linker, "/EXPORT:...)导出,且指定导出序号。
9 {) b; |6 R R 4.如果系统中没有 DbgHelp.dll,将无法识别 C++ 模式的导出。 5 z+ M. r' j( N$ C) b
5 o' `! |; \; [7 |主页:http://Yonsm.reg365.com 3 }1 X5 V O7 C v e
邮件:[email protected] / W/ {! S0 \2 I
源码:如果需要,请访问作者主页 |