首页 > 其他 > 详细

黑马day03 字节输出流的乱码原理分析

时间:2015-06-17 13:31:26      阅读:244      评论:0      收藏:0      [点我收藏+]

//编码和解码一致就不会造成乱码,浏览器默认的是当前系统的默认字符编码,因此解码的时候会查gbk

一.字节输出流乱码解决

1.字节输出流getOutputStream().write();

package com.itheima;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//编码和解码一致就不会造成乱码,浏览器默认的是当前系统的默认字符编码,因此解码的时候会查gbk
public class Demo6Servlet extends HttpServlet {
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.getOutputStream().write("中国".getBytes());//查看String类的getBytes方法可以看到使用的是当前系统默认的编码进行解码即当前是gbk
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

	
}
会乱码么?答案:

不会乱码,因为getBytes编码的时候会查gbk,浏览器解码的时候会使用gbk.因此不会乱码!
技术分享

2.如果指定编码

response.getOutputStream().write("中国".getBytes("utf-8"))

必定会乱码,因为编码使用的是utf-8,浏览器解码的时候使用默认的gbk因此会乱码

技术分享

解决方式:

告知浏览器使用utf-8编码进行解码:

使用//通知浏览器使用utf-8解码

response.setHeader("Content-Type", "text/html;charset=utf-8");

技术分享



黑马day03 字节输出流的乱码原理分析

原文:http://blog.csdn.net/u014010769/article/details/46531907

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!