主要解决以下类别的乱码
1 用POI 下载excel 时,文件名乱码
2 tomcat 日志乱码
3 统一乱码过滤
4
excel 文件名乱码
原理分析:我们知道 url 中的 中文是依靠 URI 编解码 实现的,中文会被浏览器编码成类似EB% 这种。
excel的文件名是 靠header传输的,所以 在传输的前后都应该用 默认的 ISO8859-1 进行 处理 。这不是 简单的 setCharacterEncoding 能解决的,因为header并不是content 的一部分
解决方案:必须将 文件名 先转码成 ISO8859-1,设置到 header属性里面,进行传输,这样浏览器就可以 用 ISO8859-1进行解码正确的 header 为 U8格式了
if (!filename.endsWith(".xls")) {
filename += ".xls";
}
// 防止文件名乱码 将U8格式转换为 ISO8859-1 传输给浏览器
filename = new String(filename.getBytes("UTF-8"), "iso-8859-1");
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding("UTF-8");
response.setHeader("content-disposition", "attachment;filename=" + filename);
//以下都是待整理内容,忽略即可
1、pageEncoding="UTF-8"的作用是设置JSP编译成Servlet时使用的编码。
2、contentType="text/html;charset=UTF-8"的作用是指定对服务器响应进行重新编码的编码。
3、request.setCharacterEncoding("UTF-8")的作用是设置对客户端请求进行重新编码的编码。
4、response.setCharacterEncoding("UTF-8")的作用是指定对服务器响应进行重新编码的编码。
response和request的setCharacterEncoding
一、request.setCharacterEncoding():是设置从request中取得的值或从数据库中取出的值。
指定后可以通过getParameter()则直接获得正确的字符串,如果不指定,则默认使用iso8859-1编码。值得注意的是在执行setCharacterEncoding()之前,不能执行任何getParameter()。而且,该指定只对POST方法有效,对GET方法无效。分析原因,应该是在执行第一个getParameter()的时候,Java将会按照编码分析所有的提交内容,而后续的getParameter()不再进行分析,所以setCharacterEncoding()无效。而对于GET方法提交表单是,提交的内容在URL中,一开始就已经按照编码分析提交内容,setCharacterEncoding()自然就无效。
get需在Tomcat的server.xml中的:
<connector port="8080" protocol="HTTP/1.1" connectiontimeout="20000" redirectport="8443" <="" p="">
URIEncoding="GBK" />
)加入URIEncoding="GBK",解决get请求乱码问题
二、response.setContentType("text/html;charset=gb2312")是设置页面中为中文编码。
前者是设置动态文字(参数,数据库),后者设置页面静态文字
response.setContentType指定 HTTP 响应的编码,同时指定了浏览器显示的编码.
response.setCharacterEncoding设置HTTP 响应的编码,如果之前使用response.setContentType设置了编码格式,则使用response.setCharacterEncoding指定的编码格式覆盖之前的设置.与response.setContentType相同的是,调用此方法,必须在getWriter执行之前或者response被提交之前.

本文介绍了解决Excel文件名乱码的方法,通过将文件名从UTF-8编码转换为ISO8859-1编码来确保浏览器正确解析。此外,还探讨了如何解决Tomcat日志乱码的问题,以及request和response字符集设置的相关细节。

被折叠的 条评论
为什么被折叠?



