【问题标题】:StreamCorruptedException while de-serializing objects [duplicate]反序列化对象时出现 StreamCorruptedException [重复]
【发布时间】:2013-07-03 10:08:30
【问题描述】:

我有一个序列化对象的类 UserData,

import java.io.*;

public final class UserData implements Serializable
{
    private String name,username,password;
    private boolean male;
    private int age;

    public void setName(String name) { this.name = new String(name); }
    public void setUsername(String username) {this.username = new String(username); }
    public void setPassword(String password) {this.password = new String(password); }
    public void setAge(int age) { this.age = age; }
    public void setGender(boolean gender) { this.male = gender; }

    public String getName() { return new String(this.name); }
    public String getUsername() { return new String(this.username); }
    public String getPassword() { return new String(this.password); }
    public int getAge() { return this.age; }
    public boolean getGender() { return male; }

    public static void writeUserDataToFile(UserData data,String fileName)
    {
        try
        {
            if(data == null)
            {
                return;
            }
            ObjectOutputStream objOutput = new ObjectOutputStream(new FileOutputStream(new File(fileName),true));
            objOutput.writeObject(data);
            objOutput.flush();
            objOutput.close();
        }
        catch(FileNotFoundException ex)
        {
            System.out.println("Error : Cannot Save Data , The given filename \""+fileName+"\" is not valid.");
            return;
        }
        catch(NotSerializableException ex)
        {
            System.out.println("Error : It has been found that some data is not Serializable!");
            return;
        }
        catch(IOException ex)
        {
            System.out.println("Error : IOException has been encountered,");
            return;
        }
        catch(SecurityException S)
        {
            System.out.println("Error : Security Exception has been Encountered.");
            return;
        }
        catch(Exception e)
        {
            System.out.println("Error : Unknown Exception thrown!");
            return;
        }
        System.out.println("Sucess : Data written to \""+fileName+"\".");
    }
    public static UserData checkCredentials(String fileName,String userName,String passWord)
    {
        try
        {
            ObjectInputStream objInput = new ObjectInputStream(new FileInputStream(new File(fileName)));
            UserData data;
            while((data = (UserData)objInput.readObject())!=null)
            {
                if( userName.equals(data.getUsername()) && passWord.equals(data.getPassword()) )
                    return data;
            }
            objInput.close();
        }
        catch(Exception ex)
        {
            System.out.println("Error : Unknown Exception Caught while deserializing object.");
            ex.printStackTrace();
        }
        return null;
    }
}

为了测试这个类,我写了另一个类,

public class TestUserData
{
    public static void main(String args[])
    {
        UserData data = new UserData();
        System.out.println("Serializing objects .... ");
        for(int i=0;i<5;i++)
        {
            data.setName("John");
            data.setAge(10+i);
            data.setGender((i%2==0)?true:false);
            data.setUsername("John"+i);
            data.setPassword(i+"John");
            UserData.writeUserDataToFile(data,"testSerial.dat");
        }
        System.out.println("de-Serializing objects .... ");
        for(int i=0;i<5;i++)
        {
            data = UserData.checkCredentials("testSerial.dat","John"+i,i+"John");
            if(data!=null)
            {
                System.out.println("Name : "+data.getName());
                System.out.println("Age  : "+data.getAge());
                System.out.println("Gender : "+(data.getGender() ? "Male" : "Female"));
            }
            else
            {
                System.out.println("Data for Object "+i+" not de-serialized.");
            }
        }
    }
}

我得到的输出

Serializing objects .... 
Sucess : Data written to "testSerial.dat".
Sucess : Data written to "testSerial.dat".
Sucess : Data written to "testSerial.dat".
Sucess : Data written to "testSerial.dat".
Sucess : Data written to "testSerial.dat".
de-Serializing objects .... 
Name : John
Age  : 10
Gender : Male
Error : Unknown Exception Caught while deserializing object.
java.io.StreamCorruptedException: invalid type code: AC
    at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1374)
    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:369)
    at UserData.checkCredentials(UserData.java:67)
    at TestUserData.main(TestUserData.java:19)
Data for Object 1 not de-serialized.
Error : Unknown Exception Caught while deserializing object.
java.io.StreamCorruptedException: invalid type code: AC
    at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1374)
    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:369)
    at UserData.checkCredentials(UserData.java:67)
    at TestUserData.main(TestUserData.java:19)
Data for Object 2 not de-serialized.
Error : Unknown Exception Caught while deserializing object.
java.io.StreamCorruptedException: invalid type code: AC
    at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1374)
    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:369)
    at UserData.checkCredentials(UserData.java:67)
    at TestUserData.main(TestUserData.java:19)
Data for Object 3 not de-serialized.
Error : Unknown Exception Caught while deserializing object.
java.io.StreamCorruptedException: invalid type code: AC
    at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1374)
    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:369)
    at UserData.checkCredentials(UserData.java:67)
    at TestUserData.main(TestUserData.java:19)
Data for Object 4 not de-serialized.

在 TestUserData 类中,我正在序列化 5 个 UserData 对象,序列化进行得很好,但在反序列化部分,它无法反序列化超过第一个对象。

我应该改变什么来让程序反序列化所有对象??

【问题讨论】:

    标签: java file serialization deserialization


    【解决方案1】:

    您不能像这样附加到序列化文件。有写的标题,所以在你的文件中你会有&lt;header&gt;&lt;data&gt;&lt;header&gt;&lt;data&gt;&lt;header&gt;&lt;data&gt;...

    文件格式必须为&lt;header&gt;&lt;data&gt;&lt;data&gt;&lt;data&gt;&lt;data&gt;

    因此,虽然您的阅读方法是正确的,但您的保存方法实际上是错误的。您需要将所有进入同一文件的对象同时写入。

    【讨论】:

    • 但在我的情况下,我不能同时序列化所有对象,因为最初的目的是在用户随时创建帐户的应用程序中使用它(我的意思是不在同时)除了序列化还有其他选择吗??
    • 通过序列化,您需要将对象读入内存,进行必要的更改(例如添加用户),然后将它们全部写回文件。另一种简单的方法是使用文本文件,例如 CSV 格式,每个用户都有一行。更强大的解决方案是使用数据库(例如 Java DB)。
    • 所以我必须反序列化所有对象,然后同时再次序列化它们?但这不会增加开销吗?
    • 与什么相比增加开销?您无法将有效的解决方案与无效的解决方案进行比较。
    猜你喜欢
    • 1970-01-01
    • 2013-03-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-02-09
    • 2015-12-09
    • 2020-07-06
    相关资源
    最近更新 更多