String fileName = URLEncoder.encode("白名单正确数据导出.xlsx", "UTF-8");乱码%E7%99%BD%E5%90%8D%E5%8D%95%E6%AD%A3%E7%A1%AE%E6%95%B0%E6%8D%AE%E5%AF%BC%E5%87%BA.xlsx
时间: 2024-04-26 15:23:46 浏览: 147
您的问题是关于字符串编码的吗?这段代码使用了UTF-8编码对文件名进行了URL编码,导致输出的字符是以%XX的形式表示的编码字符。在浏览器中打开时,浏览器会将编码字符转换回原始字符,因此您看到的是中文文件名。如果您想在Java中解码该文件名,可以使用URLDecoder类的decode方法进行解码。例如,可以使用以下代码来解码文件名:
String decodedFileName = URLDecoder.decode("%E7%99%BD%E5%90%8D%E5%8D%95%E6%AD%A3%E7%A1%AE%E6%95%B0%E6%8D%AE%E5%AF%BC%E5%87%BA.xlsx", "UTF-8");
此时,decodedFileName 将会是 "白名单正确数据导出.xlsx"。
相关问题
String filename = URLEncoder.encode("测试" + ".xlsx", "UTF-8");
在Java中,URLEncoder类是一个用于处理URL编码的实用工具类。在这个例子中,我们将字符串"测试"编码成URL编码格式,即%符号后面跟着十六进制的数字,例如"%E6%8E%A5%E5%8F%A3%E6%B5%8B%E8%AF%95"。这里的UTF-8是指使用UTF-8编码格式,可以将字符串中的中文等非ASCII字符转换成相应的编码格式,以便于在URL传输中不会出现乱码或者被服务器拒绝访问等情况。
所以,String filename = URLEncoder.encode("测试" + ".xlsx", "UTF-8"); 的作用就是将文件名"测试.xlsx"进行URL编码,以便于在网络传输中不会出现问题。
OutputStream outputStream = response.getOutputStream(); response.reset(); String fileName = URLEncoder.encode("白名单正确数据导出.xlsx", "UTF-8"); response.setHeader("Content-disposition", "attachment; filename=" + fileName); response.setContentType("application/x-msdownload;charset=utf-8"); workbook.write(outputStream); workbook.close(); outputStream.close();wps能打开ofiice打不开
这段代码是一个将 Excel 文件导出并下载的示例。其中,`workbook` 是一个已经创建好的 Excel 工作簿对象,`response` 是一个 HTTP 响应对象。这段代码会将 Excel 文件的数据写入到 `response` 对象的输出流中,以便用户可以下载该文件。
关于您提到的 WPS 能打开 Office 打不开的问题,可能是因为 WPS 对 Office 文件的兼容性不够好导致的。建议您尝试将文件保存为 Office 格式(如 .xlsx)后再进行打开。另外,您也可以尝试升级 WPS 到最新版本,以获得更好的兼容性支持。
阅读全文