一般使用到properties配置文件,一般都是在spring项目里面,直接由框架帮你读,当然,你也得考虑到编码的问题。
但是现在要是要求使用java直接读写properties文件,就发现很多的问题,比如,我的properties文件的编码竟然不是utf-8的。或者说我压根就没考虑到这个问题。
再比如,当properties文件里面有汉子的时候,发现读写的汉字乱码了,在我这是因为我的电脑默认编码是gbk,但是读的时候,又没有设置编码,搞出的问题。
下面直接上代码,看问题。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
package com.lxk.propertyfiletest; import java.io.*; import java.util.properties; /** * 读写properties文件测试 * <p> * created by lxk on 2017/4/25 */ public class main { public static void main(string[] args) { properties prop = new properties(); inputstream in = null ; fileoutputstream ofile = null ; try { in = new bufferedinputstream( new fileinputstream( "d:config.properties" )); //prop.load(in);//直接这么写,如果properties文件中有汉子,则汉字会乱码。因为未设置编码格式。 prop.load( new inputstreamreader(in, "utf-8" )); for (string key : prop.stringpropertynames()) { system.out.println(key + ":" + prop.getproperty(key)); } //保存属性到b.properties文件 ofile = new fileoutputstream( "b.properties" , false ); //true表示追加打开,false每次都是清空再重写 prop.setproperty( "phone" , "10086" ); //prop.store(ofile, "此参数是保存生成properties文件中第一行的注释说明文字");//这个会两个地方乱码 //prop.store(new outputstreamwriter(ofile, "utf-8"), "汉字乱码");//这个就是生成的properties文件中第一行的注释文字乱码 prop.store( new outputstreamwriter(ofile, "utf-8" ), "lll" ); } catch (exception e) { system.out.println(e.getmessage()); } finally { if (in != null ) { try { in.close(); } catch (ioexception e) { system.out.println(e.getmessage()); } } if (ofile != null ) { try { ofile.close(); } catch (ioexception e) { system.out.println(e.getmessage()); } } } } } |
运行结果:这个只是读出来的内容的结果。
下面是写出来的文件内容。
额,这个图,有点乱。但是,却把三种运行情况,全部给展示出来了。很清晰。
最后,代码里面也看到了怎么把字节流变成带编码格式的字符流,这个可以注意下,我也留个笔记。
对上面的代码的更新,算是结构调整,功能分开。瞬间代码看着就清晰明了啦。
所以,一般上面的代码是不推荐实用的。个中妙用,自行体会吧。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
package com.lxk.propertyfiletest; import java.io.*; import java.util.properties; /** * 读写properties文件测试 * <p> * created by lxk on 2017/4/25 */ public class main { public static void main(string[] args) { properties prop = readpropertiesfile(); writepropertiesfile(prop); } /** * 读properties文件 */ private static properties readpropertiesfile() { properties prop = new properties(); inputstream in = null ; try { in = new bufferedinputstream( new fileinputstream( "d:config.properties" )); //prop.load(in);//直接这么写,如果properties文件中有汉子,则汉字会乱码。因为未设置编码格式。 prop.load( new inputstreamreader(in, "utf-8" )); for (string key : prop.stringpropertynames()) { system.out.println(key + ":" + prop.getproperty(key)); } } catch (exception e) { system.out.println(e.getmessage()); } finally { if (in != null ) { try { in.close(); } catch (ioexception e) { system.out.println(e.getmessage()); } } } return prop; } /** * 写properties文件 */ private static void writepropertiesfile(properties prop) { prop.setproperty( "phone" , "10086" ); fileoutputstream ofile = null ; try { //保存属性到b.properties文件 ofile = new fileoutputstream( "b.properties" , false ); //true表示追加打开,false每次都是清空再重写 //prop.store(ofile, "此参数是保存生成properties文件中第一行的注释说明文字");//这个会两个地方乱码 //prop.store(new outputstreamwriter(ofile, "utf-8"), "汉字乱码");//这个就是生成的properties文件中第一行的注释文字乱码 prop.store( new outputstreamwriter(ofile, "utf-8" ), "lll" ); } catch (exception e) { system.out.println(e.getmessage()); } finally { if (ofile != null ) { try { ofile.close(); } catch (ioexception e) { system.out.println(e.getmessage()); } } } } } |
注意:这个是我后来发现的,不知道在看的各位有没有这个问题。
我发现写出来的properties文件的编码格式并不是简单的utf-8,而是utf-8无bom格式。证据可参见下图:
这个打开工具叫 notepad++ 估计在看的各位的电脑上都有这个吧。
但是你要是把这个文件的编码格式给修改成utf-8编码之后,运行的结果,就有一丢丢不一样。
继续参见下图:
看到多了一个小杠“”-“”,具体怎么解释,我暂时还不清楚。
这个时候,写出来的文件的,也同样出现了这个问题,具体还是继续参见下图:
所以,这个我暂时解释不了。
惭愧。。。。
还有个问题就是:读出来的属性,是不按原来文件中的顺序展示的,当然写的时候,也是乱序的。
这还是个问题,还有待解决。什么时候解决了,再在此处留个链接。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/qq_27093465/article/details/70765870