HttpServletResponse OutputStream中文乱码解决方法

HttpServletResponse使用OutputStream输出中文的时候,如果编码不设置就会产生乱码,产生乱码的原因有以下几种:

1. Tomcat服务器默认的编码为ISO-8859-1,不支持中文,应当告诉浏览器和服务器,使用UTF-8编码。

2. 服务端,浏览器端2边的编码不一致,比如服务器用utf-8,浏览器用gb2312,也会产生乱码。

解决方法:

public void outputChineseByOutputStream(HttpServletResponse response) throws IOException{
	String data = "javaschool免费在线java教程";
	OutputStream outputStream = response.getOutputStream();//获取OutputStream输出流
	response.setHeader("content-type", "text/html;charset=UTF-8");//通过设置响应头控制浏览器以UTF-8的编码显示数据,如果不加这句话,那么浏览器显示的将是乱码
	//getBytes()方法如果不带参数,那么就会根据操作系统的语言环境来选择转换码表,如果是中文操作系统,那么就使用GB2312的码表
	byte[] dataByteArr = data.getBytes("UTF-8");//将字符转换成字节数组,指定以UTF-8编码进行转换
	outputStream.write(dataByteArr);//使用OutputStream流向客户端输出字节数组
}

response.setHeader("content-type", "text/html;charset=UTF-8") 通过设置响应头控制浏览器以UTF-8的编码显示数据

使用OutputStream流向客户端浏览器输出中文,以UTF-8的编码进行输出,此时就要控制客户端浏览器以UTF-8的编码打开,否则显示的时候就会出现中文乱码。

总结

1.如果中文返回出现??字符,这表明没有加HttpServletResponse.setCharacterEncoding("UTF-8");这句话。

2.如果返回的中文是“烇湫”这种乱码,说明浏览器的解析问题,应该检查下是否忘加response.setHeader("Content-type", "text/html;charset=UTF-8");这句话。

3.如果还是有乱码,就指定html文件里内容的编码方式<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

版权声明:本文为JAVASCHOOL原创文章,未经本站允许不得转载。