Probleme bei Stringvergleichen (Windows/Linux)

Zitzit

Mitglied
Hi,
ich habe seit längerem ein sehr merkwürdiges Problem was ich mir nicht erklären kann.

Situation 1:
- MySQL-DB auf einem Windows 7 Rechner (Encoding: UTF-8)
- Das Programm (JAR-Datei) liegt ebenfalls auf dem Windows 7 Rechner und benötigt zur Laufzeit eine DB-Connection zu der MySQL-DB (funktioniert ast rein)

Situation 2:
- MySQL-DB auf einem Linux Server (Encoding: UTF-8)
- Das Programm (JAR-Datei) liegt ebenfalls auf dem Linux Server und benötigt zur Laufzeit eine DB-Connection zu der MySQL-DB (funktioniert ast rein)
- Das Programm, welches sich auf dem Linux Server befindet, wird via Netzwerk von einem PC mit Windows 7 ausgeführt

Im ersten Fall (alles auf Windows 7 Rechner) funktioniert alles perfekt. Im zweiten Fall (Linux Server) funktionieren teilweise die Stringvergleiche nicht mehr:

Ich erhalte in einigen Fällen aus der Datenbank folgende Strings: "textvorher ?text? textnachher". "?" scheint ein Encoding-Fehler bei der Befüllung der Datenbank gewesen zu sein, worauf ich allerdings keinen Einfluss habe. Das eigentliche Zeichen war anscheinend ein Hochkomata o.ä. (zumindest würde dies zu der Struktur der Strings passen). Genau bei diesem Zeichen fliegen mir die EQUALS-Stringvergleiche in Situation 2 (Linux Server) um die Ohren... Bei Situation 1 (Win 7 Rechner) habe ich diese Problematik nicht. Hier ein Beispiel:

Java:
//Input1 kommt aus der DB
String input1 = "?hallo?" 
//Input2 kommt aus der Quelle aus welcher "input1" ebenfalls vor der DB-Speicherung kam
String input2 = "?hallo?"
if(input1.equals(input2)){

} else {
   //Speicherung von "input2" in der Datenbank (andere Tabelle als die wo input1 gespeichert ist)
}

Bei diesem Beispiel würde die IF-Kaskade in den ELSE-Block springen, da der EQUALS-Vergleich false ergibt, und folglich den "neuen" Wert (input2) in ebenfalls in der Datenbank speichern. Wenn ich nun allerdings beide Werte aus der Datenbank per select auswähle, in Strings speicher und diese wiederum per EQUALS vergleiche sind sie auf einmal identisch bzw. EQUALS gibt true zurück.

Da ich das Problem bei der Situation 1 (alles auf Win 7 Rechner) nicht habe, tippe ich ganz stark auf ein Encoding-Problem. Allerdings habe ich keine Ahnung wo ich da überhaupt ansetzen könnte, da der gesamte Background (Datenbank und die Datenquelle für "input2" sowie dessen Verarbeitung) auf UTF-8-Encoding eingestellt ist. Da andere Sonderzeichen (wie " oder ä etc.) funktionieren Tippe ich ebenfalls darauf, dass bereits die Formatierung in der Datenquelle falsch/defekt ist.

Ich hoffe ich konnte mein Problem einigermaßen gut darstellen, aber ich muss gestehen, dass mir zur Beschreibung des Problems irgendwie die Fachwörter fehlen :/ Vorschläge für Google-Suchtexte würden mir auch schon weiterhelfen (da wollen mir einfach keine kurzen und prägnanten Schlüsselworte einfallen).

Vielen Dank schon mal im vor raus,

Zitzit
 

thE_29

Top Contributor
Wenn die DB in Latin1 läuft, wird sich das mit öäü usw auch decken, weil die auch bei UTF-8 an der gleichen Stelle sind..

Schreib mal ein € Zeichen rein, weil das gibts in Latin1 (ISO-8859-1) gar nicht, sondern nur in Latin-9 (ISO-8859-15)!
 

fastjack

Top Contributor
Ist jetzt aus dem blauen Dunst, aber ich denke bei der MySQL-Verbindung (in dem Verbindungsstring) aus Java raus, muß Du auch das Encoding UTF8 explizit mit angeben, da er sonst die Daten nach dem Client Encoding encoded.
 

mfernau

Bekanntes Mitglied
War eben auch so meine Vermutung dass die Datenbank unter Linux mit latin1 läuft. Unter Windows stadardmässig vll mit UTF8?
Wo Deine JAR-Datei letzten endes liegt sollte egal sein. Auch die Verarbeitung der Daten innerhalb von Java müsste egal sein. Java arbeitet intern IIRC mit UTF-8
 

fastjack

Top Contributor
Du braucht so etwas hier beim Verbinden:

Code:
jdbc:mysql://hostname:port/database?useUnicode=true&characterEncoding=utf8

und beim Datenbank erstellen

Code:
CREATE DATABASE meineDB CHARACTER SET utf8 COLLATE utf8_bin;

nützlich ist es auch die Settings in der mysql-Console abzufragen

Code:
status;
 

Zitzit

Mitglied
Wenn die DB in Latin1 läuft, wird sich das mit öäü usw auch decken, weil die auch bei UTF-8 an der gleichen Stelle sind.. Schreib mal ein € Zeichen rein, weil das gibts in Latin1 (ISO-8859-1) gar nicht, sondern nur in Latin-9 (ISO-8859-15)!

Also die DB ist komplett in UTF-8. Eurozeichen etc. werden perfekt angezeigt.
Sowohl die DB-Schema-Collation als auch die der einzelnen Tabellen sind auf UTF-8 umgestellt. Lediglich die Table-Columns verwenden als Collation "Table-Default", aber die ist ja UTF-8.

Für den MySQL-Server ist mir allerdings im Bereich der System Variables aufgefallen, dass bei folgenden charset/collation Einstellungen nicht UTF-8 sonder Latin1 eingestellt ist:
character_set_client = latin1
character_set_connection = latin1
character_set_database = latin1
character_set_filesystem = binary
character_set_results = latin1
character_set_server = latin1
character_set_system = latin1
collation_connection = latin1_swedish_ci
collation_database = latin1_swedish_ci
collation_server = latin1_swedish_ci

Was diese Einstellungen allerdings bedeuten, habe ich keine Ahnung und es verwundert mich ebenfalls, dass ich diese nicht für mein Schema seperat einstellen kann (in der MySQL Workbench kann ich nicht mal diese System Variables ändern :/ ).

Ist jetzt aus dem blauen Dunst, aber ich denke bei der MySQL-Verbindung (in dem Verbindungsstring) aus Java raus, muß Du auch das Encoding UTF8 explizit mit angeben, da er sonst die Daten nach dem Client Encoding encoded.

Ok das werde ich direkt mal testen!!! Und melde die Ergebnisse ;)

War eben auch so meine Vermutung dass die Datenbank unter Linux mit latin1 läuft. Unter Windows stadardmässig vll mit UTF8? Wo Deine JAR-Datei letzten endes liegt sollte egal sein. Auch die Verarbeitung der Daten innerhalb von Java müsste egal sein. Java arbeitet intern IIRC mit UTF-8

In der ganzen Encoding-Fehlersuchgeschichte habe ich mir mittlerweile ebenfalls die Einstellungen von Eclipse selbst angeschaut. Diese sind merkwürdigerweise (außer für XML Dateien) auf Latin1 (ISO-8859-1) oder Cp1252 (Win ANSI) eingestellt. Macht es hier nicht generell Sinn dies auf UTF-8 zu ändern? Mir ist nämlich ebenfalls aufgefallen das wenn ich mein Programm direkt auf dem Linux Server ausführe sämtliche Umlaute etc. nicht angezeigt werden.
 
Zuletzt bearbeitet:

Zitzit

Mitglied
jdbc:mysql://hostname:port/database?useUnicode=true&characterEncoding=utf8

Es funktioniert!!! Einfach verrückt! Vielen vielen Dank ;)

Aber noch ein mal generell zu dem Encoding der Java-Dateien selbst:
Ist es sinnvoll die Default-Eclipse-Encodings auf UTF-8 zu ändern? oder könnte es da neue Probleme geben? Ich will mein Programm zwar nicht auf Linux ausführen, aber wer weiss was in der Zukunft so alles noch ansteht... Und da denke ich wäre (insbesondere wenn man eine deutsche GUI hat) die Umstellung auf UTF-8 durchaus sinnig. Neben Linux vermute ich mal das die gleiche Problematik ebenfalls bei MAC's der Fall wäre? was ja letztendlich den Gedanken von Java ein bißchen ruiniert oder?

P.S.: Das merkwürdige Zeichen war doch kein Hochkommata. Habe ein derartiges Symbol noch nie in meinem Leben gesehen ;)
 

thE_29

Top Contributor
Pass auf das du aber nicht UTF-8 mit BOM nimmst!

Eclipse, etc. kann das zwar kompilieren, aber javac stellts dann auf, weil die BOM eigentlich für Editoren da sind und viele Programme mit dem nicht umgehen können...

Und wenn man auf unterschiedlichen Systemen ENTWICKELT, macht es durchaus Sinn die .java Dateien auf UTF-8 zu setzen..

Aber wenn keine Strings drinnen sind und man keine öäü in Klassenvariablen oder Klassennamen nutzt oder auf Linux, Windows und/oder Mac OS gleichzeitig entwickelt, sollte es egal sein..

Bei dir war ja auch nicht das Problem, dass die .java Dateien nicht in UTF-8 waren, sondern dass die DB-Verbindung automatisch das Systemencoding beim Verbinden nimmt, wenn man NICHTS angibt..
 

Zitzit

Mitglied
Pass auf das du aber nicht UTF-8 mit BOM nimmst!
Si! ;)

Aber wenn keine Strings drinnen sind und man keine öäü in Klassenvariablen oder Klassennamen nutzt oder auf Linux, Windows und/oder Mac OS gleichzeitig entwickelt, sollte es egal sein..

Naja die Problematik war allerdings auch das in der GUI die Buttontexte etc. (wenn ich das Programm auf dem Linux Server gestartet habe) nicht angezeigt werden. Außerdem kommentiere ich doch ganz gerne kritische Methoden zusätzlich ausführlich in deutsch um Übersetzfehler zu vermeiden.

Auf jedenfall tausend Dank an Euch alle! ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
C Probleme beim Erstellen eines runnable-jar files Allgemeine Java-Themen 1
S Umstellung von File auf Path - Probleme mit Stream Allgemeine Java-Themen 5
C Probleme mit javax.mail.Session Allgemeine Java-Themen 8
M tomcat probleme Allgemeine Java-Themen 1
N Division macht Probleme Allgemeine Java-Themen 14
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
MarvinsDepression Probleme mit relativem Dateipfad Allgemeine Java-Themen 1
G Geotools Probleme nach PC-Wechsel Allgemeine Java-Themen 6
nibe1501 GUI Probleme Allgemeine Java-Themen 16
C Probleme mit dem WindowBuilder Allgemeine Java-Themen 3
P Selenium . Probleme ein Iron Icon Element anzusprechen Allgemeine Java-Themen 2
B Compiler-Fehler Probleme beim Kompilieren mit Jsoup Allgemeine Java-Themen 8
K VisualVM Profiling Remote Probleme Allgemeine Java-Themen 1
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
M Probleme bei Eclipse wenn ich entpacke Allgemeine Java-Themen 15
D Regex Probleme Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
L Vererbung Verständnis Probleme Vererbung Allgemeine Java-Themen 2
Dann07 Probleme mit OpenAL Allgemeine Java-Themen 0
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
V Compiler-Fehler Online Compiler Probleme Allgemeine Java-Themen 4
M Probleme mit Negamax-Algorithmus Allgemeine Java-Themen 29
M Probleme mit BigDecimal Allgemeine Java-Themen 1
T Probleme mit NumberFormat Allgemeine Java-Themen 5
J Probleme exe-Start mit Task Scheduler Allgemeine Java-Themen 1
B Input/Output Probleme beim Ausführen von Shell-Befehlen mit Java Allgemeine Java-Themen 28
J Probleme beim einbinden von Zip4j library Allgemeine Java-Themen 6
F Variablen Palindromzahl (Probleme mit Methode) Allgemeine Java-Themen 9
K Data Konverter - Probleme mit Byte[] Kodierung Allgemeine Java-Themen 3
T Probleme mit dem Pfad zum Propertie file Allgemeine Java-Themen 7
H Swing HashMap zu Tabelle macht mir Probleme Allgemeine Java-Themen 4
Neoline Interpreter-Fehler Probleme mit Arrays.toString Allgemeine Java-Themen 7
F SQLite mit Java / Probleme beim INSERT Befehl Allgemeine Java-Themen 4
J Erste Schritte Probleme mit der Hauptklasse Allgemeine Java-Themen 14
J Tetris Probleme bei Klassen Allgemeine Java-Themen 14
J MinMax VierGewinnt Probleme Allgemeine Java-Themen 22
J Probleme mit CodeCoverage und Lombok Equals Allgemeine Java-Themen 1
S Eclipse Probleme beim Implementieren / Ausführen von jUnit 5-Test Suites Allgemeine Java-Themen 14
R Snake Probleme Allgemeine Java-Themen 2
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
RalleYTN 3D Objekt Translation basierend auf Rotation (Probleme mit Z Rotation) Allgemeine Java-Themen 0
Bluedaishi Druck Probleme mit PDF dateien Allgemeine Java-Themen 4
G Ant Probleme bei einer Installation die Apache ant+ivy verwendet Allgemeine Java-Themen 14
E TableView Probleme Allgemeine Java-Themen 7
perlenfischer1984 Probleme beim Mocken Allgemeine Java-Themen 6
S Kaffemaschine Programmierung Probleme Allgemeine Java-Themen 2
K Threads Runtime und Process Probleme Allgemeine Java-Themen 3
S Probleme mit unterschiedlichen Java-Versionen (Mac OS X 10.11) Allgemeine Java-Themen 0
S Event Handling keyPressed()-Probleme Allgemeine Java-Themen 2
VfL_Freak Große und seltsame Probleme nach Java-Update auf V1.8.0_91 Allgemeine Java-Themen 3
P Probleme mit Grafik (Java) Allgemeine Java-Themen 6
R probleme beim starten von jar unter linux Allgemeine Java-Themen 2
H Probleme mit DAY_OF_WEEK Allgemeine Java-Themen 4
Arif Probleme mit NullPointerException Allgemeine Java-Themen 2
E Probleme mit nextInt() und Exception Allgemeine Java-Themen 35
Streeber Probleme mit AWT-EventQueue: ArrayList Elemente hinzufügen Allgemeine Java-Themen 1
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
M Probleme beim rechnen, bei Zahlen mit führenden Nullen. Allgemeine Java-Themen 7
RalleYTN Probleme mit Encrypting Allgemeine Java-Themen 10
M Probleme mit Schriftarten PDFBox Allgemeine Java-Themen 3
J Probleme mit der Java-Runtime Allgemeine Java-Themen 10
G Probleme mit BufferedWriter und URL Allgemeine Java-Themen 4
S Probleme mit meinem MacBook Pro DRINGEND HILFE erbeten! Allgemeine Java-Themen 17
Androbin Interpreter-Fehler Probleme mit Rekursion - StackOverflowError Allgemeine Java-Themen 8
E JCuda-0.6.5 Probleme beim ausführen der Datei Allgemeine Java-Themen 0
M Runtime.exec() verursacht auf manchen Systemen Probleme - Ursache unklar Allgemeine Java-Themen 2
W JNDI - LDAP - Probleme beim editieren von Usern Allgemeine Java-Themen 0
R DBUnit Performance Probleme Allgemeine Java-Themen 0
S Probleme mit Collection Allgemeine Java-Themen 7
L Probleme mit Jar Allgemeine Java-Themen 6
N Zahlensysteme umrechnen; Probleme beim Umwandeln Allgemeine Java-Themen 4
K OOP OOP Gui Spiel + Vererbungen Probleme durch Nichtwissen!! Allgemeine Java-Themen 1
F Java Native/Shared Library (.so) laden macht Probleme Allgemeine Java-Themen 3
J Synchronized Probleme Allgemeine Java-Themen 7
J Java Progressbar & Download Probleme Allgemeine Java-Themen 10
S Probleme mit dem filechooser Allgemeine Java-Themen 1
J Comperator Probleme Allgemeine Java-Themen 4
A Probleme beim auslesen von Quelltext (HTML) Allgemeine Java-Themen 5
S Probleme mit Webappplikation Allgemeine Java-Themen 5
L Plötzlich Probleme mit der JVM :( Allgemeine Java-Themen 6
S starke performance probleme des forums Allgemeine Java-Themen 10
K Probleme bei Berechnung der Komplexität Allgemeine Java-Themen 7
R JRE Ablaufdatum seit 7u10 - Probleme bei selbst ausgelieferter JRE bekannt? Allgemeine Java-Themen 3
H Reg Exp Probleme Allgemeine Java-Themen 5
M Classpath Probleme bei JAR Generierung Allgemeine Java-Themen 2
S Probleme mit JAVA-Installation Allgemeine Java-Themen 3
D Probleme bei for-Schleife Allgemeine Java-Themen 4
R Probleme mit Javadoc Allgemeine Java-Themen 2
G Gson Probleme Allgemeine Java-Themen 2
P KI für TicTacToe programmieren > Probleme Allgemeine Java-Themen 2
M Google App Engine macht Probleme Allgemeine Java-Themen 4
H Probleme mit finally-Block und close() Allgemeine Java-Themen 4
F 2d array probleme Allgemeine Java-Themen 2
M 3D-Grafik Probleme beim drehen von Objekten Allgemeine Java-Themen 9
T Interface Probleme Allgemeine Java-Themen 8
C Eclipse Probleme bei selbst erstelltem Algorithmus Allgemeine Java-Themen 2
M Probleme mit String in Label übergeben. Allgemeine Java-Themen 6
H MediaManager Fragen/Probleme Allgemeine Java-Themen 6
U Probleme mit Kopiervorgang Allgemeine Java-Themen 3
S Probleme beim Auslesen einer Liste Allgemeine Java-Themen 8

Ähnliche Java Themen

Neue Themen


Oben