这里有一个前提,关于编译器设置和properties编码格式都已经设置了utf-8了。
对于编译器如何设置全局utf-8编码的本文不涉及。。
在我们JavaWeb工程中,有时候我们不借助Spring,而是自己用代码去读取properties文件时,一般的代码会这么写:
private static synchronized Map loadFile(String fileName){
Properties properties = new Properties();
HashMap<String, String> ppt = new HashMap<>();
try {
properties.load(PropertiesUtil.class.getClassLoader().getResourceAsStream(fileName));
Enumeration<?> enumeration = properties.propertyNames();
while(enumeration.hasMoreElements()){
String key = (String) enumeration.nextElement();
String value = properties.getProperty(key);
ppt.put(key,value);
}
return ppt;
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
但是当你的properties文件中有value是中文的时候,按以上那样写法,有时候(我也不知道为什么)会出现中文乱码的情况。。。
这时,你可以将
properties.load(PropertiesUtil.class.getClassLoader().getResourceAsStream(fileName));
写成
properties.load(new InputStreamReader(PropertiesUtil.class.getClassLoader().getResourceAsStream(fileName),"UTF-8"))
即可!