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

相关推荐
程序员清风15 分钟前
阿里二面:Kafka 消费者消费消息慢(10 多分钟),会对 Kafka 有什么影响?
java·后端·面试
幼稚园的山代王15 分钟前
Prompt Enginering(提示工程)先进技术
java·人工智能·ai·chatgpt·langchain·prompt
周某某~24 分钟前
二.单例模式‌
java·单例模式·设计模式
摸鱼仙人~27 分钟前
深入理解Java单例模式:确保类只有一个实例
java·javascript·单例模式
hstar952743 分钟前
三十五、面向对象底层逻辑-Spring MVC中AbstractXlsxStreamingView的设计
java·后端·spring·设计模式·架构·mvc
pengyu1 小时前
【Java设计原则与模式之系统化精讲:壹】 | 编程世界的道与术(实战指导篇)
java·后端·设计模式
日月星辰Ace1 小时前
JVM 垃圾回收简介
java
掉头发的王富贵1 小时前
Arthas神器入门:动态调试Java应用,轻松搞定生产环境Bug!
java·后端·debug
Java陈序员1 小时前
再见 Navicat!一款开源的 Web 数据库管理工具!
java·react.js·docker
知其然亦知其所以然2 小时前
RAG 结果太水?用 RRF + Reranker 重排,效果翻倍提升!
java·后端·llm