一般,我们写一个简单的servlet的时候都会实现它的doget()或者dopost()方法,此时我们在拿到response对象的时候,利用response对象实现一个输出流,即如下代码时:
PrintWriter writer = response.getWriter();
writer.write("HelloWorld");
我们发现我们启动Tomcat进行访问的时候,我们能够成功访问到我们吸入到response缓冲区中的信息,即如下图所示:
但是,如果此时我输入了一句中文的提示,那么在浏览器中的输出就会存在问题 ;如下图:
浏览器的输出结果:
产生这一结果的原因是因为我们在进行数据的写入和输出的时候,都存在一种默认的编码格式,当我们通过输出流来对response缓冲区进行数据的书写时,我们的默认编码格式一般是IOS-8859,而我们浏览器的编码格式一般会使用utf-8,所以就会形成上面的结果,这时候我们需要完成数据输出流之前,来对数据编码格式进行设置,实现如下:
而此时的结果却不是我们想要的结果
这是因为在浏览器解析的时候,运用的编码格式依然不和我们想response缓冲区书写数据时的格式进行相互匹配,所以产生了这种结果,需要进行以下更改:
第三步的更改可以实现我们想要的结果:
另外,第三步的实现是包括第二步的,如果我们想要通过跳过第二步来直接利用第三步来实现编码格式的统一,也是可以的;