- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在学习Java中的套接字,以便在我正在开发的Minigame程序的两个单独的Java应用程序之间发送信息。目的是要拥有它,以便服务器A可以通过在switch语句中写入和读取int来告诉服务器B做某事。这是服务器端套接字的代码:
@Override
public void run() {
try (
DataInputStream input = new DataInputStream(this.socket.getInputStream())
) {
this.output = new DataOutputStream(this.socket.getOutputStream());
while (!this.finished) {
int type = input.readInt();
this.plugin.getLogger().info("Type: " + type + " from " + this.socket.getRemoteSocketAddress());
switch (type) {
case 1: {
ServerManager.getInstance().addActiveServer(this.serverInfo, input.readInt());
break;
}
case 2: {
int length = input.readInt();
for (int i = 0; i < length; i++) {
UUID uuid = UUID.fromString(input.readUTF());
PlayerData playerData = PlayerManager.getInstance().getPlayerData(uuid);
if (playerData == null) {
continue;
}
playerData.setPlaying(false);
playerData.setSpectating(false);
playerData.setQueuing(false);
playerData.getPlayer().connect(this.plugin.getLobbyServer());
}
ServerManager.getInstance().addInactiveServer(this.serverInfo);
break;
}
case 3: {
int length = input.readInt();
for (int i = 0; i < length; i++) {
UUID uniqueId = UUID.fromString(input.readUTF());
PlayerData playerData = PlayerManager.getInstance().getPlayerData(uniqueId);
if (playerData == null) {
continue;
}
playerData.setQueuing(true);
}
break;
}
default:
}
}
this.output.close();
this.socket.close();
} catch (Exception e) {
e.printStackTrace();
}
}
当迷你游戏开始倒计时序列时,它将在迷你游戏实际开始时写入并刷新“1”到服务器端套接字,然后写入并刷新“3”。
// Tells Server A that the max players have been met
// and to start a countdown sequence for a Minigame.
public void sendStartUpdate(int gameKey) {
try {
this.output.writeInt(1);
this.output.writeInt(gameKey);
this.output.flush();
} catch (IOException e) {
e.printStackTrace();
}
}
// Lets Server A know that the player is queued up for a Minigame
public void sendQueuingUpdate(@NotNull Collection<UUID> players) throws IOException {
this.output.writeInt(3);
this.output.writeInt(players.size());
for (UUID player : players) {
this.output.writeUTF(String.valueOf(player));
}
this.output.flush();
}
但是,由于某种原因,每当我运行该程序时,服务器都会首先收到预期的'1'和'3',然后又从服务器B接收到一系列非常长的整数。
[02:45:24 INFO] Type: 1 // This is good!
[02:45:27 INFO] Type: 3 // This is good!
[02:45:43 INFO] Type: 16777216 // Huh??
[02:45:43 INFO] Type: 1280 // WHAT???
[02:45:43 INFO] Type: 256 // Insert confused guy meme here
[02:45:43 INFO] Type: 610548020
[02:45:43 INFO] Type: 1667643705
[02:45:43 INFO] Type: 925721650
[02:45:43 INFO] Type: 842018100
[02:45:43 INFO] Type: 878785581
[02:45:43 INFO] Type: 1647785059
[02:45:43 INFO] Type: 761477426
[02:45:43 INFO] Type: 825570148
[02:45:43 INFO] Type: 1647851062
当迷你游戏结束并且程序通知服务器A迷你游戏已结束时,也会发生此问题。直到我对以下代码进行了少许修改,我才遇到这个问题:
public void sendPlayingUpdate(@NotNull Collection<UUID> players) throws IOException {
this.output.writeBoolean(true);
this.output.writeBoolean(false);
this.output.writeBoolean(false);
this.output.writeInt(5);
this.output.writeInt(players.size());
for (UUID player : players) {
this.output.writeUTF(String.valueOf(player));
}
// this.output.writeInt(4);
// this.output.writeInt(players.size());
// for (UUID uuid : players) {
// this.output.writeUTF(String.valueOf(uuid));
// }
this.output.flush();
}
注释掉的位是原始代码。如果我用未注释的代码替换它,它将给出所有那些任意大的整数。是否有其他应用程序可以通过某种方式连接到与套接字相同的端口并开始提供随机信息的方法?我只是看不到一个小的细微变化如何导致发送类似于1667643705的东西,这些整数确实让我想起了哈希码。
最佳答案
时间戳指示第二和第三数据包之间有16秒的间隔。因此,很有可能不是第二个3
数据包损坏了。您正在其他地方以未显示的代码发送格式错误的数据包。
数据为:
01 00 00 00 00 00 05 00 00 00 01 00 24 [... load of hex ...]
0x24
是
$
,但是可以是
writeUTF
的字符串长度-例如,两个UUID串联在一起。
关于java - Java套接字连接: receiving completely arbitrary integers from the Input Stream,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65661837/
我有一个返回 future 的函数,该函数取决于要解决的回调结果: Future connectSocket(String email, String password, {Function o
我正在尝试链接两个返回 Completable 的响应式调用在 android 上使用改造: val userRequest = ... val languageRequest = ... retur
我正在尝试将一些数据保存在数据库中。对于添加方法,我使用 Completable。在我保存一个实体 - 客户之后,我想保存一个天数列表,但只有在客户被保存之后。这是我现在的代码。 mDatabaseM
我是 RxJava 的新手,遇到了以下问题: 我有两个 Completable 对象来存储一些数据。我想触发第一个,然后仅在第一个成功完成后才启动第二个。对第二个 Completable 的调用应该被
我正在尝试从两个不同的文件中读取数据,一个是 csv 格式,另一个文件是 xml 数据。使用completeFuture 我正在尝试从两个文件异步读取数据。我收到类型转换错误。请让我知道我是否遵循正确
我有以下人员类别: class Person { String name; String city; public void setInfo(PersonInformation
我正在尝试这个: var notifications = $( "#notifications" ); notifications.fadeOut("slow") .complete(func
我发现 Bash shell 支持一种不同于“传统”自动完成的自动完成类型,所有可能性都列在下一行。 使用“传统的”自动完成,如果我键入 ch 然后按 Tab 键,我会得到如下信息: $ ch cha
我是 rxjava/rxkotlin/rxandroid 的初学者。 我需要按顺序处理三个不同的异步调用。问题是第一步返回 Single ,第二个Completable第三个又是Completable
默认情况下,在 TextMate 中按 Esc 会循环执行可能的补全(除了关闭对话框之外),这可能会在文档中放入不需要的字符,特别是如果您习惯于在大多数文本编辑器中使用 Esc 作为安全键的话。 (事
我知道 pull complete 在之后到达 download complete 在生命周期中,但我有兴趣了解它们之间的区别。我尝试在互联网上搜索,但找不到任何清楚解释这些差异的内容。 最佳答案 拉
以下代码似乎永远不会工作,因为组似乎没有终止,并且 takeLast() 不知道最后是什么: observableSequence .groupBy { $0.key } .map { gro
我是 ido-mode 的忠实粉丝,以至于我想用它来做 describe-function 之类的事情或 find-tag等等,而无需编写类似“我可以在 Emacs 中搜索标签的 ido-mode-s
我们什么时候应该使用 Completable.fromAction()我们什么时候应该使用 Completable.fromCallable()是否有特定的用例 从文档看来,两者都做同样的事情,很难注
我有以下gulpfile.js,我通过命令行执行gulp消息: var gulp = require('gulp'); gulp.task('message', function() { cons
我在我的 .vimrc 文件中设置了 omnifuc : setlocal omnifunc = javacomplete#complete 然后当我编辑任何文件时出现异常: E518: Unknow
我如何将 Single 链接到 Completable,以便在 Completable 完成时订阅它? repository.downloadUser() 是 Single。 根据调试,似乎此方法中的
在bash中,默认情况下,按Tab键将显示当前目录中的所有文件和目录。例如:。Cat a将显示类似aFile.txt apples.png aDirectory/的内容。如果您随后完成了a目录,它将显
在bash中,默认情况下,按Tab键将显示当前目录中的所有文件和目录。例如:。Cat a将显示类似aFile.txt apples.png aDirectory/的内容。如果您随后完成了a目录,它将显
我错过了什么?示例使用 min.js。 bundle.min.js 有更多代码,但我找不到该额外代码的描述...... https://getbootstrap.com/docs/4.0/gettin
我是一名优秀的程序员,十分优秀!