java - Kryonet 客户端在向服务器发送数据包后断开连接(java)

标签 java packet disconnect kryonet

我正在做一个小型 MMO 项目,现在我正在开发登录/注册系统。每当我尝试发送 ClientLoginPacket 时,客户端就会与服务器断开连接,并且服务器根本不会收到该数据包。没有显示堆栈跟踪,但这是我的代码。抱歉,有点多,但都是必要的:

ClientLoginPacket.java:

package net.vediogames.archipelo.networking.packets;

import net.vediogames.archipelo.networking.Networking;

public class ClientLoginPacket extends Packet{

    private String username;
    private String password;
    private int validity = 0;

    public ClientLoginPacket(String username, String password){
        this.username = username;
        this.password = password;
    }

    public String getUsername(){
        return this.username;
    }

    public String getPassword(){
        return this.password;
    }

    public int getLoginValidity(){
        return validity;
    }

    public void setLoginValidity(int validity){
        this.validity = validity;
    }

    public void send(){
        Networking.sendTCP(this);
    }
}

这是登录数据包。这个和服务器的唯一区别是导入和包声明(它的 archipeloserver 而不仅仅是 archipelo)。正如你所看到的,这个类扩展了Packet,这是我的Packet类:

package net.vediogames.archipelo.networking.packets;

public abstract class Packet {

    protected int connectionID;

    public abstract void send();

    public int getConnectionId(){
        return connectionID;
    }
    public void setConnectionID(int id){
        this.connectionID = id;
    }

}

所有数据包都有一个 send() 方法,调用该方法来发送它们。我发送数据包的方式是通过执行此 new ClientLoginPacket(username, password).send();。在 ClientLoginPacket 类中,您可以看到它运行 Networking.sentTCP(this) 来发送数据包。这只是在我的主 kryonet 类 Networking.java 中运行此代码。这是它用来在客户端发送数据包的代码:

public static void sendTCP(Packet object){
    client.sendTCP(object);
}

在 kryonet 中,您必须在发送类(class)之前注册类(class)。我这样做了,但我不知道我是否做得正确。这是我使用的确切代码。 服务器:

private static void setupClasses(){
    Kryo kryo = server.getKryo();
    kryo.register(ClientRegisterPacket.class);
    kryo.register(ClientLoginPacket.class);
    System.out.println("Registered classes.");
}

客户:

public static void setupClasses(){
    Kryo kryo = client.getKryo();
    kryo.register(ClientRegisterPacket.class);
    kryo.register(ClientLoginPacket.class);
}

我确信的是,在发送数据包之前我确实与服务器建立了连接,我使用服务器上的连接监听器对其进行了测试。我的问题是什么?我的类(class)注册有问题吗?两个类必须完全相同吗?提前致谢!

附:抱歉把所有代码都扔掉了。如果没有必要,我通常不会这样做。我尽量放最少的。如果您需要更多信息来了解其他内容如何工作以及问题是否存在,请询问我。谢谢!

最佳答案

Kryo 需要一个不带任何参数的构造函数来反序列化。看来您的 ClientLoginPacket 可能需要一个?这也给我带来了一个问题。直到我在服务器上使用调试 kryonet jar 并打开日志记录后,我才收到解释它的错误消息。

关于java - Kryonet 客户端在向服务器发送数据包后断开连接(java),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25934876/

相关文章:

java - 通过通用网关发送请求时,服务器可用的应用程序和数据包层信息

java - Camel 运行时计时器更改

java - 为什么我收到错误 "the Method Is Undefined for the type"?

algorithm - 为什么 DFA 等同于延迟输入 DFA

networking - 将数据包信息写入文本文件

c - ESP32 蓝牙连接在完成读取缓冲区后断开

node.js - 断开连接后,nodejs socket.io 套接字文件未关闭

delphi - 断开连接时发生 IdHTTP 访问冲突

java - URL中的Webflux Webclient转义斜杠

java - 使用javac/java手动编译并运行多个包