首頁 > Java > Java基礎 > 主體

java怎麼解決導出csv檔亂碼

發布: 2019-12-28 16:29:51
原創
2510 人瀏覽過

java怎麼解決導出csv檔亂碼

將查詢的資料以xls檔案匯出時(UTF-8編碼),資料正常;但以CSV檔案匯出時,檔案中的中文亂碼,同樣是UTF-8編碼,改成GBK編碼導出時,中文顯示正常。 (建議:java影片教學

解決方法:

#以CSV方式匯出的檔案中預設不含BOM訊息,透過給予將要輸出的內容設定BOM標識(以EF BB BF 開頭的位元組流)即可解決此問題。 具體方法如下:

...
OutputStreamWriter outputStreamWriter = new OutputStreamWriter(response.getOutputStream(), "UTF-8");  
// 要输出的内容  
result = (String)contentMap.get(RESPONSE_RESULT);  
response.setHeader("Content-Disposition", "attachment;filename=test.csv");  
outputStreamWriter.write(new String(new byte[]{(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}));  
outputStreamWriter.write(result);  
outputStreamWriter.flush();
登入後複製

如果是以OutputStream流實現的,參數可以如下修改:

out = response.getOutputStream();     
//加上UTF-8文件的标识字符      
out.write(new byte []{(byte) 0xEF, (byte) 0xBB, (byte) 0xBF});
登入後複製

更多java知識請關注java基礎教程欄目。

以上是java怎麼解決導出csv檔亂碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板