乱码问题

本文介绍了解决Excel文件名乱码的方法,通过将文件名从UTF-8编码转换为ISO8859-1编码来确保浏览器正确解析。此外,还探讨了如何解决Tomcat日志乱码的问题,以及request和response字符集设置的相关细节。
主要解决以下类别的乱码
1 用POI 下载excel 时,文件名乱码
2 tomcat 日志乱码
3 统一乱码过滤
4 

excel 文件名乱码

原理分析:我们知道 url 中的 中文是依靠 URI 编解码 实现的,中文会被浏览器编码成类似EB% 这种。

excel的文件名是 靠header传输的,所以 在传输的前后都应该用 默认的 ISO8859-1 进行 处理 。这不是 简单的 setCharacterEncoding 能解决的,因为header并不是content 的一部分

文件名在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被提交之前.

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值