Description du problème :
Cette situation se produit souvent dans TOMCAT : la chaîne que nous saisissons est constituée de caractères chinois (l'encodage par défaut est GBK), mais l'encodage par défaut de TOMCAT est Encodage ISO8859-1, il y a donc des erreurs, entraînant des caractères tronqués.
Solution :
Utilisez ISO8859-1 pour convertir à nouveau la chaîne obtenue de Tomcat en un tableau d'octets, puis utilisez GBK pour l'encoder.
package cn.com; public class Test7 { public static void main(String[] args) throws Exception { System.out.println("我们输入的汉字,默认编码是gbk"); String str1="大家好"; System.out.println("str1="+str1); byte [] GBKArr=str1.getBytes("gbk"); //等同于 byte [] b1=s1.getBytes();因为它默认的就是gbk编码 System.out.println("Tomcat,默认编码是ISO8859-1编码"); String str2=new String(GBKArr, "iso8859-1"); System.out.println("str2="+str2);//导致乱码 System.out.println("把从Tomcat得到的字符串再次利用ISO8859-1将其变为字节数组,然后利用GBK进行编码"); byte [] ISOArr =str2.getBytes("iso8859-1"); String result=new String(ISOArr,"gbk");//等同于new String(ISOArr);因为默认的就是gbk编码 System.out.println("result="+result); } }
Tutoriel recommandé : Java Quick Start
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!