proj — 大型客户端游戏的游戏辅助开发框架 | 软件推介

2017 年 11 月 9 日 开源中国 cutself


扫描二维码或点击图片进入西安源创会报名


本项目是 win32 下大型客户端游戏的游戏辅助开发框架,由于它集成并包含了游戏辅助开发的各方面功能,称本项目为win32辅助开发的组件也可。


本项目是 win32 下大型客户端游戏的游戏辅助开发框架,由于它集成并包含了游戏辅助开发的各方面功能,称本项目为win32辅助开发的组件也可。 


内含具体项目有fifa online3、疾风之刃、怪物猎人online、流放之路等,也有辅助帐号验证服务器,帐号查寻与管理工具,特征码识别,资源文件系统等。


本人现已转型,特发布此项目,旨在分享一份只供参考的多年工作经验与心血,若本项目中有些您认为闪亮的设计、思路或技巧,并对您有帮助的话,则乐哉幸甚!


以下是文件目录与概要功能组件简要说明:



proj 根目录下目录说明:


cpp:C++工程所在地,包括引用的一些C++开源库。


lua:通用的脚本功能,控制台界面通用的lua相关实现等。


OD:计划存放关于OD逆向分析的一些东西。


python:包括用python写的自动更新ida数据库信息的插件,其中python/ForFrame/PreBuild.py是用来帮助编译器生成assf资源文件的(assf是本项目所依赖的资源文件系统,类似安卓下的资源打包,也像windows下的rc资源文件)。


lua目录下目录与功能说明:



common目录提供了lua通用基础功能。


wgframe是控制台界面通用的实现。


wgscript提供辅助脚本通用的基础功能。


python目录下目录与功能说明:



_idaex和AUT是关于IDA自动更新数据库信息的插件,ida分析某个可执行文件的过程中,若是该可执行文件更新了新版本,那么载入这个新的可执行文件,ida建立的是个全新的数据库,旧的分析记录全都不可用了。


本插件就是解决这个问题的。本插件支持多种特征码定位方式,以便把旧的数据库信息更新到新的ida数据库中。


ForFrame是用于生成assf格式的文件,assf是本项目自定义的资源文件系统的格式,类似于windows下的rc资源文件。


本项目生成的大多数可执行都依赖于assf资源文件系统。


cpp目录下目录与功能说明:



apps:包括辅助帐号验证服务器(CheckServer),辅助帐号管理器(CSViewer),资源文件系统浏览器(AssetExplore),特征码提取器(ExtractFeatureCode)。


tools:包括注入dll(HijackDll),通用辅助登陆验证(LoginHlp),录制地图坐标工具(RecordMap)等。


libs:框架和具体项目依赖的外部开源库,包括boost、lua、luabind、luacom、pluto、wxLua、Eigen、openssl、poco、wxWidgets、zlib等。


subs:具体的辅助项目均放在此目录下,包括fifa online3、疾风之刃、怪物猎人online、流放之路等。


Frame:框架所在,包括资源文件系统(AssetSys),小的外部开源库集合(ExternLib),非常苛刻编程环境下的框架代码集合(PublicX),一般苛刻编程环境下的框架代码集合(PubMix),普通编程环境下的框架代码集合(PubMix)。


其中苛刻编程环境意思是只能引用少部分系统功能(dll),不能在该库中加入更多的外部引用动态库。比如非常苛刻编程环境,要求dll在初始化时只能引用这些系统dll:kernel32.dll、user32.dll等。


以上5个目录可以理解为工程项目的5种分类,其中apps、tools、subs依赖于Frame,而Frame又依赖于libs。


libsetup.props和setup.props是vs的项目属性页配置,libs中的工程大多数都继承自libsetup.props通用属性配置,


apps、tools、subs、Frame中的工程则继承自setup.props通用属性配置。


Frame目录下目录与功能说明:



AssetSys:资源文件系统,项目中主要依赖于该文件系统,可解耦于文件具体的位置所在,索引方式等。即相同的文件使用方式,具体到具体文件,则该文件可以是系统文件系统的目录A下,也可以在目录B下,还可以是内存中的某处。


发布版本的时候,文件系统的打包与加解密,对应用层来说都是透明的。


其中apps/AssetExplore是该资源文件系统的可视化编辑工具。


Public、PubMix、PublicX 都是框架各方面功能的集合,区分之原因可参见cpp目录下的ReadMe.txt,此处只介绍框架所支持的需要注意的机制。


BufCall:是个自动序列化的机制,类似boost.serialization。主要应用于网络通信的自动序列化与解析。


其实现多借鉴于luabind,以tcp网络通信为例,每次发包相当于通过网络异步或同步调用对方一个函数,那么对于发包方来说,只需要告诉要调用的函数名以及参数信息,对于收包方来说,只需要提供相应函数名的函数。


其中发包方的参数序列化都是自动的,收包方的函数参数的解析也是自动的,当远程收到该包,则自动解析出函数参数,并调用之。


从这个意义来讲,比较像RPC,所以才将之命名为BufCall。


FuncObj:tcp-ip通信机制,底层用的是boost.asio库,设计与实现并不复杂,设计之初更多地想要模仿com通信技术,后来觉得并无必要,然后把它实现简化了,直至现在的版本。加上BufCall机制的协作,对于应用层来说,基本上可以无视FuncObj了。


Hooker:抽象并封装了hook的底层实现细节,让hook函数避免去维护堆栈细节,做到在hook函数内像普通函数一样自由地写代码。


异常:所有框架异常都继承自CmnExceptionBase,可自动处理lua、luabind、c++之间的异常传递,对应用层来说是透明的,CmnExceptionBase异常与DummySleep函数的协调运作,奠定了此框架下游戏辅助开发的方式与基调,在自身定位方面意义非常。


同时也让单线程下具有异步的效果,但又无多线程和协程的复杂性和不稳定性。它们是项目中很多其他机制的基石,比如Action、脚本事件、Timer等。


Database:数据库支持,使得数据库方面的操作具有sql语句方式的简洁效果。


LogOut:日志系统,对boost.log进行封装,使之更方便、简洁,对本项目进行适配。支持输出日志到文件和DbgView。


IoTimer:计时器,支持以毫秒为单位的计时器。


Iterator:迭代器模式的模板实现,支持到lua的for迭代。


lua:通过diy lua和luabind,支持中文脚本,c++调试模式下的lua堆栈变量的输出等。


Cmn_AppBase类族:类似CWinApp,抽象可执行模块,一个Cmn_AppBase既可以是基于MFC的CWinApp,又可以是基于wxWidgets的app,还可以是dll。


其中Cmn_AppBaseFactory类族是典型的工厂模式,以便达到为app配置各种组件的目的,组件包括通信、脚本方面、辅助游戏逻辑等实现细节,一般而言,使用框架默认的组件即可。


RStd:全称为Release of Std,即标准库的release版。标准库中debug版和release版中的数据结构很多都是不一样的,主要应用于数据分析,因为游戏中的数据结构很多都是应用的标准库中的,但都是release版的,RStd可以让人避免去实现这样的算法细节。


WgFacility:提供了辅助游戏逻辑方面比较常用的功能,包括优化过后的A星算法,过滤器(filter,比如物品过滤、技能过滤、游戏对象过滤等),地图坐标录制相关(CmnMapPath),任务处理(CmnQuestHandler),场景处理(CmnSceneHandler),最短路径(ShortestPaths)等。


GGameObjBase、GGameObjMgrBase:辅助对象到游戏对象的对应对象,比如游戏里的角色对象,那么辅助里就有一个Player类表示角色,辅助里的Player对象称之为代理对象。代理对象数据的更新为主动触发型,即根据需要去更新对象数据。


游戏逻辑中到处可见各种对象,所以GGameObjBase、GGameObjMgrBase虽然看起来仅仅只定义了这么个抽象,但这个抽象挺重要。


Action:CA_IAction类族,与异常等的协作,让游戏逻辑中角色同时做多件事情成为了比较容易的工作。




作者语:


以上是框架方面部分功能或机制的简要介绍,细览代码,发现好多东西未能在此尽述,想写上来吧,发现只可意会,难以言传,不写吧,难不成这几年为之努力的框架就那么点东西吗?真若如此,自己都觉得对不起自己。


思量再三,还是不写了吧,究其原因,概因自己目前水平所限,仅此而已。



11 月 10 日之前,只要在【你谈见解我送书:《Kotlin 程序开发入门精要》技术书籍大放送】文末留言你在试读书籍第一章后的见解,就有机会获得文中提及技术书籍一本!快来留言吧,说不定中奖的就是你哦!!


推荐阅读

MINIX 成世界最流行的操作系统,暗藏着最大的威胁?

Biny —— 腾讯开源的超轻量级 PHP 框架

微服务下的网关与容错

消息中间件 kafka+zookeeper 集群部署、测试与应用(1)

带来高收入的 10 大开源技术,可以涨工资了!

点击“阅读原文”查看更多精彩内容

登录查看更多
1

相关内容

干净的数据:数据清洗入门与实践,204页pdf
专知会员服务
161+阅读 · 2020年5月14日
【实用书】Python爬虫Web抓取数据,第二版,306页pdf
专知会员服务
116+阅读 · 2020年5月10日
【实用书】流数据处理,Streaming Data,219页pdf
专知会员服务
76+阅读 · 2020年4月24日
【ICMR2020】持续健康状态接口事件检索
专知会员服务
17+阅读 · 2020年4月18日
数据标注研究综述,软件学报,19页pdf
专知会员服务
88+阅读 · 2020年2月20日
【干货】大数据入门指南:Hadoop、Hive、Spark、 Storm等
专知会员服务
95+阅读 · 2019年12月4日
Keras作者François Chollet推荐的开源图像搜索引擎项目Sis
专知会员服务
29+阅读 · 2019年10月17日
机器学习相关资源(框架、库、软件)大列表
专知会员服务
39+阅读 · 2019年10月9日
VS Code Remote发布!真·远程开发
开源中国
6+阅读 · 2019年5月3日
Pupy – 全平台远程控制工具
黑白之道
43+阅读 · 2019年4月26日
34个最优秀好用的Python开源框架
专知
9+阅读 · 2019年3月1日
爱奇艺基于AI的移动端自动化测试框架的设计
前端之巅
18+阅读 · 2019年2月27日
去哪儿网开源DNS管理系统OpenDnsdb
运维帮
21+阅读 · 2019年1月22日
33款可用来抓数据的开源爬虫软件工具 (推荐收藏)
数据科学浅谈
7+阅读 · 2017年7月29日
Arxiv
8+阅读 · 2018年5月1日
Arxiv
3+阅读 · 2017年11月21日
Arxiv
3+阅读 · 2012年11月20日
VIP会员
相关VIP内容
干净的数据:数据清洗入门与实践,204页pdf
专知会员服务
161+阅读 · 2020年5月14日
【实用书】Python爬虫Web抓取数据,第二版,306页pdf
专知会员服务
116+阅读 · 2020年5月10日
【实用书】流数据处理,Streaming Data,219页pdf
专知会员服务
76+阅读 · 2020年4月24日
【ICMR2020】持续健康状态接口事件检索
专知会员服务
17+阅读 · 2020年4月18日
数据标注研究综述,软件学报,19页pdf
专知会员服务
88+阅读 · 2020年2月20日
【干货】大数据入门指南:Hadoop、Hive、Spark、 Storm等
专知会员服务
95+阅读 · 2019年12月4日
Keras作者François Chollet推荐的开源图像搜索引擎项目Sis
专知会员服务
29+阅读 · 2019年10月17日
机器学习相关资源(框架、库、软件)大列表
专知会员服务
39+阅读 · 2019年10月9日
相关资讯
VS Code Remote发布!真·远程开发
开源中国
6+阅读 · 2019年5月3日
Pupy – 全平台远程控制工具
黑白之道
43+阅读 · 2019年4月26日
34个最优秀好用的Python开源框架
专知
9+阅读 · 2019年3月1日
爱奇艺基于AI的移动端自动化测试框架的设计
前端之巅
18+阅读 · 2019年2月27日
去哪儿网开源DNS管理系统OpenDnsdb
运维帮
21+阅读 · 2019年1月22日
33款可用来抓数据的开源爬虫软件工具 (推荐收藏)
数据科学浅谈
7+阅读 · 2017年7月29日
Top
微信扫码咨询专知VIP会员