Erreur et manière correcte d'exporter Java : (Recommandé : tutoriel vidéo Java)
错误方式: 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"));
Raison : httpheader exige que son contenu soit iso8859 - 1 encodage, après avoir transmis ces caractères à la destination, le programme de destination utilise la méthode inverse Strings_utf8 = newString(s_iso88591.getBytes("ISO8859-1"),"UTF-8") pour obtenir les caractères chinois corrects" ", ce non seulement garantit le respect de l'accord, mais soutient également la langue chinoise.
En Java, la méthode getBytes() de String consiste à obtenir un tableau d'octets dans le format d'encodage par défaut du système d'exploitation. Cela signifie que sous différents systèmes d'exploitation, les éléments renvoyés sont différents ! La méthode
String.getBytes(Stringdecode) renverra la représentation sous forme de tableau d'octets d'une certaine chaîne dans l'encodage en fonction de l'encodage de décodage spécifié, tel que :
byte[] b_gbk = "中".getBytes("GBK"); byte[] b_utf8 = "中".getBytes("UTF-8"); byte[] b_iso88591 = "中".getBytes("ISO8859-1");
renverra la représentation sous forme de tableau d'octets du caractère chinois "中" en codage GBK, UTF-8 et ISO8859-1 respectivement. À l'heure actuelle, la longueur de
b_gbk est de 2, et
La longueur de b_utf8 est 3, et la longueur de
b_iso88591 est 1.
Contrairement à getBytes, vous pouvez restaurer le caractère "中" via new String(byte[], decode).
Cette nouvelle String(byte[], decode) utilise en fait le. décodage d'encodage spécifié pour analyser l'octet[] dans une chaîne
String s_gbk = new String(b_gbk,"GBK"); String s_utf8 = new String(b_utf8,"UTF-8"); String s_iso88591 = new String(b_iso88591,"ISO8859-1");
En produisant s_gbk, s_utf8 et s_iso88591, vous constaterez que s_gbk et s_utf8 sont tous deux "moyens", et seuls s_iso88591 ne sont pas reconnus (can. être compris comme des caractères tronqués), pourquoi le mot « 中 » ne peut-il pas être restauré après avoir utilisé l'encodage et la recombinaison ISO8859-1 ? La raison est très simple, car la table d'encodage ISO8859-1 ne contient pas du tout de caractères chinois. Bien sûr, il est impossible d'obtenir le caractère "中" correct dans ISO8859-1 via "中".getBytes("ISO8859). -1"); La valeur encodée est déjà là, il est donc impossible de la restaurer via newString().
Par conséquent, lors de l'obtention de byte[] via la méthode String.getBytes(Stringdecode), vous devez vous assurer que la valeur de code représentée par String existe réellement dans la table d'encodage de décodage, afin que le tableau byte[] obtenu peut être restauré correctement.
Remarque :
Parfois, afin d'adapter les caractères chinois à certaines exigences particulières (comme l'en-tête http exigeant que son contenu soit encodé iso8859-1), les caractères chinois peuvent être codés en octets format Pour coder la situation, telle que :
String s_iso88591 = newString("中".getBytes("UTF-8"),"ISO8859-1"), la chaîne s_iso8859-1 ainsi obtenue est en fait trois Pour les caractères ISO8859-1, après avoir transmis ces caractères à la destination, le programme de destination utilise la méthode opposée Strings_utf8 = newString(s_iso88591.getBytes("ISO8859-
Pour plus de connaissances Java, veuillez faire attentionTutoriel de base de Javacolonne
.Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!