response乱码 response.setCharacterEncoding("UTF-8")不生效的原因及解决方法

本文主要讲述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>



  • 40
    点赞
  • 97
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值