>Java >Java베이스 >Java에서 Excel로 내보낸 잘못된 코드에 대한 솔루션

Java에서 Excel로 내보낸 잘못된 코드에 대한 솔루션

尚
원래의
2019-12-05 10:41:513655검색

Java에서 Excel로 내보낸 잘못된 코드에 대한 솔루션

잘못된 방법:

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"));

원인: httpheader에서는 해당 내용을 iso8859-1로 인코딩해야 합니다. 이러한 문자를 대상에 전달한 후 대상 프로그램은 Strings_utf8 = newString(s_iso88591. getBytes("ISO8859-1"),"UTF-8")를 사용하여 프로토콜 준수를 보장할 뿐만 아니라 중국어도 지원하는 올바른 중국어 문자 "中"을 가져옵니다.

Java에서 String의 getBytes() 메서드는 운영 체제의 기본 인코딩 형식으로 바이트 배열을 가져오는 것입니다. 이는 운영 체제에 따라 반환되는 내용이 다르다는 것을 의미합니다.

String.getBytes(Stringdecode) 메서드는 다음과 같이 지정된 디코드 인코딩에서 특정 문자열의 바이트 배열 표현을 반환합니다. GBK, UTF-8, ISO8859-1 인코딩으로 한자 "中"의 바이트 배열 표현. 이때

b_gbk의 길이는 2,

b_utf8의 길이는 3,

의 길이 b_iso88591은 1입니다.

getBytes와 비교하면 new String(byte[], decode)를 통해 "中" 문자를 복원할 수 있습니다.

이 new String(byte[], decode)는 실제로 지정된 인코딩을 사용하여 byte[]로 구문 분석됩니다.

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

s_gbk, s_utf8 및 s_iso88591을 출력하면 s_gbk 및 s_utf8이 모두 "medium"이라는 것을 알 수 있지만 s_iso88591만 인식할 수 없는 문자입니다(잘못된 코드로 이해될 수 있음). 왜 -1 인코딩 이후에 ISO8859를 사용합니까? 그리고 재조합하면 '中'이라는 단어는 복원할 수 없나요?

이유는 매우 간단합니다. 왜냐하면 ISO8859-1 인코딩의 인코딩 테이블에는 한자가 전혀 포함되어 있지 않기 때문입니다. 물론 "中".getBytes("를 통해 ISO8859-에서 올바른 "中" 문자를 얻는 것은 불가능합니다. ISO8859-1"); 1에 코딩된 값이 없어져 newString()을 통해서는 복원이 불가능합니다.

따라서 String.getBytes(Stringdecode) 메소드를 통해 byte[]를 얻을 때 String이 표현하는 코드 값이 디코드 인코딩 테이블에 실제로 존재하는지 확인해야 획득된 byte[] 배열이 올바르게 복원될 수 있습니다. .

더 많은 Java 지식을 알고 싶다면

java 기본 튜토리얼

칼럼을 주목해주세요. 참고:

때때로 특정 특수 요구 사항(예: 내용이 iso8859-1로 인코딩되어야 하는 httpheader)에 중국어 문자를 적용하기 위해 중국어 문자를 다음과 같은 바이트 형식으로 인코딩할 수 있습니다.

String s_iso88591 = newString("中".getBytes("UTF-8"),"ISO8859-1") 이렇게 얻은 s_iso8859-1 문자열은 실제로 ISO8859-1의 세 글자인데, 이 문자들을 대상 프로그램은 반대 방법 Strings_utf8 = newString(s_iso88591.getBytes("ISO8859-1"), "UTF-8")을 사용하여 올바른 중국어 문자 "中"을 가져옵니다. 이는 계약 조항을 준수하고 중국어도 지원합니다.

위 내용은 Java에서 Excel로 내보낸 잘못된 코드에 대한 솔루션의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.