문제 설명:
이 상황은 TOMCAT에서 자주 발생합니다. 입력한 문자열은 중국어이지만(기본 인코딩은 GBK) TOMCAT의 기본값은 ISO8859-1 인코딩이므로 오류가 발생하여 생성이 발생합니다. 왜곡된 문자들.
해결책:
ISO8859-1을 사용하여 Tomcat에서 얻은 문자열을 다시 바이트 배열로 변환한 다음 GBK를 사용하여 인코딩합니다.
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); } }
추천 튜토리얼: java 빠른 시작
위 내용은 Java의 문자열은 항상 깨집니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!