Heim >Java >javaLernprogramm >Java-Fehler: Java11 UTF-8-Eigenschaftendateifehler, wie man damit umgeht und ihn vermeidet
Java ist eine plattformübergreifende Programmiersprache, die häufig in der Entwicklung von Webanwendungen, mobilen Anwendungen, Desktop-Anwendungen und anderen Bereichen verwendet wird. Wenn Java-Entwickler Code schreiben, müssen sie häufig Eigenschaftsdateien verwenden, um Konfigurationsinformationen, internationalisierte Zeichenfolgen und andere Daten zu speichern. Bei Anwendungen, die mit Java 11 entwickelt wurden, können jedoch Fehler in der UTF-8-Eigenschaftsdatei auftreten. In diesem Artikel wird erläutert, wie Fehler in der Java11 UTF-8-Eigenschaftsdatei behandelt und vermieden werden.
1. Symptome von UTF-8-Eigenschaftendateifehlern
Wenn Sie in Java 11 die UTF-8-Codierung zum Speichern einer Eigenschaftendatei verwenden und die Eigenschaftendatei chinesische, japanische und andere Nicht-ASCII-Zeichen enthält, kann es zu Problemen kommen Folgende Ausnahme:
java.nio.charset.MalformedInputException: Input length = 1 at java.base/java.nio.charset.CoderResult.throwException(CoderResult.java:274) at java.base/sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:339) at java.base/sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178) at java.base/java.io.InputStreamReader.read(InputStreamReader.java:185) at java.base/java.io.BufferedReader.fill(BufferedReader.java:161) at java.base/java.io.BufferedReader.readLine(BufferedReader.java:326) at java.base/java.io.BufferedReader.readLine(BufferedReader.java:392)
Es ist schwierig, die Grundursache des Problems mit dieser Ausnahmemeldung zu erkennen, aber durch Analyse können wir die folgenden Schlussfolgerungen ziehen:
2. So vermeiden Sie UTF-8-Attributdateifehler
Wenn die oben genannte Ausnahme beim Speichern der Attributdatei mit UTF-8-Kodierung auftritt, können Sie versuchen, die Kodierung der Attributdatei zu ändern Attributdatei nach ISO-8859-1 oder GB2312 und anderen Kodierungsformaten. Diese beiden Codierungsformate unterstützen keine Unicode-Zeichen, sodass keine MalformedInputException auftritt. Es ist jedoch zu beachten, dass eine Änderung des Kodierungsformats dazu führen kann, dass Nicht-ASCII-Zeichen verloren gehen oder verstümmelt werden.
Ändern Sie den Code, der die Eigenschaftendatei liest, um den richtigen Zeichensatz zum Lesen der Eigenschaftendatei zu verwenden. Wenn in Java11 die Properties-Klasse zum Lesen von Eigenschaftendateien verwendet wird, wird standardmäßig die ISO-8859-1-Kodierung verwendet, sodass beim Lesen von Nicht-ASCII-Zeichen wie Chinesisch möglicherweise verstümmelte Zeichen erscheinen. Sie können den folgenden Code verwenden, um die Eigenschaftendatei im UTF-8-Format zu lesen:
InputStream inputStream = this.getClass().getResourceAsStream("/test.properties"); Reader reader = new InputStreamReader(inputStream, StandardCharsets.UTF_8); Properties properties = new Properties(); properties.load(reader);
Diese Methode legt das Codierungsformat der Eigenschaftendatei auf UTF-8 fest, um sicherzustellen, dass Eigenschaftendateien, die Nicht-ASCII-Zeichen wie Chinesisch enthalten, nicht übertragen werden können richtig gelesen.
3. So gehen Sie mit Fehlern in der UTF-8-Eigenschaftendatei um
Wenn Sie auf einen Fehler in der UTF-8-Eigenschaftendatei gestoßen sind, können Sie ihn mit den folgenden Schritten beheben:
Verwenden Sie einen beliebigen Texteditor, öffnen Sie die Eigenschaftendatei und prüfen Sie, ob der Dateiinhalt chinesische, japanische, koreanische und andere Nicht-ASCII-Zeichen enthält. Wenn die Eigenschaftendatei diese Zeichen nicht enthält, müssen Sie nach anderen Problemen im Code suchen.
Öffnen Sie die Eigenschaftendatei mit einem Texteditor und überprüfen Sie das Codierungsformat der Datei. Wenn die Datei im UTF-8-Codierungsformat vorliegt und Nicht-ASCII-Zeichen enthält, kann eine MalformedInputException-Ausnahme auftreten.
Je nach spezifischer Situation können Sie das Codierungsformat der Eigenschaftendatei ändern oder den Code der Eigenschaftendatei lesen, um die MalformedInputException zu vermeiden oder zu lösen Ausnahme.
Kurz gesagt: Wenn Sie Eigenschaftsdateien im UTF-8-Kodierungsformat in Java11 verwenden, müssen Sie der Frage der Zeichensatzkodierung besondere Aufmerksamkeit schenken. Durch die korrekte Einstellung des Codierungsformats und des Codes zum Lesen der Eigenschaftendatei kann das Problem von Fehlern in der UTF-8-Eigenschaftsdatei wirksam vermieden werden.
Das obige ist der detaillierte Inhalt vonJava-Fehler: Java11 UTF-8-Eigenschaftendateifehler, wie man damit umgeht und ihn vermeidet. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!