Heim  >  Artikel  >  Java  >  Java-Fehler: Java11 UTF-8-Eigenschaftendateifehler, wie man damit umgeht und ihn vermeidet

Java-Fehler: Java11 UTF-8-Eigenschaftendateifehler, wie man damit umgeht und ihn vermeidet

WBOY
WBOYOriginal
2023-06-25 09:26:271584Durchsuche

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:

  • Beim Lesen der Eigenschaftendatei verwendet Java11 standardmäßig die UTF-8-Codierung.
  • Während des Lesens der Eigenschaftendatei liest Java sie Byte für Byte gemäß den UTF-8-Codierungsregeln.
  • Wenn eine Bytesequenz gelesen wird, die Nicht-ASCII-Zeichen enthält, versucht Java, sie in Unicode-Zeichen umzuwandeln.
  • Wenn die gelesene Bytesequenz gemäß den UTF-8-Kodierungsregeln nicht in Unicode-Zeichen dekodiert werden kann, wird eine MalformedInputException-Ausnahme ausgelöst.

2. So vermeiden Sie UTF-8-Attributdateifehler

  1. Ändern Sie die Attributdateikodierung

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.

  1. Ändern Sie den Code, der die Eigenschaftendatei liest.

Ä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:

  1. Überprüfen Sie, ob die Eigenschaftendatei Nicht-ASCII-Zeichen enthält

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.

  1. Bestätigen Sie das Codierungsformat der Eigenschaftendatei.

Ö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.

  1. Ändern Sie das Codierungsformat der Eigenschaftendatei oder lesen Sie den Code der Eigenschaftendatei.

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn