Heim >Java >JavaBase >Gründe und Lösungen für verstümmelte Zeichen, die aus Java nach Excel exportiert wurden

Gründe und Lösungen für verstümmelte Zeichen, die aus Java nach Excel exportiert wurden

尚
Original
2019-11-29 10:37:147147Durchsuche

Gründe und Lösungen für verstümmelte Zeichen, die aus Java nach Excel exportiert wurden

Fehler und korrekter Weg zum Java-Export: (Empfohlen: Java-Video-Tutorial)

错误方式:
response.setHeader("Content-Disposition", "inline;filename="+ new String(fileName.getBytes(),"utf-8"));
String fileName =    aicaseNodeDeptService.getFilename(request)+".xlsx";
 
response.setCharacterEncoding("UTF-8");
response.setContentType("application/ms-excel");
正确的方式:
response.setHeader("Content-Disposition",
        "inline;filename="+
                new String(fileName.getBytes("utf-8"),"iso8859-1"));

Grund: httpheader erfordert, dass sein Inhalt iso8859 sein muss - 1-Kodierung: Nachdem diese Zeichen an das Ziel übergeben wurden, verwendet das Zielprogramm die entgegengesetzte Methode Strings_utf8 = newString(s_iso88591.getBytes("ISO8859-1"),"UTF-8"), um die richtigen chinesischen Zeichen zu erhalten stellt nicht nur die Einhaltung der Vereinbarung sicher, sondern unterstützt auch die chinesische Sprache.

In Java dient die getBytes()-Methode von String dazu, ein Byte-Array im Standardcodierungsformat des Betriebssystems abzurufen. Dies bedeutet, dass unter verschiedenen Betriebssystemen die zurückgegebenen Dinge unterschiedlich sind!

Die Methode String.getBytes(Stringdecode) gibt die Byte-Array-Darstellung einer bestimmten Zeichenfolge in der Codierung entsprechend der angegebenen Decodierungscodierung zurück, wie zum Beispiel:

byte[] b_gbk = "中".getBytes("GBK");
byte[] b_utf8 = "中".getBytes("UTF-8");
byte[] b_iso88591 = "中".getBytes("ISO8859-1");

gibt die Byte-Array-Darstellung des chinesischen Zeichens „中“ in GBK-, UTF-8- bzw. ISO8859-1-Kodierung zurück. Zu diesem Zeitpunkt beträgt die Länge von

b_gbk 2. und

Die Länge von b_utf8 ist 3, und die Länge von

b_iso88591 ist 1.

Im Gegensatz zu getBytes können Sie das „中“-Zeichen durch new String(byte[], decode) wiederherstellen.

Dieser neue String(byte[], decode) verwendet tatsächlich das angegebene Kodierung zum Parsen von Byte[] in eine Zeichenfolge als verstümmelte Zeichen verstanden werden), warum kann das Wort „中“ nach Verwendung der ISO8859-1-Kodierung und Neukombination nicht wiederhergestellt werden? Der Grund ist sehr einfach, denn die Kodierungstabelle der ISO8859-1-Kodierung enthält überhaupt keine chinesischen Zeichen. Natürlich ist es unmöglich, das richtige „中“-Zeichen in ISO8859-1 über „中“.getBytes(“ISO8859“ zu erhalten -1"); Der codierte Wert ist bereits vorhanden, daher ist es unmöglich, ihn über newString() wiederherzustellen.

Daher müssen Sie beim Abrufen von Byte [] über die Methode String.getBytes (Stringdecode) sicherstellen, dass der durch String dargestellte Codewert tatsächlich in der Dekodierungstabelle vorhanden ist, sodass das erhaltene Byte []-Array vorhanden ist korrekt wiederhergestellt werden kann.

Hinweis:

Manchmal können die chinesischen Zeichen in Byte codiert werden, um chinesische Zeichen an bestimmte spezielle Anforderungen anzupassen (z. B. wenn der Inhalt eines HTTP-Headers ISO8859-1-codiert sein muss). Format Um die Situation zu kodieren, wie zum Beispiel:

String s_iso88591 = newString("中".getBytes("UTF-8"),"ISO8859-1"), ist die auf diese Weise erhaltene Zeichenfolge s_iso8859-1 tatsächlich drei Für Zeichen in ISO8859-1 verwendet das Zielprogramm nach der Übergabe dieser Zeichen an das Ziel die entgegengesetzte Methode Strings_utf8 = newString(s_iso88591.getBytes("ISO8859-

Für weitere Java-Kenntnisse achten Sie bitte darauf

Java Basics Tutorial

Spalte .

Das obige ist der detaillierte Inhalt vonGründe und Lösungen für verstümmelte Zeichen, die aus Java nach Excel exportiert wurden. 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