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) メソッドは、次のように、指定されたデコード エンコーディングに従ってエンコーディングで特定の文字列のバイト配列表現を返します。
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 基本チュートリアル 列に注目してください。
注: 中国語の文字を特定の特殊な要件 (コンテンツが ISO8859-1 でエンコードされている必要がある http ヘッダーなど) に適合させるために、中国語の文字がバイト単位でエンコードされる場合があります。形式: 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 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック

Java の乱数ジェネレーターのガイド。ここでは、Java の関数について例を挙げて説明し、2 つの異なるジェネレーターについて例を挙げて説明します。

Java のアームストロング番号に関するガイド。ここでは、Java でのアームストロング数の概要とコードの一部について説明します。

Java の Weka へのガイド。ここでは、weka java の概要、使い方、プラットフォームの種類、利点について例を交えて説明します。

この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです
