用java搭建下载文件资源的网页时,如果文件名是中文的,下载时会出现乱码。这是由每个浏览器解析的不同编码方法造成的。以下工具类可以解决这个问题:
package utils;import java.io.UnsupportedEncodingException;import java.net.URLEncoder;import java.util.Base***;public class DownLoadUtils { public static String getFileName(String agent, String filename) throws UnsupportedEncodingException { if (agent.contains("MSIE")) { // IE浏览器 filename = URLEncoder.encode(filename, "utf-8"); filename = filename.replace("+", " "); } else if (agent.contains("Firefox")) { // 火狐浏览器 final Base***.Decoder decoder = Base***.getDecoder(); final Base***.Encoder encoder = Base***.getEncoder(); filename = "=?utf-8?B?" + encoder.encodeToString(filename.getBytes("utf-8")) + "?="; } else { // 其它浏览器 filename = URLEncoder.encode(filename, "utf-8"); } return filename; }}
本文来自幻墨如烟投稿,不代表舒华文档立场,如若转载,请注明出处:https://www.chinashuhua.cn/24/613658.html