我使用 java.util.prefs.Preferences 为我的应用程序创建引用但由于某种原因我似乎无法从xml文件加载首选项。我没有收到文件未找到的错误,所以它正在加载文件。它似乎没有解析文件。有人能让我知道我做错了吗?
澄清是的,正在加载文件。行'root.exportSubtree(System.out)'输出整个XML。然而,我从中获取的示例只有它显示根'user'的子根。这可能是我的问题的一个提示,但我仍然没有解决它。
我的偏好课程
package com.g4apps.secure.processserver;
import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.prefs.Preferences;
public class PSPrefs {
private String user;
private String url;
private String password;
private String database;
public PSPrefs(String file) {
InputStream is = null;
try {
is = new BufferedInputStream(new FileInputStream(file));
Preferences.importPreferences(is);
Preferences root = Preferences.userRoot();
root.exportSubtree(System.out);
this.user=root.get("user", "");
this.url=root.get("url", "");
this.password=root.get("password","");
this.database=root.get("database","");
}
catch (Exception e) {
e.printStackTrace();
}
}
public String getUser() {
return this.user;
}
public String getURL() {
return this.url;
}
public String getPassword() {
return this.password;
}
public String getDatabase() {
return this.database;
}
}
我的preferences.xml文件。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE preferences SYSTEM "http://java.sun.com/dtd/preferences.dtd">
<preferences EXTERNAL_XML_VERSION="1.0">
<root type="user">
<map/>
<node name="Server Settings">
<map>
<entry key="user" value="user"/>
<entry key="url" value="jdbc:mysql://mysqldb.com/"/>
<entry key="password" value="password"/>
<entry key="database" value="mydb"/>
</map>
</node>
</root>
</preferences>
感谢您的帮助。
答案 0 :(得分:0)
嗯,突然出现的事情是文件不在你认为的位置。尝试使用file.exists()
确保文件位于执行上下文中的正确位置
<强>更新强>
好的,对不起我的坏事:(
试试这个:
try {
is = new BufferedInputStream(new FileInputStream(file));
Preferences.importPreferences(is);
Preferences root = Preferences.userRoot();
Preferences node = Preferences.userRoot().node("Server Settings");
this.user = node.get("user", "");
this.url = node.get("url", "");
this.password = node.get("password", "");
this.database = node.get("database", "");
System.out.println(user);
System.out.println(url);
System.out.println(password);
System.out.println(database);
} catch (Exception e) {
e.printStackTrace();
}
这给了我
的输出user
jdbc:mysql://mysqldb.com/
password
mydb
哦,如果你使用的是roseindia的例子,它实际上会抛弃整个首选项树,它们只是“突出显示”那里的分支