选择显示字体大小

协议型网络游戏外挂制作之外挂窗口

  上一次我们说了目标程序的启动,以及对目标程序的预处理。这一节中争取可以将外挂的窗口显出来,具体能不能说这么多,只能看着办了。

  因为我决定采用最俗的办法hook来注入线程(有时候我都觉得自己是否有必要这么做,因为debug的办法也不错),为了程序的更普遍性和更快的移植,以及简单一点,我决定还是采用hook。这里提前说一下,如果不懂汇编和程序调试的话,最好先补一下课,这在以后要用的。

  我们先来编写hook.dll部分,程序的启动部分暂时不用理会了(我以后就将那部分叫做wg.exe吧),昨天着急忘了说一声了,我让屏蔽的writeprocessmemory中的数据地址是大话9.16更新之前的最后一个版本,在9.16更新之后的版本中需要先将程序脱壳,这部分我在以后会说的,所以让大家屏蔽掉那两个写内存的操作。
对于hook.dll来说,我们准备使用f12键来激活外挂,在cb中编写dll非常简单,建立一个dll项目工程,然后就可以添加代码了。建立工程的时候一点记得选上使用c++,使用vcl,multi thread这几个选项,理由:

  1、使用c++是为了让我省点口水(我将apihook封装到了一个类里面)。

  2、使用vcl是因为我太懒惰,不想编写界面代码。

  3、使用多线程是因为程序必须。

  由于外挂主窗体在dll中,因此生成的dll就会比一般的dll大。窗体其实可以放到任何地方的,只是放到dll中比较方便而以,而且在说的时候可以更好的分开。

  以下是hook.cpp的代码:

//---------------------------------------------------------------------------
#include <vcl.h>
#include <windows.h>
#include "hookapi.h"
#include "hookform.h"
#pragma hdrstop

#pragma argsused
hhook g_hhook = null;//hook的句柄
hinstance dllhinst = null; //dll的句柄
hwnd gamehwnd; //游戏句柄
handle hthread = null; //线程句柄
hwnd wghandle = null; //外挂窗口句柄
handle gamehandle; //游戏窗口句柄,忘了有没有用
hinstance gameinstance; //游戏的,也不知道用了没用
dword threadid; //线程id

lresult callback keyboardhook(int ncode, wparam wparam, lparam lparam);//键盘hook
extern "c" __declspec(dllexport)bool enablehook(dword dwthreadid);//启动hook的函数
extern "c" __declspec(dllexport)bool disablehook();//卸载hook的函数,和上面的函数一样都是为了外部可以控制

dword winapi thread1(pvoid param);//线程函数,在该函数中,将启动外挂窗口

int winapi dllentrypoint(hinstance hinst, unsigned long reason, void* lpreserved)
{
 dllhinst = hinst;//载入dll
 return 1;
}
extern "c" __declspec(dllexport)bool enablehook(dword dwthreadid)
// 导出函数enablehook()
{
 if (g_hhook == null)
 // 安装新钩子
 {
  g_hhook = setwindowshookex(wh_keyboard, (hookproc)keyboardhook, dllhinst,
dwthreadid);
  /*记得createprocess中的参数吗?我们传进的参数是目标程序的主线程id,表示我们启动的是线程hook,而不是全局hook,这样不会对其他程序产生任何影响*/
 }
 if (g_hhook)
 {
  return true;
 }
 return false;
}
extern "c" __declspec(dllexport)bool disablehook() // 导出函数disablehook()
{
 /*卸载hook,现在暂时先这样了,其实在真实的情况下如果要做的完美的话,需要做许多事情,如果直接关闭客户端的话,这样就足够了,这个函数其实并没有任何的用处,这里仅仅是为了说明外部可以主动控制外挂的启动和关闭而已*/
 if (g_hhook != null)
 {
  unhookwindowshookex(g_hhook);
  g_hhook = null; // 卸掉新钩子
  return true;
 }
 return false;
}
lresult callback keyboardhook(int ncode, wparam wparam, lparam lparam)
{
 if (ncode >= 0)
 {
  if (wparam == 123)
   //123为f12的键码,可以查看msdn或者windows api参考方面的书找到,自己写个小程序测试也可以
  {
   if (hthread == null)
   //这里确保线程启动一次,而不是多次,每一次的启动都回引入一个外挂窗口
   {
    hthread = createthread(null, 0, thread1, null, null, &threadid);
    //启动线程,该线程很快执行完毕
   }
  }
 }
 return (callnexthookex(g_hhook, ncode, wparam, lparam));//剩下的让目标程序去处理
}

  dll中的函数是外挂程序的核心。在线程启动成功之后,就可以卸载hook了,这里只是为了简便,所以将hook仍然保留。


 


关键字 本文所属关键字

相关 与本文相关文章

分类 所有文章关键字导航

源码编程相关

Java   Asp   PHP   .Net   XML   C/C++   CGI   VB   Jsp   J2ee   J2se   J2me   EJB   Servlet   Tomcat   Resin   Struts   Weblogic   Eclipse   ANT   GUI   JMS   Web servise   IDEA   Webphere   Hibernate   Spring   Jboss   Applet   Swing   Socket   Javamail   Perl   Ajax   P2P   安全   模式   框架   测试   开源   游戏

SQL数据库相关

My-SQL   Ms-SQL   Access   DB2   Oracle   Sybase   SQLserver   索引   存储过程   加密   数据库   分页   视图  

手机无线相关

3G   Wap   CDMA   GRPS   GSM   IVR   彩信   短信   无线   增值业务

网页设计制作相关

HTML   CSS   网页配色   网页特效   Javascript   VBscript   Dreamweaver   Frontpage   JS   Web   网站设计

网站建设推广相关

建站经验   网站优化   网站排名   推广   Alexa

操作系统/服务器相关

Windows XP   Windows 2000   Windows 2003   Windows Me   Windows 9.x   Linux   UNIX   注册表   操作系统   服务器   应用服务器

图形图像多媒体相关

Photoshop   Fireworks   Flash   Coreldraw   Illustrator   Freehand   Photoimpact   多媒体   图形图像

标准 网站致力的规范

Valid CSS!

无不良内容,无不良广告,无恶意代码

Valid XHTML 1.0 Transitional

creativecommons