解决Servlet中直接使用response.getWriter().write() 输出乱码

基础环境

项目编码:utf-8
页面编码:utf-8
请求类型:Post

Demo1:

Servlet核心代码

request.setCharacterEncoding("UTF-8");
response.setCharacterEncoding("UTF-8");
String username = request.getParameter("username");
System.out.println(username);//控制台正确输出中文
response.getWriter().write(username);//页面中文乱码
   
   

    运行结果

    这里写图片描述

    Demo2:

    Servlet核心代码

    request.setCharacterEncoding("UTF-8");
    String username = request.getParameter("username");
    System.out.println(username);
    request.setAttribute("username", username);
    request.getRequestDispatcher("result.jsp").forward(request, response);
    
       
       

      运行结果

      这里写图片描述

      Demo3:

      Servlet核心代码

      request.setCharacterEncoding("UTF-8");
      response.setContentType("text/html;charset=utf-8");
      String username = request.getParameter("username");
      System.out.println(username);
      response.getWriter().write(username);
         
         

        运行结果

        这里写图片描述

        思考?

        为什么Demo1会出现乱码?而Demo2没有出现乱码?
        明明Demo1的response也设置了utf-8编码。

        Demo1乱码的原因

        从控制台输出可以看出,控制台并没有乱码,只是response在输出中文的
        时候出现了乱码,因此,这行代码:response.setCharacterEncoding(“UTF-8”);
        可能并没有起到想要的效果。

        反观Demo2,并没有response.setCharacterEncoding(“UTF-8”); 这句话,但是输出的
        页面是通过request的转发到JSP页面实现的。其实JSP页面最后也要转换为Servlet
        页面中的元素也是response.getWriter().write(“”);出来的。既然有response,那么
        这个response的编码是如何确定的呢?我们看一看JSP与对应的Servlet就可以明白了:

        这里写图片描述

        也就是说Demo2中的response.setCharacterEncoding隐藏在JSP页面中了。
        然后根据转换后的Servlet可以看出response.setContentType(“text/html;charset=utf-8”);
        才能达到应有的效果,在使用http协议的情况中,该方法设置 Content-type实体报头
        response.setContentType()的作用是使客户端浏览器,区分不同种类的数据,并根据不
        同的MIME调用浏览器内不同的程序嵌入模块来处理相应的数据。
        例如:web浏览器就是通过MIME类型来判断文件是GIF图片,通过MIME类型来处理json字符串。
        Tomcat的安装目录\conf\web.xml 中就定义了大量MIME类型 ,可以参考。
        response.setContentType(“text/html; charset=utf-8”); html
        response.setContentType(“text/plain; charset=utf-8”); 文本
        response.setContentType(“text/javascript; charset=utf-8”); json数据
        response.setContentType(“application/xml; charset=utf-8”); xml数据

        因此Demo3正是解决Demo1乱码的方法!

        • 2
          点赞
        • 8
          收藏
          觉得还不错? 一键收藏
        • 1
          评论

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

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

        请填写红包祝福语或标题

        红包个数最小为10个

        红包金额最低5元

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

        抵扣说明:

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

        余额充值