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) メソッドは、次のように、指定されたデコード エンコーディングに従ってエンコーディングで特定の文字列のバイト配列表現を返します。
byte[] b_gbk = "中".getBytes("GBK"); byte[] b_utf8 = "中".getBytes("UTF-8"); byte[] b_iso88591 = "中".getBytes("ISO8859-1");
は、GBK、UTF-8、ISO8859-1 エンコーディングでそれぞれ漢字「中」のバイト配列表現を返します。このとき、
b_gbk の長さは 2、
b_utf8 の長さは 3、
#b_iso88591 の長さは 1 です。 getBytes と比較すると、new String(byte[], decode) を通じて「中」文字を復元できます。この new String(byte[], decode) は、実際には指定された文字列を使用します。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");
Java 基本チュートリアル 列.
以上がJavaからExcelにエクスポートした文字化けの原因と解決策の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。