Serialisierung Document - java.io.InvalidClassException

Status
Nicht offen für weitere Antworten.

Stefan S.

Aktives Mitglied
Hallo,

ich habe derzeit ein Problem mit einem Dokument (javax.swing.text.Document), eigentlich ein DefaultStyledDocument, das ich serialisiere und woanders wieder deserialisiere - genauer gesagt wird es zunächst über ein Netzwerk übertragen. Leider wirft mir der Interpreter die folgende Exception mit der logischen Begründung:

Code:
local class incompatible: stream classdesc serialVersionUID = 940485415728594881, local class serialVersionUID = 940485415728614849

Wie man sieht sind die zwei UIDs leicht verschieden, weshalb ich die Exception bei der Deserialisierung erhalte.

Die Daten habe ich bereits über einen Sha256 laufen lassen um die Datenintegrität bei der Übertragung sicherzustellen. Beide Hashes waren erwartungsgemäß gleich.

Code:
Erster Hash: 24F6139C406CD060A60EA2828988125F2BDA8BDE7A1E86A049B2CD935EADEBF5

Zweiter Hash: 24F6139C406CD060A60EA2828988125F2BDA8BDE7A1E86A049B2CD935EADEBF5

Irgendwo scheint die UID zu variieren, eventuell macht der Compiler hier auch faxen, wobei die UID immer bei beiden gleich verschieden bleiben, also immer die oberen longs.

Hat jemand einen Typ für die Fehlersuche oder vielleicht einen anderen Rat woran das liegen könnte? Irgendwo fehlen fehlt die UID, eventuell gleich eine eigene writeObject Implementierung?
 

Wildcard

Top Contributor
Die Java Version auf der einen Seite ist eine andere als auf der anderen Seite. Die beiden Classfiles haben eine andere UID und sind daher binär inkompatibel.
 

Stefan S.

Aktives Mitglied
Die Java Version auf der einen Seite ist eine andere als auf der anderen Seite. Die beiden Classfiles haben eine andere UID und sind daher binär inkompatibel.

Hallo! :)

Daran habe ich auch schon gedacht, aber das kann nicht sein. Ich habe die Netzwerkapplikationen unter localhost, verschiedene Ports getestet - mit demselben Resultat.

Logischerweise läuft bei mir auf dem Rechner nur eine, nämlich dieselbe Java Version.

Auf der offiziellen Seite steht folgendes.

Warning: Serialized objects of this class will not be compatible with future Swing releases. The current serialization support is appropriate for short term storage or RMI between applications running the same version of Swing. As of 1.4, support for long term storage of all JavaBeansTM has been added to the java.beans package. Please see XMLEncoder.

Wie gesagt, das kann hier nicht das Problem sein, weil ich es auf demselben Computer getestet habe.
 
S

SlaterB

Gast
auf einem Computer können mehrere Java-Versionen installiert sein,
startest du beide Programme gleichartig? (verschieden wäre z.B. einmal per IDE wie Eclipse + einmal per Konsole)

teste erstmal nur mit einem laufenden Programm, welches sowohl einen ServerSocket aufmacht als auch in einem separaten Thread den Client spielt
 

Stefan S.

Aktives Mitglied
auf einem Computer können mehrere Java-Versionen installiert sein,
startest du beide Programme gleichartig? (verschieden wäre z.B. einmal per IDE wie Eclipse + einmal per Konsole)

teste erstmal nur mit einem laufenden Programm, welches sowohl einen ServerSocket aufmacht als auch in einem separaten Thread den Client spielt

Hi,

ich habe die Java Versionen bereits getestet, die beiden Applikationen starten mit exakt derselben Version, nämlich 1.6.0_13.

Ich habe testweise beide Netzwerkkomponenten kompiliert, mit derselben IDE und anschließend ausgeführt um sicherzustellen das es auch dieselbe JDK ist, mit der beide Programme kompiliert wurden.

Egal ob ich beide mit Netbeans über F6 oder direkt über Konsole starte, ich erhalte stets denselben Fehler.

Die Deserialisierung funktioniert innehalb des eigenen Programmes fehlerfrei. Dort lässt sich der byte[] buffer wieder in ein DefaultStyledDocument Object deserialisieren.

Merkwürdig bleibt das die UID immer dieselben oben bleiben, selbst wenn ich ein drittes Sample Programm erstelle.

Die deserialisierten Bytes sind bei beiden Programmen identisch, die haben denselben Hash. Die Daten sind also einwandfrei.

Irgendwo macht mir die UID einen Strich durch die Rechnung. :(
 

Stefan S.

Aktives Mitglied
Nachtrag: Ich habe es jetzt tatsächlich mal einfach an mich selbst geschickt, also App über Socket an sich selbst und dann versucht zu serialisieren. Ich erhalte nun auch den Fehler bei der Deserialisierung. :eek:

Wenn ich den serialiserten byte[] buffer aber gleich deserialisere ohne ihn über Socket zu senden funktioniert es.

Und jetzt kommts.

Sowohl vor dem Senden ... als auch nach Empfang der Nachricht hat der byte[] buffer dieselbe Länge und die Daten darin liefern denselben Hash!

Bei der Übertragung fand also kein Fehler statt.

Ich tappe momentan wirklich im Dunkeln... :eek:
 
S

SlaterB

Gast
wenn du schon so detailliert dabei bis, könntest du auch versuchen, ein kleines Testprogramm zu posten,

alles außer dem Objekt der fraglichen Klasse könnte sofort raus, die Klasse selber, falls eine eigene oder anoynme innere Klasse,
so einfach wie möglich
 

Stefan S.

Aktives Mitglied
wenn du schon so detailliert dabei bis, könntest du auch versuchen, ein kleines Testprogramm zu posten,

Das ist leider nur bedingt möglich. Das minimale Beispielprpgramm basiert auf einer umfangreichen Netzwerkbibliothek mit über 50 Klassen. ;)

alles außer dem Objekt der fraglichen Klasse könnte sofort raus, die Klasse selber, falls eine eigene oder anoynme innere Klasse,
so einfach wie möglich

Ich habe das Problem identifiziert. :lol:

Es liegt an der Konvertierung!

Ich hatte zunächst folgendes gemacht.

Code:
buffer_ = IOUtil.serialize( jTextPane1.getDocument() );

Allerdings hatte ich es nun zunächst in einen String gewandelt.

Code:
String test = new String( buffer_ );

Nun testete ich den Hash:

Code:
Utility.getSha256( test.getBytes() )

Und nun transferierte ich es über das Netzwerk.

Code:
peer.sendToUser(pid, MessageType.ChatM.toString(), test, false);

Anschließend nahm ich erneut den Hash und bekam denselben heraus. Offensichtlich war die Übertragung fehlerfrei.

Mein Fehler war den Hash erst nach der Konvertierung in den String zu ziehen.

Ich habe ihn nun am Anfang direkt aus dem byte[] Array gezogen. Nun ist er zuvor und danach unterschiedlich! Genauer gesagt:

Code:
System.out.println( "Hash: " + Utility.getSha256( buffer_ ) );

liefert ein anderes Ergebnis als

Code:
System.out.println( "Hash: " + Utility.getSha256( new String( buffer_ ).getBytes() ) );

:autsch:

Und wegen dieser Kleinigkeit verschwendete ich gestern 2 Stunden.

Sehr unerwartet... ich dachte diese Form der Konvertierung wäre sicher? ???:L

Ich tippe darauf dass das serialisierte Objekt eine bestimmte Enkodierung enthält, die bei der Konstruktion über String mit dem Standardencoding beschädigt wird.
 
Zuletzt bearbeitet:

Stefan S.

Aktives Mitglied
Achja, ein Abschlussbericht für alle die auf ein ähnliches Problem stoßen. Ich mag keine Forenbeiträge ohne Lösung. ;)

Falls sensible Bytedaten, beispielsweise ein serialisiertes Objekt, in ein String konvertiert werden soll, solltet ihr es zunächst in Base 64 konvertieren. Anschließend kann man leicht String.getBytes() verwenden ohne Angst haben zu müssen dass die Daten falsch en/dekodiert wurden.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Serialisierung in JFrame AWT, Swing, JavaFX & SWT 4
S Serialisierung vor Exit AWT, Swing, JavaFX & SWT 2
J Swing JComboBox Serialisierung AWT, Swing, JavaFX & SWT 2
K JProgressBar für Serialisierung AWT, Swing, JavaFX & SWT 6
B Serialisierung und UIDefaults AWT, Swing, JavaFX & SWT 2
R Swing Mehrere JTextFields mit einem Document Listener AWT, Swing, JavaFX & SWT 2
TheWhiteShadow Swing Document Text Position in Pixel AWT, Swing, JavaFX & SWT 2
D Swing Document-Structure; Element AWT, Swing, JavaFX & SWT 4
B setText() auf TextField mit Document AWT, Swing, JavaFX & SWT 2
A Herausfinden welches Document gesetzt ist AWT, Swing, JavaFX & SWT 4
U Klasse Document ! AWT, Swing, JavaFX & SWT 2
A Wie JTextFields über Document disablen? AWT, Swing, JavaFX & SWT 3
Juelin Für Java-Spezialisten AWT, Swing, JavaFX & SWT 4
Juelin Java <-> Delphi AWT, Swing, JavaFX & SWT 3
H Exceptions seit java: 1.6.0_65 Umstellung AWT, Swing, JavaFX & SWT 3
H Exception: java.lang.ClassCastException AWT, Swing, JavaFX & SWT 2
M JavaFX java.lang.RuntimeException: Error initializing QuantumRenderer: no suitable pipeline found AWT, Swing, JavaFX & SWT 5
J Java GUI Dropdown-Menü anzeigen AWT, Swing, JavaFX & SWT 5
M Eigene Java Klasse für allgemeine Grafikelemente AWT, Swing, JavaFX & SWT 8
thor_norsk Java - Allgemeine - Frage AWT, Swing, JavaFX & SWT 14
W Kennt jemand Dear ImGui (und den Java-Wrapper dazu)? AWT, Swing, JavaFX & SWT 0
B Java Projekt mit JavaFX und jfoenix ausführbar machen AWT, Swing, JavaFX & SWT 46
D JAVA Schieberegler AWT, Swing, JavaFX & SWT 6
N JavaFX Einfacher Taschenrechner mit Scene Builder und Java FX AWT, Swing, JavaFX & SWT 0
Jose05 Aus einer normalen Java Klasse eine FXML-Klasse laden AWT, Swing, JavaFX & SWT 12
S Welches Java Layout sollte ich verwenden? AWT, Swing, JavaFX & SWT 3
B Actionlistener mit Java Swing AWT, Swing, JavaFX & SWT 2
P Fehlermeldung: Error: Could not find or load main class set Caused by: java.lang.ClassNotFoundException: set AWT, Swing, JavaFX & SWT 5
Encera Java FX im Eclipse-Marketplace nichtmehr auffindbar AWT, Swing, JavaFX & SWT 6
_user_q Versionscode aus build.gradle in Java-Klasse ausgeben lassen AWT, Swing, JavaFX & SWT 14
M Java Dateien kopieren mit Fortschrittsbalken AWT, Swing, JavaFX & SWT 13
M Frage zu Java Bundesligaverwaltung AWT, Swing, JavaFX & SWT 7
_user_q Gibt es eine Möglichkeit, in Java alle möglichen Zeichen automatisch tippen zu lassen? AWT, Swing, JavaFX & SWT 13
E 3D-Grafik Java Fatal error bei LWJGL AWT, Swing, JavaFX & SWT 2
Heldderschatten Java Events und Interfaces AWT, Swing, JavaFX & SWT 18
volcanos Scrollen: JScrollPane mit Graphics g und Java-Fonts extends Frame ? AWT, Swing, JavaFX & SWT 5
sserio Java Fx - Problem AWT, Swing, JavaFX & SWT 3
U Warum wird zweimal die Affinetransformation estellt (2Dgraphics, Java)? AWT, Swing, JavaFX & SWT 31
U was bewirkt die methode fill und unterschied zu anderen fill Methoden in 2dgraphics? (Java)? AWT, Swing, JavaFX & SWT 6
DonBronson Java Graphics bewegbar machen (Drag&Drop) AWT, Swing, JavaFX & SWT 3
Yonnig Lokale HTML-Datei in Java GUI rendern AWT, Swing, JavaFX & SWT 4
E Java-TexturePaint sehr langsam AWT, Swing, JavaFX & SWT 9
N Java MySQL Datenbank durchsuchen? AWT, Swing, JavaFX & SWT 7
maximstein JavaFX WebView - java.lang.NoSuchMethodError: 'boolean com.sun.prism.ResourceFactory.isDisposed()' AWT, Swing, JavaFX & SWT 4
Splayfer Custom Font in AttributedString Java AWT, Swing, JavaFX & SWT 4
imawake Java Paket-Tracking Programm 📦 AWT, Swing, JavaFX & SWT 7
izoards *.doc Seitenränder per Java setzen... AWT, Swing, JavaFX & SWT 14
T FXML Datei in Java Code einbinden: javafx.fxml.LoadException AWT, Swing, JavaFX & SWT 2
J Key-Listener in Java AWT, Swing, JavaFX & SWT 37
J Java Datei durch CMD mit Parameter ausführen AWT, Swing, JavaFX & SWT 1
N Java Mouse Listiner macht alles zusammen AWT, Swing, JavaFX & SWT 4
J Java FX NullPointerException, ObservableList wird in View nicht angezeigt.. AWT, Swing, JavaFX & SWT 34
T Exception in thread "main" java.lang.NoClassDefFoundError AWT, Swing, JavaFX & SWT 4
M Error occurred during initialization of boot layer java.lang.module.FindException: Module javafx.controls not found AWT, Swing, JavaFX & SWT 14
AmsananKING Java Menü-Problem AWT, Swing, JavaFX & SWT 1
T Swing DPI-Skalierung und Java 2D unter Java 11 (und Windows 10) AWT, Swing, JavaFX & SWT 2
J Spiel mit Java AWT, Swing, JavaFX & SWT 9
I AWT java.awt.FileDialog - "coffee cup"-Icon lässt sich nicht ersetzen AWT, Swing, JavaFX & SWT 14
O Ein Java-Programm mit Swing steuern AWT, Swing, JavaFX & SWT 1
izoards Java FX Window Event SHOWING AWT, Swing, JavaFX & SWT 17
N FXMLLoader.load java.lang.RuntimeException: Gradle AWT, Swing, JavaFX & SWT 2
T Java GUI - Würfel Programm AWT, Swing, JavaFX & SWT 6
JojoSand Java Programm wird nicht gestartet - keinen Fehlerhinweis AWT, Swing, JavaFX & SWT 9
dtr84 JavaFX/OpenJFX mittels Apache Ivy einbinden (Java 11) AWT, Swing, JavaFX & SWT 18
M Jogl und Java 3d AWT, Swing, JavaFX & SWT 0
S0PEX JavaFX Java 8 auf 15 migrieren OpenJFX mit Gradle eingebunden, jedoch nicht gefunden !? AWT, Swing, JavaFX & SWT 4
I Gui in bestehendes Java-Programm AWT, Swing, JavaFX & SWT 11
V Java-Zeichenfeld mit AWT AWT, Swing, JavaFX & SWT 3
N java Gui friert scheinbar zufällig ein AWT, Swing, JavaFX & SWT 5
T Anderen Java Code durch Code kompilieren und Fehler in Label ausgeben AWT, Swing, JavaFX & SWT 5
P Java Fx einrichten AWT, Swing, JavaFX & SWT 2
pkm Frage wegen java.lang.IllegalStateException bei DocumentListener AWT, Swing, JavaFX & SWT 4
S JavaFX Java Custom Node Grafik zurückgeben AWT, Swing, JavaFX & SWT 2
MiMa Java und JavaFX 13 läuft endlich AWT, Swing, JavaFX & SWT 4
N eclipse Java, bilder benutzten Funktioniert nicht AWT, Swing, JavaFX & SWT 6
Trèfle Ausklappbare Diagramme in Java AWT, Swing, JavaFX & SWT 1
R Java, GUI, Hintergrundbild, Image, AWT, Swing, JavaFX & SWT 4
K JAVA FX Constraints AWT, Swing, JavaFX & SWT 2
F Java FX und webcam AWT, Swing, JavaFX & SWT 1
T Wie kann man in java aufwendige grafiken programmieren AWT, Swing, JavaFX & SWT 1
M Swing Java Swing/AWT Combobox Bug AWT, Swing, JavaFX & SWT 3
S Java GUI durch variable Größe einer Map anpassen AWT, Swing, JavaFX & SWT 3
J Java SWT Tabelleninhalt formattieren AWT, Swing, JavaFX & SWT 10
Blender3D Falsche Werte mit Java Toolkit Screensize AWT, Swing, JavaFX & SWT 4
K Swing AWT-EventQueue-1 java.lang.NoClassDefFoundError bei setVisible(true) AWT, Swing, JavaFX & SWT 3
A Java Programm gestalten AWT, Swing, JavaFX & SWT 4
B [Problem] Java öffnet Word-Datein nicht AWT, Swing, JavaFX & SWT 14
S Swing Java Swing AWT, Swing, JavaFX & SWT 6
I Java Bildfarbe ändern wie bei Photoshop AWT, Swing, JavaFX & SWT 9
R JavaFX Java FXML Vererbung in Klassen AWT, Swing, JavaFX & SWT 9
T Java: Zwei abhängige JSlider machen nicht das, was sie sollen AWT, Swing, JavaFX & SWT 4
J Parallele Aktionen in Java FX richtig durchführen. AWT, Swing, JavaFX & SWT 5
Neumi5694 java.awt.Window nach javafx.stage.Window AWT, Swing, JavaFX & SWT 1
M JavaFX java.lang.IllegalStateException: Location is not set. AWT, Swing, JavaFX & SWT 9
L Java- CardLayout AWT, Swing, JavaFX & SWT 10
M Java zeichnet nicht pixelgenau AWT, Swing, JavaFX & SWT 40
B Swing Eclipse is running under 0, but this Java project has a 1.6 Java compliance level, so WindowBuilder AWT, Swing, JavaFX & SWT 2
L Java- UI zweites Fenster aus einer anderen Klasse öffnen durch ButtonClick AWT, Swing, JavaFX & SWT 4
S Java Gui AWT, Swing, JavaFX & SWT 5
R Sierpinski Dreieck mit Java FX AWT, Swing, JavaFX & SWT 4

Ähnliche Java Themen


Oben