JAVA中BufferedReader设置编码的必要性

实验环境 Myeclipse 

默认编码 UTF-8

先看两种读文件的方式:

方式一:

InputStreamReader fReader = new InputStreamReader(new FileInputStream(filePathString),"UTF-8");
BufferedReader reader = new BufferedReader(fReader);
String line;
while ((line = reader.readLine()) != null)
{
      //do something      
}
reader.close();

方式二:

BufferedReader reader = new BufferedReader(new FileReader(filePathString));
String line;
while ((line = reader.readLine()) != null)
{
      //do something
}
reader.close();

J2SE,两种方式均能正常读取文件。

以前我觉得代码能短就短,所以一直用方式二。因为windows下的Myeclipse设置成UTF-8了,linux直接就是UTF-8;

但是但是但是!

直到有一天,我写了一个web project。发现里面读的是按照GBK读的,导致都是乱码。

 

原因如下:

windows默认编码是 非UTF-8 ,而tomcat默认编码是继承系统的(server.xml里可以修改编码,但是不知道为什么在我这里不好使),而web与后台通信是经过tomcat的,所以web工程里默认编码是tomcat中的编码。

 

结论:

如果涉及到web工程的文件读写,记得要设定文件读写的编码格式。

posted @ 2014-07-12 11:07  油焖大黄瓜  阅读(13046)  评论(0编辑  收藏  举报