Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/348.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Kryonet序列化错误_Java_Kryonet - Fatal编程技术网

Java Kryonet序列化错误

Java Kryonet序列化错误,java,kryonet,Java,Kryonet,在任何人试图告诉我这是一个重复之前,我已经尝试了解决方案,并且几乎所有其他的答案我都能找到 我的项目在IntelliJ中构建得很好,通过了我设置的所有测试,甚至从IntelliJ内部运行也很好,只要我尝试运行maven构建的JAR,我就会被打耳光,除了几个例外 代码所指向的类: package com.albion; import com.albion.logging.Loggable; import com.albion.packets.Packet; import com.albion.p

在任何人试图告诉我这是一个重复之前,我已经尝试了解决方案,并且几乎所有其他的答案我都能找到

我的项目在IntelliJ中构建得很好,通过了我设置的所有测试,甚至从IntelliJ内部运行也很好,只要我尝试运行maven构建的JAR,我就会被打耳光,除了几个例外

代码所指向的类:

package com.albion;

import com.albion.logging.Loggable;
import com.albion.packets.Packet;
import com.albion.packets.Packets;
import com.esotericsoftware.kryonet.Server;
import com.esotericsoftware.minlog.Log;

import javax.swing.*;
import java.io.IOException;
import java.util.HashMap;
import java.util.UUID;
import java.util.logging.Level;

public class Main extends Loggable {
    protected static Integer PORT = 47532;

    protected static byte[] key = { /* contents omitted for obvious reasons */ };

    protected static Server server;
    protected static Controller controller;

    public static void main(String[] args) throws IOException {
        try {
            UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
        } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
            ex.printStackTrace();
        }

        Log.set(Log.LEVEL_DEBUG);
        server = new Server();
        server.bind(PORT);

        try {
            controller = new Controller();
            controller.setVisible(true);
            ClientManager.setController(controller);
        } catch (Exception ex) {
            getLog().log(Level.SEVERE, "Error creating a new Controller instance: ", ex.getCause());
        }

        handlers();
        register();

        server.start();
    }

    private static void handlers() {
        getLog().info("Creating new PacketHandler");
        PacketHandler handler = new PacketHandler(controller);

        getLog().info("Creating new ClientListener");
        ClientListener listener = new ClientListener(handler);

        getLog().info("Adding listeners to server");
        server.addListener(listener);
    }

    private static void register() {

        getLog().info("Registering data types");

        server.getKryo().register(UUID.class);
        server.getKryo().register(byte[].class);
        server.getKryo().register(Packet.class);
        server.getKryo().register(String.class);
        server.getKryo().register(HashMap.class);
        server.getKryo().register(Packets.class);
        server.getKryo().register(String[].class);

    }
}
根据我看到的异常情况,当通过命令提示符运行时,问题出现在第31行,这将是:

    server = new Server();
命令提示符中的堆栈跟踪如下所示:

    Exception in thread "main" java.lang.IllegalArgumentException: Unable to create serializer "com.esotericsoftware.kryo.serializers.FieldSerializer" for class: com.esotericsoftware.kryonet.FrameworkMessage$RegisterTCP
    at com.esotericsoftware.kryo.factories.ReflectionSerializerFactory.makeSerializer(ReflectionSerializerFactory.java:48)
    at com.esotericsoftware.kryo.factories.ReflectionSerializerFactory.makeSerializer(ReflectionSerializerFactory.java:26)
    at com.esotericsoftware.kryo.Kryo.newDefaultSerializer(Kryo.java:351)
    at com.esotericsoftware.kryo.Kryo.getDefaultSerializer(Kryo.java:344)
    at com.esotericsoftware.kryo.Kryo.register(Kryo.java:365)
    at com.esotericsoftware.kryonet.KryoSerialization.<init>(KryoSerialization.java:31)
    at com.esotericsoftware.kryonet.KryoSerialization.<init>(KryoSerialization.java:23)
    at com.esotericsoftware.kryonet.Server.<init>(Server.java:91)
    at com.esotericsoftware.kryonet.Server.<init>(Server.java:73)
    at com.albion.Main.main(Main.java:31)
Caused by: java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at com.esotericsoftware.kryo.factories.ReflectionSerializerFactory.makeSerializer(ReflectionSerializerFactory.java:35)
    ... 9 more
Caused by: java.lang.RuntimeException: Cannot create UnsafeFieldFactory
    at com.esotericsoftware.kryo.serializers.FieldSerializer.getUnsafeFieldFactory(FieldSerializer.java:408)
    at com.esotericsoftware.kryo.serializers.FieldSerializer.newMatchingCachedField(FieldSerializer.java:375)
    at com.esotericsoftware.kryo.serializers.FieldSerializer.newCachedField(FieldSerializer.java:343)
    at com.esotericsoftware.kryo.serializers.FieldSerializer.createCachedFields(FieldSerializer.java:307)
    at com.esotericsoftware.kryo.serializers.FieldSerializer.rebuildCachedFields(FieldSerializer.java:239)
    at com.esotericsoftware.kryo.serializers.FieldSerializer.rebuildCachedFields(FieldSerializer.java:156)
    at com.esotericsoftware.kryo.serializers.FieldSerializer.<init>(FieldSerializer.java:133)
    ... 14 more
Caused by: java.lang.ClassNotFoundException: com.esotericsoftware.kryo.serializers.UnsafeCachedFieldFactory
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at com.esotericsoftware.kryo.serializers.FieldSerializer.getUnsafeFieldFactory(FieldSerializer.java:405)
    ... 20 more
线程“main”java.lang.IllegalArgumentException中的异常:无法为类com.esotericsoftware.kryo.serializers.FieldSerializer创建序列化程序“com.esotericsoftware.kryonet.FrameworkMessage$RegisterCp” 位于com.esotericsoftware.kryo.factories.ReflectionSerializerFactory.makeSerializer(ReflectionSerializerFactory.java:48) 位于com.esotericsoftware.kryo.factories.ReflectionSerializerFactory.makeSerializer(ReflectionSerializerFactory.java:26) 在com.esotericsoftware.kryo.kryo.newDefaultSerializer(kryo.java:351)上 位于com.esotericsoftware.kryo.kryo.getDefaultSerializer(kryo.java:344) 登录com.esotericsoftware.kryo.kryo.register(kryo.java:365) 在com.esotericsoftware.kryonet.KryoSerialization.(KryoSerialization.java:31) 在com.esotericsoftware.kryonet.KryoSerialization.(KryoSerialization.java:23) 位于com.esotericsoftware.kryonet.Server.(Server.java:91) 位于com.esotericsoftware.kryonet.Server.(Server.java:73) 位于com.albion.Main.Main(Main.java:31) 原因:java.lang.reflect.InvocationTargetException 位于sun.reflect.NativeConstructorAccessorImpl.newInstance0(本机方法) 位于sun.reflect.NativeConstructorAccessorImpl.newInstance(未知源) 位于sun.reflect.delegatingConstructor或AccessorImpl.newInstance(未知源) 位于java.lang.reflect.Constructor.newInstance(未知源) 位于com.esotericsoftware.kryo.factories.ReflectionSerializerFactory.makeSerializer(ReflectionSerializerFactory.java:35) ... 9更多 原因:java.lang.RuntimeException:无法创建UnsafeFieldFactory 位于com.esotericsoftware.kryo.serializers.FieldSerializer.getUnsafeFieldFactory(FieldSerializer.java:408) 在com.esotericsoftware.kryo.serializers.FieldSerializer.newMatchingCachedField(FieldSerializer.java:375)上 在com.esotericsoftware.kryo.serializers.FieldSerializer.newCachedField(FieldSerializer.java:343)上 位于com.esotericsoftware.kryo.serializers.FieldSerializer.createCachedFields(FieldSerializer.java:307) 位于com.esotericsoftware.kryo.serializers.FieldSerializer.rebuildCachedFields(FieldSerializer.java:239) 位于com.esotericsoftware.kryo.serializers.FieldSerializer.rebuildCachedFields(FieldSerializer.java:156) 位于com.esotericsoftware.kryo.serializers.FieldSerializer.(FieldSerializer.java:133) ... 14多 原因:java.lang.ClassNotFoundException:com.esotericsoftware.kryo.serializers.UnsafectachedFieldFactory 位于java.net.URLClassLoader$1.run(未知源) 位于java.net.URLClassLoader$1.run(未知源) 位于java.security.AccessController.doPrivileged(本机方法) 位于java.net.URLClassLoader.findClass(未知源) 位于java.lang.ClassLoader.loadClass(未知源) 位于sun.misc.Launcher$AppClassLoader.loadClass(未知源) 位于java.lang.ClassLoader.loadClass(未知源) 位于com.esotericsoftware.kryo.serializers.FieldSerializer.getUnsafeFieldFactory(FieldSerializer.java:405) ... 20多 正如前面提到的,我使用maven构建这个项目,我使用maven shade插件将kryonet文件隐藏到我的JAR中

以下是我的POM.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
    <groupId>com.albion</groupId>
    <artifactId>Server</artifactId>
    <version>1.0-SNAPSHOT</version>
</parent>
<artifactId>Server</artifactId>
<dependencies>
    <dependency>
        <groupId>com.albion</groupId>
        <artifactId>ServerCommons</artifactId>
        <version>1.0-SNAPSHOT</version>
        <scope>compile</scope>
    </dependency>
</dependencies>
<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-shade-plugin</artifactId>
            <version>2.3</version>
            <configuration>
                <minimizeJar>true</minimizeJar>
            </configuration>
            <executions>
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>shade</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>2.5</version>
            <configuration>
                <archive>
                    <index>true</index>
                    <manifest>
                        <addClasspath>true</addClasspath>
                    </manifest>
                    <manifestEntries>
                        <Main-Class>com.albion.Main</Main-Class>
                    </manifestEntries>
                </archive>
            </configuration>
        </plugin>
    </plugins>
</build>

4.0.0
阿尔比恩公司
服务器
1.0-快照
服务器
阿尔比恩公司
服务器共享空间
1.0-快照
编译
org.apache.maven.plugins
maven阴影插件
2.3
真的
包裹
阴凉处
org.apache.maven.plugins
maven jar插件
2.5
真的
真的
com.albion.Main

似乎是maven的shade插件中的minimizeJar造成的。 在最后一次尝试修复时,删除了该选项,一切正常