使用Java实现魔兽争霸3冰封王座联网

背景

自己实现搭建网络,在非同一个局域网下也可以玩魔兽争霸3冰封王座。一般我们是通过平台上玩魔兽争霸3地图,比如浩方平台,kk对战平台,何不自己尝试搭建一个。

分析

首先应用层下的运输层是使用的是tcp或者udp协议,我们可以通过Wireshark工具去抓包观察数据包走向。我们用Wireshark抓包那么多包,怎么知道那些数据包是魔兽争霸3的数据包。其实我们可以通过下面cmd命令查到应用进程,并通过进程查出他们的协议和端口。

cmd 复制代码
# 在任务列表查包含`War`的任务
tasklist | findstr War
# 在端口列表中查包含`<pid>`进程的端口
netstat -ano | findstr <pid>

如下图,你会发现魔兽争霸3居然tcp和udp用了同一个端口6112,不是说同一个ip的tcp和udp不能同一个端口吗,原来同一个应用是下是可以tcp和udp占同一个端口的。

拿到协议和端口,我们可以在Wireshark监听以太网并且过滤一下,在过滤栏输入

ini 复制代码
udp.port == 6112 || tcp.port == 61122

你会发现当你在局域网创建房间才会看到数据包,255.255.255.255那不是广播地址吗,那不是创建房间后就广播出去,告诉其他电脑我已经开好房了,如图↓

我这边用了Hyper-V虚拟机快速创建的window11系统,新打开一个魔兽争霸3客户端,在局域网中可以看到我刚才的创建的房间,但是在Wireshark监听的以太网是没看到新的数据包,说明虚拟机的数据包是没有走本地的以太网的,而是直连的。那我们可以通过Wireshark监听vEthernet(Default Switch)虚拟机网络,虚拟机中用魔兽争霸3创建房间,自己电脑则进入房间,你会看到一下面抓的数据包。

上面抓包信息,可以看到先是udp协议后,才开tcp协议。大概是流程是,魔兽争霸3在局域网选择房间界面时会监听6112端口广播,收到广播后向目标ip发送udp信息询问房间信息,目标客户端就会通过udp返回房间信息。当我们点击房间的时候,就会和目标ip进行tcp协议连接,这就是上面数据包的流程。

思路

通过上面的分析,数据就是先经过udp后经过tcp,那我们只要把这边魔兽争霸3udp广播的数据发送到另一个魔兽争霸3客户端中,让他们相互交换数据,之后在让他们建立tcp连接交换数据。因为不通过局域网,我们需要让他连接一个服务器,服务器有两个端口一个是用来交换udp数据的,另一个用来交换tcp数据的。

udp数据走向如上图,魔兽争霸3应用是监听了udp:0.0.0.0:6112,我们可以通过java应用监听udp:192.168.1.10:6112拿到广播,再通过java创建一个创建一个客户端连接服务端,通过服务端把数据传到另一台电脑上java客户端上,最后让java客户端发送到另一台的魔兽争霸3上。

tcp数据走向如上图,这个看起来复杂些,一个魔兽争霸3客户端的需要连接另一个魔兽争霸3客户端时,先下发指令告诉另一台客户端需要连接,赶紧连接服务端,然后在服务端等待队列连接,另一台魔兽争霸3连接成功时,就会加到服务器等待队列中,最后得到两个魔兽争霸3客户端连接就可以交换数据。

测试

用本机电脑加虚拟机跑魔兽争霸3,连接云服务测试是可以跑通的。

代码

感兴趣可以下载代码跑跑。断续/war3Demo (gitee.com) 断续/war3Demo (gitee.com)

相关推荐
WaaTong15 分钟前
《重学Java设计模式》之 原型模式
java·设计模式·原型模式
m0_7430484415 分钟前
初识Java EE和Spring Boot
java·java-ee
AskHarries17 分钟前
Java字节码增强库ByteBuddy
java·后端
小灰灰__37 分钟前
IDEA加载通义灵码插件及使用指南
java·ide·intellij-idea
夜雨翦春韭41 分钟前
Java中的动态代理
java·开发语言·aop·动态代理
程序媛小果1 小时前
基于java+SpringBoot+Vue的宠物咖啡馆平台设计与实现
java·vue.js·spring boot
追风林1 小时前
mac m1 docker本地部署canal 监听mysql的binglog日志
java·docker·mac
芒果披萨1 小时前
El表达式和JSTL
java·el
duration~2 小时前
Maven随笔
java·maven
zmgst2 小时前
canal1.1.7使用canal-adapter进行mysql同步数据
java·数据库·mysql