本文主要讲述response乱码原因及 response.setCharacterEncoding("UTF-8")不生效的原因及解决方法
一、response乱码
1、首先,response返回有两种,一种是字节流outputstream,一种是字符流printwrite。
申明:这里为了方便起见,所有输出都统一用UTF-8编码。
先说字节流,要输出“中国",给输出流的必须是转换为utf-8的“中国”,还要告诉浏览器,用utf8来解析数据
-
//这句话的意思,是让浏览器用utf8来解析返回的数据 -
response.setHeader("Content-type", "text/html;charset=UTF-8"); -
String data = "中国"; -
OutputStream ps = response.getOutputStream(); -
//这句话的意思,使得放入流的数据是utf8格式 -
ps.write(data.getBytes("UTF-8"));
2、 再说字符流,要输出中国,需要设置response.setCharacterEncoding("UTF-8");
-
//这句话的意思,是让浏览器用utf8来解析返回的数据 -
response.setHeader("Content-type", "text/html;charset=UTF-8"); -
//这句话的意思,是告诉servlet用UTF-8转码,而不是用默认的ISO8859 -
response.setCharacterEncoding("UTF-8"); -
String data = "中国"; -
PrintWriter pw = response.getWriter(); -
pw.write(data);
经验:1,如果中文返回出现??字符,这表明没有加response.setCharacterEncoding("UTF-8");这句话。
2,如果返回的中文是“烇湫”这种乱码,说明浏览器的解析问题,应该检查下是否忘加response.setHeader("Content-type", "text/html;charset=UTF-8");这句话。
二、 response.setCharacterEncoding("UTF-8")不生效的原因及解决方法
原因:
1. request.getRequestDispatcher方式跳转到SecondServlet后,FirstServlet与SecondServlet共有同一个response。
2. response.setCharacterEncoding(“UTF-8”)语句执行之前执行了response.getWriter()语句。
基于以上两点原因,即使SecondServlet中response.setCharacterEncoding(“UTF-8”)语句执行之前没有执行了response.getWriter()语句,但是FirstServlet中执行了response.getWriter()语句,同样会使response.setCharacterEncoding(“UTF-8”)不生效。
错误写法:
-
<code>PrintWriter out = response.getWriter(); -
response.setCharacterEncoding("UTF-8");</code>
正确写法:
-
<code>response.setCharacterEncoding("UTF-8"); -
PrintWriter out = response.getWriter();</code> -
转载https://blog.csdn.net/tlms_/article/details/78749980

本文详细解释了HTTP响应中出现中文乱码的原因,并提供了具体的解决方案。包括如何正确使用字符流和字节流输出中文字符,以及如何确保response的编码设置生效。

393

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



