java 读取文件的乱码问题

在java读取文件的时候有时候就是免不了一系列的乱码问题,比如下面的这个程序如果读取编码为gb2312的网页文件时候,就会正常的显示,不会出现乱码。

如果将private static String EnCoding = "gb2312";
改为private static String EnCoding = "utf-8";读取编码为gb2312的网页的时候又会出现乱码!

    private static String EnCoding = "gb2312";
    private static Connection connection = DB.getConn();
    private static String[] columnText; 
    
    
	public void readFile(String filePath) {
		try {
			//读取文件时指定字符编码(new FileInputStream( new File(szFileName)), EnCoding) 解决乱码的更本之道 
			File file = new File(filePath);
			FileInputStream fileInputStream = new FileInputStream(file);
			InputStreamReader inputStreamReader = new InputStreamReader(fileInputStream, EnCoding);
			BufferedReader br = new BufferedReader(inputStreamReader);
	        StringBuffer stringBuffer = new StringBuffer();
	        String s = "";
	        while ((s = br.readLine()) != null) {
	            stringBuffer.append(s);
	            stringBuffer.append("\n");
	        }
	        s = stringBuffer.toString();
}

 以上程序能够正确的读取网页的编码为gb2312的文件,在读取文件的时候将java中InputStreamReader的编码和被读取文件的编码设置为同样的编码,这样就不会出现乱码问题了

 

rThinker 公司调研

你可能感兴趣的:(java)