码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2015-06-17 13:32:03      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:servlet 乱码

//编码和解码一致就不会造成乱码,浏览器默认的是当前系统的默认字符编码,因此解码的时候会查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 字节输出流的乱码原理分析

标签:servlet 乱码

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!