在HttpServletResponse对象中有两个方法,分别为getOutputStream,getWriter.都是从ServletResponse中继承过来的.
getOutputStream返回的是ServletOutputStream(字节流)的流的子类,getWriter返回的是PrintWriter(字符流)的类.
对象response
PrintWriter out字符流对象本身有一个默认的编码方式,在Java中采用的就是Unicode编码.例如:
PrintWriter out=response.getWriter();
String data="中国";";//不是采用UTF-8或GB2312,采用的是字符串方式
out.print("is value="+data);
由于out对象是由response.getWriter()方法获取的,而response对象是外国人写的,默认的采用ISO 8859-1(根本就不支持中文)编码方式,所以会产生乱码......
浏览器采用默认的编码方式打开页面,如:UTF-8,所以同样也会产生乱码.....
总结
1.Servlet程序输出给浏览器的内容,不是任何一种正确的中文字符集编码ISO 8859-1
2.浏览器浏览网页文档时所采用的字符集编码与它接收到的中文字符本身的字符编码不一致.