游戏对战平台,在没有了解的情况下,总是给人一种很神秘的感觉,然而,当你对socket的理解到达一定程度之后,你就不会再觉得神秘。
       用一句话来总结这种技术:虚拟局域网(VLAN)。

实现这种平台,主要是客户端,而客户端有很多种方法,就我所了解,可以用面三种方法实现:
    1. 替换Windows socket DLL,然后,你想做什么就做什么吧。
    2. 进程注入,HOOK WinSock函数调用。
    3. 虚拟网卡驱动。

其实,前两种技术,也是许多木马使用的方法。正所谓技术是一面双刃剑,看你要用到什么地方了。现在的对战平台,就我了解,使用的是后两种方法。大多数是第2中----毕竟,驱动在有些用户权限下是无法安装和使用的。
       浩方,QQ对战平台,VS等,基本上都是采用第二中方法。第三种方法,见过一个。效果还可以。

下面介绍一下我研究时写的平台结构:
       整个平台包含两个组成部分:服务端和客户端。
       通讯方式:全部采用UDP通讯。

零、基础知识:
     如果你有志与开发这样一个类似平台,我建议你先了解以下内容:
     a. Windows协议栈的简单了解。
     b. WinSock通讯。
     c. HOOK技术。
     d. 线程,进程之间的数据交换和通讯。
     e. 线程之间的同步。
     f. 线程注入。
     e. 其它的一些Windows开发的基础知识,就不一一列举了。

这些都是基本功,基本功如何,决定了你能走到哪一步。

一、服务端:
      服务器在逻辑上被分为了两部分:
      a. 用户服务器: 虚拟IP分配,用户管理,消息通知等。
      b. 转发服务器: 进行必要的数据转发(无法进行P2P通讯的)

二、客户端:
     客户端也包含两个部分,
     a. 客户端EXE: 负责进行进程注入,与服务器通讯。
     b. 客户端DLL: 负责进行socket函数替换和处理。

注:这里,服务器和客户端都有KeepAlive的功能,如果在一定时间内未收到包,则认为用户已经掉线。

三、主要工作流程:
     这里主要对用户登陆和登出,启动和退出游戏这连个主要环节进行总结。

a. 用户登陆过程
     +-------------------------------+
      | 输入用户名和密码,登陆 |
     +-------------------------------+
                     |
     +-----------------------------+
     |   发送登陆包到服务器    |
     +-----------------------------+
                    |
     +-----------------------------+
     |        处理反馈信息        |
     +------------------------------+
                |
           <登陆成功>   ------------失败-------------> [提示用户]
                |
     +------------------------------+
     | 请求其他在线用户信息 |
     +-----------------------------+
   用户登陆信息客户端处理流程

+--------------------+
         | 收到用户登陆包 |
         +--------------------+
                  |
             <数据解析>----------------> [丢弃不合法数据包]
                  |
         <验证用户登陆信息> -----------失-败-------+
                  |                                                    |
                  |                                                      |
    +----------------------------+        +---------------------------------+
    |      分配虚拟IP地址        |       |反馈登陆失败信息到客户端|
    +----------------------------+       +-------------------------------+

|
    +--------------------------------------+
    |    添加用户到在线用户列表     |
    +--------------------------------------+
    |反馈用户登陆成功,服务器信息|
    |                   到客户端                | (* 这里包含了转发服务器信息)
    +--------------------------------------+
                           |
       +------------------------------+
       |广播信息到所有登陆用户|
       +-----------------------------+

用户登陆信息服务端处理流程(由用户服务器处理)

b. 用户登出过程
     
             +--------------------+
             | 收到用户退出包 |
             +--------------------+
                       |
                   <数据解析>----------------> [丢弃不合法数据包]
                       |
             +----------------------+
             < 查找将用户信息 >   ------------> 未找到,不处理
             +---------------------+
                       |
       +----------------------------------------+
       |   将用户从在线用户列表中删除   |
       +---------------------------------------+
                       |
       +------------------------------------+
       |     回收虚拟IP给其他用户       |
       +-----------------------------------+
                       |
       +-------------------------------------------+
       | 广播用户登出信息到所有在线用户 |
       +-------------------------------------------+

服务器处理过程

<判断用户是否在游戏中>   -----------是------------> 提示用户
                  |
                否
                 |
       +-----------------------------+
       |   发送登出包到服务器    |
       +-----------------------------+
                  |
       +-------------------------+
       |          退出                |
       +-------------------------+
            客户端处理过程

c. 游戏启动过程

+--------------------------+
       |      创建内存共享      |
       | (CreateFileMapping) |
       |   写入游戏当前配置   |
       | (包含在线用户信息和 |
       |    转发服务器信息)   |
       +--------------------------+
                 |
       +-----------------------------+
       | 根据用户选择启动游戏 |
       | (调用CreateProcess) |
       +----------------------------+
                 |
          <是否启动成功> ------------否----------> [提示用户失败信息]
                 |
       +-----------------------------+
       | 将游戏DLL注入到游戏 |
       +----------------------------+
                  |
    +--------------------------------+
    |     读取游戏的配置信息     |
    +-------------------------------+
                  |
    +-----------------------------+
    |       连接转发服务器       |
    +-----------------------------+
                  |
    +--------------------------------------+
    | 游戏DLL HOOK所有网络函数 |
    |   (采用Inline Hook方式)          |
    +-------------------------------------+
                  |
    +----------------------------------+
    |   OK, now game start OK!   |
    +----------------------------------+

d. 游戏退出过程

+----------------------------------------------+
   | 游戏DLL释放所有已经HOOK的函数 |
   +---------------------------------------------+
                  |
   +-----------------------------------+
   |     关闭内存共享文件            |
   +-----------------------------------+
                  |
   +--------------------------------------+
   |     发送退出包到转发服务器      |
   +--------------------------------------+

四、游戏DLL工作过程:

整个平台运作过程中,最主要的部分恐怕就是这个部分了,所以,单独将这部分的结构进行一下说明。
   
     在这里,我将处理过程分成了三个层,每个层分别完成不同的功能:网络HOOK层,自定义协议栈,网络数据传输层。
     首先,HOOK所有上层的网络函数调用,然后交给自定义协议栈进行处理,处理完成后,如果需要发送数据,则交由下层的网络发送层进行发送。

+----------------------------------------------------------+
     |                                                                          |
     | 网络函数HOOK层: 主要负责网络函数的替换 |
     |                  并且交由下层处理                            |
     |    这里,其实也就是对于WS2_32.dll中的          |
     | socket函数进行替换。                                      |
     |                                                                         |
     +---------------------------------------------------------+
     |                                                                         |
     | 数据处理层:主要负责将上层的各种网络       |
     |                    函数功能调用进行处理。              |
     |    举个简单的例子,当游戏调用Socket函数   |
     | 准备创建一个socket时,我们根据它的参数, |
     | 内部虚拟出一个socket句柄给它。而实际的上 |
     | Windows本身并不知道这个调用过程。          |
     |                                                                      |
     +-------------------------------------------------------+
     |                                                                     |
     | 真实网络传输层:在这一层,才是真正的将数|
     |                 据包进行包装和发送的过程            |
     |                                                                       |
     +-------------------------------------------------------+

其实,整个客户端只创建了两个socket,一个用于和服务器通讯的socket,另外一个就是在游戏DLL中创建的一个和转发服务器以及游戏之间通讯所使用的socket。
       这里重要的就是中间的那层,主要就是对于socket调用中的每个函数进行模拟。这个就需要各位自己去了解了。我不可能也没有能力把每个都描述出来。
        其实,这里的第二层处理也可以不采用我的这种方法,可以采用协议替换法,比如,当游戏调用socket函数要创建一个IPX socket时,你可以修改其中的参数,变成UDP,然后调用Windows真实的socket函数。

五、主要的技术难点:
      a. 模拟Windows Socket。

这个技术点,说起来就比较多了。我们知道Windows有六中socket模型,我们必须模拟出来大部分的模型(根据游戏所使用的模型不同而需要模拟的模型就不同)。
     根据我的跟踪和测试,说说现在了解的几个游戏所使用的socket模型和协议类型:

《红色警戒》: 使用了简单的WSAAsyncSelect模型。(IPX协议)
     《星际争霸》: 使用了Select 模型。(IPX, UDP协议,根据用户的参数)
     《暗    黑》: 使用Select模型。(使用TCP协议)
     《反恐精英》: 使用Select模型。(使用TCP, UDP协议)
     《冰封王座》: 似乎使用了IOCP Socket模型。这个还不是很清楚。(使用TCP,UDP两种协议)

b. 改进UDP数据通讯的可靠性。
         整个平台中,所有通讯全部使用的是UDP,所以,这点很重要。如果我们的游戏中采用了TCP通讯,我们在模拟的时候就的保证所有数据都能被对方收到。

   六、开发后记:
       去年的时候,我写过一个英文的对战平台研究,现在看看,那简直是垃圾!可能是那是比较浮躁,对于什么东西都没有了解清楚。一年后,再回过头来看我写的那些代码,真是惨不忍睹。现在,我觉得自己心静了很多,技术上也成熟了许多。想说的就是Windows开发,我可以算是入门了吧!呵呵!
      整个平台,只是在我的机器上进行测试和开发,难度比较大。工程。现在,我也只对《红色警戒》, 《星际争霸》, 《暗黑》三个游戏测试通过。感觉一个人开发实在太累了,而且,这些东西都是经过一次次的AV错误一步步调试出来的,想想那些岁月,真是不堪回首!暂时不想再继续下去了。等什么时候有精力和时间的时候再来处理吧。
      很多时候,为了能够调试通过一个函数,我不知要经历多少次的游戏重启过程。基本上MSDN上的大多数socket函数已经被我翻了个遍,每个函数的参数,返回值等都的了解。
      为了了解Windows实现socket的原理,阅读那份据说是Win2K的源码(如果你想阅读的话,到网上搜索一下,解压后大概有700M),关于socket的那部分代码在/win2k/private/net/sockets/winsock2/wsock32目录下(估计是WS2_32.dll的源码),读了很多内容,也了解了一些东西,也让我知道以后怎么去写socket程序。现在我有时写代码写累的时候,还会去看点Windows的源码,挺有意思的。像gina的实现,CommCtrl的实现等。
      代码大概已经写的至少有一两万行了,基本上都是我在EditPlus/NotePad中一个字母一个字母敲出来的。暂时不想共享出来了,就分享一下原理篇给大家。

原文地址:http://blog.163.com/etomahawk.popo/blog/static/919644820081131115223397/

游戏对战平台研究终结篇相关推荐

  1. 游戏对战平台搭建要选什么服务器

    游戏对战平台搭建要选什么服务器 服务器是游戏平台数据传输的重要载体,事关我们游戏创业发展的稳定性.安全性.那么,游戏平台搭建要选什么服务器?有什么参考指标?本文艾西将带领大家一探究竟! 首先是&quo ...

  2. 互动游戏对战平台推荐:盘点很火的互动小游戏多人对战平台

    虽然是个妹子,但我超有游戏天赋呦!还记得我和表哥在20年前经常在家里用世嘉.ps等主机联机玩幽游白书.魂斗罗的日子,那份美好变成了我们这代人童年最宝贵的记忆,不管是对战的互相嘲讽还是与好友一同通关的瞬 ...

  3. 休闲互动游戏有哪些?互动游戏对战平台是什么?

    还有几天的时间就是2022年了,不少企业已经开始为年终总结做准备,也相信不少小伙伴们早已期待自己的年终奖了.一些企业为了活跃团队氛围,选择休闲活动游戏来带动成员的积极性,但是休闲互动游戏有哪些?互动游 ...

  4. 对战平台有哪些和到底哪个好?

    对战平台专题为大家推荐一些非常热门的游戏对战平台下载大全,新手玩家搞不清游戏对战平台有哪些和到底哪个好? 推荐软件:浩方电竞平台 浩方电竞平台是世界上最大的网络游戏对战平台,让喜欢网游.电竞的朋友可以 ...

  5. 从11对战平台获取玩家数据进行分析

    首发:个人博客,更新&纠错&回复 在11对战平台好友列表中右键可以查看他的战绩,该页面的地址实际是这样: http://score.5211game.com/RecordCenter/ ...

  6. 万事皆有始亦有终---《The Matrix》影评之终结篇

    作者:reevesneon 来源:天大求实BBS 在此之前我以为看懂了黑客帝国,其实不然 万事皆有始亦有终---<The Matrix>影评之终结篇 一.前言 从 Matrix I 到 M ...

  7. 艾伟_转载:用C#打造quot;QQ对战平台挤房器quot;

    一.什么是"QQ对战平台挤房器"? 喜欢在"QQ对战平台"或"浩方对战平台"玩游戏的人都知道.平常平台上的房间基本很多都是人满的,如果想找个 ...

  8. 打造自己的装机U盘(三)终结篇

    打造自己的装机U盘(三)终结篇   三.利用U盘装系统   经过前面的千辛万苦,现在我们可以用前面打造的这个U盘来装系统.激动人心的时候终于到来! 首先,在欲安装系统的计算机BIOS中设置USB-HD ...

  9. Java异常处理终结篇——如何进行Java异常处理设计

    [本文转自于Java异常处理终结篇--如何进行Java异常处理设计] 有一句这样话:一个衡量Java设计师水平和开发团队纪律性的好方法就是读读他们应用程序里的异常处理代码. 本文主要讨论开发Java程 ...

  10. unity人物旋转移动代码_游戏诞生之日02 - 美术篇 快速制作人物动画

    在上一篇<游戏诞生之日01 - 美术篇 快速搭建和渲染游戏的第一个场景>里,我们得到了一个静态渲染的游戏场景. 接下来我们需要加入人物动画,为游戏注入活力. 第五块拼图 - 动画素材从哪里 ...

最新文章

  1. MySQL主从数据库同步延迟问题解决
  2. rest_快速检查REST API是否有效的方法-从清单文件中获取详细信息
  3. arduino nano 蓝牙_用Arduino玩转掌控板(ESP32):ESP32概述与Arduino软件准备
  4. RTSP流媒体数据传输的两种方式(TCP和UDP)
  5. Common Used Excel Formulas
  6. 编程语言的发展趋势及未来方向(2):声明式编程与DSL
  7. Hibernate 中Property中的formula属性的使用
  8. 支持向量机SVM、支持向量回归SVR详细推导
  9. 报修管理系统微信小程序源码 带前端后端源码
  10. 风玫瑰图的绘制,基于气象A文件(windrose)
  11. 用这本书《现在,发现你的优势》,识别了自己的典型优势
  12. c语言有flag的程序,c语言flag(编程flag的用法)
  13. 通过编写游戏程序的视角去编写字符驱动--设备树-百问imx6ull-pro
  14. 清默网络——CCIE考试经验与心得(1)
  15. 【STM8L】Active-Halt模式下的低功耗
  16. java让线程空转_详解Java编程中对线程的中断处理
  17. Python爬知乎妹子都爱取啥名
  18. rfid考勤系统mysql_通过使用Arduino将Python发送RFID数据到MySQL服务器的考勤系统
  19. 遗传学与基因组学原理 | 遗传方式及多因素遗传
  20. [转载]3Dmax+blend+WPF综合运用

热门文章

  1. 记一次查深圳磨房百公里徒步照片历程
  2. Java 导出时序折线图到Excel
  3. erlang 解决socket 数据粘包问题
  4. python 读取geotiff_从GeoTIFF文件中获取经度和纬度
  5. 18个高效使用Google搜索的技巧
  6. rc3ctf 逆向logmein writeup
  7. 虚拟偶像成为二次元香饽饽,从直播切入有戏吗?
  8. 国内常用地图坐标系总结
  9. 报错undefined symbol: _ZN3c104impl23ExcludeDispatchKeyGuardC1ENS_11DispatchKeyE
  10. 网站被攻击客户信息被泄露如何解决