我是一名充满激情的程序员,💻希望和大家一起学习进步!我热爱编程,对技术充满好奇心和求知欲!
🗣️无论你是新手还是老手,都能从我的博客中获得有价值的内容!
🚀让我们一起努力,成为更优秀的程序员吧!💪💻
当使用Java下载Excel文件时,有时会遇到文件名中文乱码的问题。在本篇博客中,我将向大家介绍如何解决这个问题。
首先,让我们了解一下为什么会出现文件名中文乱码的情况。这是由于文件名是以字节序列的形式存储的,而中文字符在不同的编码方式下可能会占用不同数量的字节。因此,在将中文字符作为文件名时,需要进行正确的编码转换。
为了解决文件名中文乱码的问题,我们可以使用Java提供的URLEncoder
类对文件名进行编码。以下是downLoadExcel代码:
public static void downLoadExcel(XSSFWorkbook wb, HttpServletResponse response, String fileName) { try { //设置下载的文件名 response.addHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(fileName, "utf-8") + ".xlsx"); response.setContentType("application/octet-stream;="); response.setCharacterEncoding("utf-8"); OutputStream outputStream = response.getOutputStream(); wb.write(outputStream); wb.close(); outputStream.close(); } catch (Exception e) { log.error("导出错误: ", e); }}
在上述代码中,我们使用URLEncoder.encode
方法将文件名进行编码,指定编码方式为"UTF-8"。然后,将编码后的文件名设置到Content-Disposition
响应头中,指定文件名为附件下载。
这样,当浏览器接收到响应时,就能正确解析并显示中文文件名了。
以上就是解决Java下载Excel文件名中文乱码问题的方法。通过正确的编码转换,我们可以确保文件名在下载时能够正确显示中文字符。希望本篇博客对你有所帮助!如有任何疑问,请随时留言。谢谢阅读!
来源地址:https://blog.csdn.net/weixin_45079659/article/details/131654709