package response;
import java.io.IOException;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//在servlet中用outputStream输出数据的问题,以及输出中文的问题
public class ResponseDemo1 extends HttpServlet {
//在servlet中用outputStream输出中文的问题
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//test1(response);
//test2(response);
//test3(response);
//test4(response);
}
private void test1(HttpServletResponse response) throws IOException,
UnsupportedEncodingException {
response.setHeader("Content-type", "text/html;charset=UTF-8"); //指定浏览器以什么码表打开
//程序以什么码表输出了,程序就一定要控制浏览器以什么码表打开
String data = "中国";
OutputStream out = response.getOutputStream();
out.write(data.getBytes());//写给response//乱码
out.write(data.getBytes("UTF-8"));
}
//用html技术中的meta标签模拟了一个http响应头,来控制浏览器的行为
private void test2(HttpServletResponse response) throws IOException,
UnsupportedEncodingException {
//html: <meta>标签:这个标签可以模拟http响应头
//程序以什么码表输出了,程序就一定要控制浏览器以什么码表打开
String data = "中国";
OutputStream out = response.getOutputStream();
out.write("<meta http-equiv='content-type' content='text/html;charset=UTF-8'>".getBytes());
out.write(data.getBytes());//写给response再由response写到浏览器。
out.write(data.getBytes("UTF-8"));
}
private void test3(HttpServletResponse response) throws IOException,
UnsupportedEncodingException {
//注意,下面写错了,浏览器会提示下载
response.setHeader("content-type", "text/html,charset=UTF-8");
//程序以什么码表输出了,程序就一定要控制浏览器以什么码表打开
String data = "中国";
OutputStream out = response.getOutputStream();
out.write(data.getBytes());//写给response再由response写到浏览器。//乱码
out.write(data.getBytes("UTF-8"));
}
private void test4(HttpServletResponse response) throws IOException,
UnsupportedEncodingException {
response.setHeader("Content-type", "text/html;charset=UTF-8");
//程序以什么码表输出了,程序就一定要控制浏览器以什么码表打开
//String data = "中国";
OutputStream out = response.getOutputStream();
//out.write(1); //编码不一样,去找国标的1代表的字符
out.write((1+" ").getBytes());//正常
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
response.getOutputStream()这样获取一个OutputStream流的时候,我们在使用完之后,并不需要手动的去关闭,系统会自动关闭它,如果我们手动去关闭这个流的话,还会引发一些问题。
浏览器输入:http://localhost:8080/Servlet/servlet/ResponseDemo1
**
1. 测试test1,注释掉其余方法
**
可以看到浏览器的输出为:
out.write(data.getBytes());出现乱码
out.write(data.getBytes(“UTF-8”));没有出现乱码
原因很简单,如果浏览器使用的是gb2312码表打开的话,就是乱码,如果是使用utf-8码表打开的话,就是正常的数据。当然我们可以手动的去设置浏览器的打开码表,默认的是gb2312(系统默认码表),那么如果我们使用utf-8将数据写入到Response中,然后浏览器使用的是默认的码表去拿取数据进行显示,那肯定是乱码了,那么我们该怎么办呢?,让用户手动的去修改浏览器的打开码表,那貌似太恶心了,所以这里我们就要介绍一个响应头字段的作用了,Content-type:这个头就是告诉浏览器以什么方式打开数据,并且指定相应的码表,具体代码如下:
response.setHeader("Content-type", "text/html;charset=UTF-8"); //指定浏览器以什么码表打开
//程序以什么码表输出了,程序就一定要控制浏览器以什么码表打开
2. 测试test2,注释掉其他方法
可以看到浏览器的输出:
out.write(data.getBytes());写给response再由response写到浏览器。出现乱码
out.write(data.getBytes(“UTF-8”));
扩展一下就是还有一种方式控制浏览器的打开码表,那就是使用<meta>
标签来实现:
out.write("<meta http-equiv='content-type' content='text/html;charset=UTF-8'>".getBytes());
3. 测试test3,注释其他方法
浏览器可以看到:
<meta>
里面的内容写错了,浏览器会提示下载
4. 测试test4,注释其他方法
可以看到浏览器的输出:
【数字乱码】
out.write(1); 由于编码不一样,原数字按指定码表解析出其内容,会出现异常
out.write((1+” “).getBytes());显示正常
输出数字:要先把数字转为字符串再getBytes(),否则浏览器会将原数字按指定码表解析出其它内容,而不会输出原数字