汇编指令大全 汇编语言的指令大全

上一节我讲解了CE的使用,这一节我讲解一下windows下C/C++的在以后外挂编程中会用到的知识,内联汇编和C++MFC的DLL编写。这两个基本知识都是以后外挂中都会用到的,但是不一定是现在的高级语言编写者都会的知识。我虽然第一个语言是C但是我还是以C发家的(毕业后一直主打的还是.NET平台的C开发)。

1.C/C++中内联汇编代码:新建一个windows 控制台项目代码如下

include "stdafx.h"
extern int add(int a,int b);//方法声明
int main(int argc, _TCHAR* argv[])
{
 int re;
 re=add(1,3);//调用add方法
 printf("%d",re);
 scanf_s("%d",&re);//纯粹为了停顿查看控制台输出的结果
 return 0;
}
int add(int a,int b){
 _asm{//汇编代码块
 mov eax,a
 add eax,b
 mov b,eax
 
 }
 return b;
}

很容易看到在被调用的add方法中嵌入了汇编代码。不难看出运行结果为4。以下是图和真相

通过这个简单的内联汇编我相信大家都熟悉了C/C++中嵌入汇编代码的方式,主要上就是放在_asm{}中。当然这其中的代码和真正的汇编还是有点区别的。让我们来看一下反汇编后的代码:

extern int add(int a,int b);//方法声明
int main(int argc, _TCHAR* argv[])
{
00143A30 push ebp 
00143A31 mov ebp,esp 
00143A33 sub esp,0D0h 
00143A39 push ebx 
00143A3A push esi 
00143A3B push edi 
00143A3C lea edi,[ebp-0D0h] 
00143A42 mov ecx,34h 
00143A47 mov eax,0CCCCCCCCh 
00143A4C rep stos dword ptr es:[edi] 
00143A4E mov eax,dword ptr ds:[0014800Ch] 
00143A53 xor eax,ebp 
00143A55 mov dword ptr [ebp-4],eax 
 int re;
 re=add(1,3);//调用add方法
00143A58 push 3 
00143A5A push 1 
00143A5C call add (01411D6h) 
00143A61 add esp,8 
00143A64 mov dword ptr [re],eax 
 printf("%d",re);
00143A67 mov esi,esp 
00143A69 mov eax,dword ptr [re] 
00143A6C push eax 
00143A6D push 1458A8h 
00143A72 call dword ptr ds:[1492BCh] 
00143A78 add esp,8 
00143A7B cmp esi,esp 
00143A7D call __RTC_CheckEsp (01411E0h) 
 scanf_s("%d",&re);//纯粹为了停顿查看控制台输出的结果
00143A82 mov esi,esp 
00143A84 lea eax,[re] 
00143A87 push eax 
00143A88 push 1458A8h 
00143A8D call dword ptr ds:[1492B8h] 
00143A93 add esp,8 
00143A96 cmp esi,esp 
00143A98 call __RTC_CheckEsp (01411E0h) 
 return 0;
00143A9D xor eax,eax 
}

这是main函数反汇编过来的。下面我们看看add函数的反汇编代码:

int add(int a,int b){
001417A0 push ebp 
001417A1 mov ebp,esp 
001417A3 sub esp,0C0h 
001417A9 push ebx 
001417AA push esi 
001417AB push edi 
001417AC lea edi,[ebp-0C0h] 
001417B2 mov ecx,30h 
001417B7 mov eax,0CCCCCCCCh 
001417BC rep stos dword ptr es:[edi] 
 _asm{//汇编代码块
 mov eax,a
001417BE mov eax,dword ptr [a] 
 add eax,b
001417C1 add eax,dword ptr [b] 
 mov b,eax
001417C4 mov dword ptr [b],eax 
 
 }
 return b;
001417C7 mov eax,dword ptr [b] 
}

从中可以看出C中内联汇编和汇编指令还是有点区别的。在main主函数中call add这个就是调用add函数,再往call add前面看,大家可以看到被调用的add参数被从右到左的放到堆栈中去了(汇编基础知识)。至于add函数的返回值就放到通用寄存器eax中。汇编中函数放回值都是放到eax中,add函数中有这样一行汇编mov eax,dword ptr [b]。其中 call add后面有add esp,8这个是为了保持堆栈平衡。这是高级语言中我们不需要关注的东西,其它的就不多说了。更多的还是自己去掌握汇编吧,毕竟汇编知识还是比较丰富的,三言两语讲不清。这里我只是让大家能看懂大致的脉络。在外挂编程中我们很多时候是通过内联汇编去call游戏线程中的某个方法,例如我们call补金疮药或者魔药的过程,可以实现自动喝药。这是基本的外挂过程。

2.C++MFC DLL的编写:从其他语言过来可能不知道C++写DLL。C++DLL有很多种方式去写。这里我就介绍MFC DLL。它最容易上手。DLL的用处是什么呢??其它用处我就不说了,只说在外挂中什么作用。在外挂中我们需要进程注入。前面讲过,每个程序都有一个自己私有的4G进程空间(32位系统,0x00000000~0x7FFFFFFF空间属于应用程序的空间,高地址空间是属于操作系统的),起到保护进程的作用。那么我们怎么控制另个一程序呢??这时候我们就要想到将我们的代码放到被控制的进程空间中去,可是正常情况下,在一个程序中正常情况下是访问不到另一个程序进程空间的。这时候我们可以用进程注入的方式将我们的DLL注入到游戏进程空间中去。我比较常用的两种方式其一是通过WriteProcessMemory的方式直接写进去,另一种方式是通过钩子的形式注入。这两种注入方式在后面的章节中再做介绍。开始去写一个DLL在项目解决方案上面添加项目(我用的是vs2012).然后选择C++,在选择MFC,选择MFC DLL.在源文件后面添加一个add方法;

int add(int a,int b){
 return a+b;
}

然后一步非常重要需要暴露出来。在def文件中放入这个函数名称

def中的代码是:

; MFCLibrary1.def : 声明 DLL 的模块参数。
LIBRARY
EXPORTS
 ; 此处可以是显式导出
 add

这样就将add函数暴露到了DLL外面。这样在exe中就可以调用了;

exe程序中的调用代码如下:

// ASMTest.cpp : 定义控制台应用程序的入口点。
//
include "stdafx.h"
pragma comment(lib,"MFCLibrary1.lib")
extern int add(int a,int b);
int main(int argc, _TCHAR* argv[])
{
 int re=3;
 re=add(1,3);//调用add方法
 printf("%d",re);
 scanf_s("%d",&re);//纯粹为了停顿查看控制台输出的结果
 return 0;
}
//int add(int a,int b){
//
// _asm{//汇编代码块
// mov eax,a
// add eax,b
// mov b,eax
// 
// }
// return b;
//}
pragma comment(lib,"MFCLibrary1.lib")这是其中一种调用方式。别忘了声明extern int add(int a,int b);否则找不到add方法。
这样,实现了一个DLL和对DLL的调用。为后面注入DLL做好铺垫。

作者:egojit

原文:http://www.cnblogs.com/egojit/archive/2013/06/15/3135607.html

本文来自“无人街七号”用户投稿,该文观点仅代表作者本人,不代表华夏信息网立场,本站不对文章中的任何观点负责,内容版权归原作者所有、内容只用于提供信息阅读,无任何商业用途。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站(文章、内容、图片、音频、视频)有涉嫌抄袭侵权/违法违规的内容,请发送邮件至1470280261#qq.com举报,一经查实,本站将立刻删除、维护您的正当权益。如若转载,请注明出处:http://www.xxxwhg.com/cs/59462.html

上一篇 2023-02-03 03:18:59
下一篇 2023-02-03 01:50:58

相关推荐

  • 锁手机快捷指令是什么意思

    果粉之家,专业苹果手机技术研究十年!您身边的苹果专家~如今,手机已经渗透进我们生活里的方方面面,每个人的手机里或多或少都有不想让别人知道的隐私。但是当遇到必须要把手机借给其他人使用时,该怎么避免别人“不小心”看到自己的隐私呢?方法一:快捷指令上锁,就是给Ap

    2023-05-19 06:00:02
    259
  • 手机什么是快捷指令功能

    这天半夜两三点,机哥我正拿着纸巾吹着空调,准备舒舒服服的看场外语电影。可还没3分钟,八弟的“午夜凶铃”就打破了机哥我酝酿许久的氛围。拿起手机一看才知道,淦,八弟又出事了...八弟说,女神要求他必须每天早上五点二十分,给她发一条“520”信息,以此来证明八弟足够爱

    2023-05-02 09:30:02
    279
  • 手机排水指令是什么意思

    电子产品触碰到水有多容易,一不小心忘记摘下来,就可能会带着AppleWatch洗手、洗澡、甚至游泳,但是Apple称,AppleWatchSeries1和第一代AppleWatch具有防溅功能;但是,不建议将它们淹没。AppleWatchSeries2和更新的AppleWatch则真的具有防水功能,但也仅限于浅水活动。Appl

    2023-04-28 08:00:03
    334
  • 手机有什么电话指令功能

    对于安卓手机,虽然现在使用的用户们非常多,可是对安卓手机能彻底了解的用户们肯定不是很多,尤其是安卓手机拨号键代码,也许说出来大家就会知道,但是大家是否能独立运用呢?今天巴士就为大家总结了安卓拨号键代码,感兴趣的机友们可以来了解下。【安卓拨号键代码总结】*27

    2023-04-20 06:00:02
    219