찾다
JavaJava베이스Java에서 Excel로 내보낸 문자가 왜곡되는 이유와 해결 방법

Java에서 Excel로 내보낸 문자가 왜곡되는 이유와 해결 방법

Java를 내보내는 잘못된 방법과 올바른 방법: (권장: 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"));

이유: 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[] 배열이 올바르게 복원될 수 있습니다. .

참고:

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

String s_iso88591 = newString("中".getBytes("UTF-8"),"ISO8859-1") 이렇게 얻은 s_iso8859-1 문자열은 실제로 ISO8859-1의 세 글자인데, 이 문자들을 대상 프로그램은 반대 방법을 사용합니다. Strings_utf8 = newString(s_iso88591.getBytes("ISO8859-

Java에 대한 자세한 내용은

java 기본 튜토리얼

열을 참고하세요.

위 내용은 Java에서 Excel로 내보낸 문자가 왜곡되는 이유와 해결 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Java (Serial, Parallel, CMS, G1, ZGC)의 다른 쓰레기 수집 알고리즘은 무엇입니까?Java (Serial, Parallel, CMS, G1, ZGC)의 다른 쓰레기 수집 알고리즘은 무엇입니까?Mar 14, 2025 pm 05:06 PM

이 기사에서는 다양한 Java Garbage Collection 알고리즘 (Serial, Parallel, CMS, G1, ZGC), 성능 영향 및 큰 힙이있는 응용 분야에 대한 적합성에 대해 설명합니다.

JVM (Java Virtual Machine)은 무엇이며 내부적으로 어떻게 작동합니까?JVM (Java Virtual Machine)은 무엇이며 내부적으로 어떻게 작동합니까?Mar 14, 2025 pm 05:05 PM

이 기사는 JVM (Java Virtual Machine)에 대해 설명하여 다양한 플랫폼에서 Java 프로그램을 실행하는 데있어 역할을 자세히 설명합니다. JVM의 내부 프로세스, 주요 구성 요소, 메모리 관리, 쓰레기 수집 및 성능 Optimizatio를 설명합니다.

JavaScript로 스크립팅하는 데 Java의 Nashorn 엔진을 어떻게 사용합니까?JavaScript로 스크립팅하는 데 Java의 Nashorn 엔진을 어떻게 사용합니까?Mar 14, 2025 pm 05:00 PM

Java의 Nashorn Engine을 사용하면 Java 앱 내에서 JavaScript 스크립팅이 가능합니다. 주요 단계로는 내슈런 설정, 스크립트 관리 및 성능 최적화가 포함됩니다. 주요 이슈에는 NASHORN의 감가 상기 거점으로 인한 보안, 메모리 관리 및 향후 호환성이 포함됩니다.

자동 리소스 관리에 Java의 Try-With-Resources 문을 어떻게 사용합니까?자동 리소스 관리에 Java의 Try-With-Resources 문을 어떻게 사용합니까?Mar 14, 2025 pm 04:59 PM

Java의 시도는 파일 스트림 또는 데이터베이스 연결과 같은 리소스를 자동으로 닫아 코드 가독성 및 유지 관리 가능성을 향상시켜 자원 관리를 단순화합니다.

Java의 열거를 사용하여 고정 된 값 세트를 나타내는 방법은 무엇입니까?Java의 열거를 사용하여 고정 된 값 세트를 나타내는 방법은 무엇입니까?Mar 14, 2025 pm 04:57 PM

Java 열거는 고정 된 값 세트를 나타냅니다. 고정 된 값 세트를 나타냅니다. 맞춤형 방법 및 생성자를 통해 유형 안전, 가독성 및 추가 기능을 제공합니다. 코드 조직을 향상시키고 효율적인 가치 처리를 위해 스위치 문에 사용할 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기