您好,登錄后才能下訂單哦!
java下載文件時(shí)文件名出現(xiàn)亂碼的解決辦法:
String userAgent = request.getHeader("User-Agent"); String formFileName = file.getFileName(); // 針對(duì)IE或者以IE為內(nèi)核的瀏覽器: if (userAgent.contains("MSIE") || userAgent.contains("Trident")) { formFileName = java.net.URLEncoder.encode(formFileName, "UTF-8"); } else { // 非IE瀏覽器的處理: formFileName = new String(formFileName.getBytes("UTF-8"), "ISO-8859-1");
} response.setHeader("Content-disposition",String.format("attachment; filename=\"%s\"", formFileName)); response.setContentType("multipart/form-data"); response.setCharacterEncoding("UTF-8");
擴(kuò)展:
亂碼指的是程序顯示出來(lái)的字符文本無(wú)法用任何語(yǔ)言去解讀。一般情況下會(huì)包含大量的?。本質(zhì)上都是由于字符串原本的編碼格式與讀取時(shí)解析用的編碼格式不一致導(dǎo)致的。
中文變成看不懂的字符:如果一串中文字符變成了一串看不懂的字符如:"ì ? £ ?? ò ?2?? £ ?",這種情況通常是編碼字符集與解碼時(shí)所用的字符集不一致所造成的。比如使用GBK編碼,如果使用ISO-8859-1解碼的話結(jié)果就是這樣。
一個(gè)漢字變成了一個(gè)問(wèn)號(hào):如果編碼和解碼的字符集都是一致的,那么可以確定該字符編碼不支持中文,例如:ISO-8859-1
一個(gè)漢字變成了兩個(gè)問(wèn)號(hào):中文經(jīng)過(guò)多次編碼且其中有一次編碼或者解碼使用了不支持中文的字符集。
以上就是java中文件下載時(shí)文件名亂碼的解決方法的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注億速云其它相關(guān)文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。