使用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)

相关推荐
坐吃山猪2 小时前
SpringBoot01-配置文件
java·开发语言
我叫汪枫3 小时前
《Java餐厅的待客之道:BIO, NIO, AIO三种服务模式的进化》
java·开发语言·nio
yaoxtao3 小时前
java.nio.file.InvalidPathException异常
java·linux·ubuntu
Swift社区4 小时前
从 JDK 1.8 切换到 JDK 21 时遇到 NoProviderFoundException 该如何解决?
java·开发语言
DKPT5 小时前
JVM中如何调优新生代和老生代?
java·jvm·笔记·学习·spring
phltxy5 小时前
JVM——Java虚拟机学习
java·jvm·学习
seabirdssss7 小时前
使用Spring Boot DevTools快速重启功能
java·spring boot·后端
喂完待续7 小时前
【序列晋升】29 Spring Cloud Task 微服务架构下的轻量级任务调度框架
java·spring·spring cloud·云原生·架构·big data·序列晋升
benben0447 小时前
ReAct模式解读
java·ai