2

首先,我知道有一些关于 StreamCorruptedExceptions 的问题,但几乎没有关于“无效类型代码:01”的问题。

我有一个本地客户端连接到本地服务器。客户端尝试向服务器发送一个可序列化的“Task_Data”对象。我用来发送的代码是(去除了杂乱):


    oos = new ObjectOutputStream(clientSocket.getOutputStream());

    Task_Data task = new Task_Data();
    task.setCheckMale(true);
    task.setCheckAdult(true);
    task.setAdditionalInfo("testing");
    task.setTakeNotes(true);
    task.setTakePhoto(true);
    oos.writeObject(task);
    oos.flush();

现在在接收端(服务器)我有:


    Task_Data task = (Task_Data) ois.readObject();
    System.out.println(task.getAdditionalInfo());

Eclipse 抛出此错误:java.io.StreamCorruptedException: invalid type code: 01

奇怪的是,像 UTF 这样的“原始”类型的传输没有任何问题。

也许原因在于我的序列化,Task_Data 类是:


public class Task_Data implements Serializable {

private static final long serialVersionUID = -226273890693695870L;

private boolean checkMale = true;
private boolean checkAdult = true;
private boolean takePhoto = true;
private boolean takeNotes = true;

private String additionalInfo = null;

private void writeObject(java.io.ObjectOutputStream out) throws IOException {
    out.writeBoolean(checkMale);
    out.writeBoolean(checkAdult);
    out.writeBoolean(takePhoto);
    out.writeBoolean(takeNotes);
    out.writeUTF(additionalInfo);
}


private void readObject(java.io.ObjectInputStream in) throws IOException, ClassNotFoundException {
    checkMale       =   in.readBoolean();
    checkAdult      =   in.readBoolean();
    takePhoto       =   in.readBoolean();
    takeNotes       =   in.readBoolean();
    additionalInfo  =   in.readUTF();
}
4

1 回答 1

0

您的writeObject()方法将在序列化期间执行,因为它与此类方法的规范签名一致,但您的readObject()方法不会,因为它不。因此存在不对称性,这可能会导致任何错误,包括这个错误。

但我不知道你为什么要编写显式代码来完成默认情况下序列化已经完成的事情。我将完全摆脱readObject()andwriteObject()方法以及任何现有的序列化流,然后重新测试。

您还必须确保在套接字的生命周期内使用相同的 ObjectInputStream 和 ObjectOutputStream。这些流上有标头,在一端开始新的标头会混淆另一端。

于 2013-03-06T20:00:31.843 回答