Gibt es eine Möglichkeit java.util.Preferences unter Windows, ohne es zu verwenden, um die Registry als Backend verwenden?
-
03-07-2019 - |
Frage
Ich mag die java.util.Preferences API verwenden, aber ich will nicht mein Programm zu versuchen, den Windows-Registry zu lesen oder zu schreiben. Wie würde ich über diese gehen?
Lösung
Ich vertraue dir die lesen / schreiben mit Hilfe von Java und Sie dann ein anderes back-End als die Registrierung haben, wenn die java.util.Preferences
API
Sie können erweitern die Preference
API , wie Bernhard oder Croft hat, wie in der dieser Artikel :
Da die Preferences API ist Backend-neutral, Sie müssen es egal, ob die Daten in Dateien, Datenbank-Tabellen gespeichert sind, oder ein plattformspezifische Speicher wie der Windows-Registry.
Beispiele für Erweiterungen durch new Preferences
hier gesehen werden kann.
Das ist besser, IMO, als eine andere API zu verwenden.
Zum Beispiel für die Klassen der Suche erstreckt java.util.prefs.AbstractPreferences
:
- Sie können einen Einstellungsspeicher verwenden, indem Sie eine XML-Datei gesichert:
de.unika.ipd.grgen.util.MyPreferences
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.prefs.AbstractPreferences;
import java.util.prefs.BackingStoreException;
/**
* Own implementation of the Java preferences API, that does not use
* a "OS backing store" but relies on importing and exporting the
* preferences via xml files.
* Also, If a preference is got, but was not in the tree, it is entered.
*/
public class MyPreferences extends AbstractPreferences {
private Map<String, String> prefs = new HashMap<String, String>();
private Map<String, AbstractPreferences> children = new HashMap<String, AbstractPreferences>();
public MyPreferences(MyPreferences parent, String name) {
super(parent, name);
}
/**
* @see java.util.prefs.AbstractPreferences#putSpi(java.lang.String, java.lang.String)
*/
protected void putSpi(String key, String value) {
prefs.put(key, value);
}
- Oder Sie könnten diese Einstellungen in einem LDAP-Speicher:
de.tarent.ldap.prefs.LDAPSystemPreferences
import java.util.prefs.AbstractPreferences;
import java.util.prefs.BackingStoreException;
import javax.naming.NamingException;
import javax.naming.directory.Attributes;
import de.tarent.ldap.LDAPException;
import de.tarent.ldap.LDAPManager;
/**
* @author kirchner
*
* Preferences im LDAP
*/
public class LDAPSystemPreferences extends AbstractPreferences {
LDAPManager ldm = null;
Properties properties = new Properties();
//Map für key/value der Preferences
Map cache = new HashMap();
//Map für timestamp der Preferences
Map timestamp = new HashMap();
private Boolean deleted = Boolean.FALSE;
- Sie können auch eine einfache Eigenschaft Datei:
com.adito.boot.PropertyPreferences
:
import java.util.prefs.AbstractPreferences;
import java.util.prefs.BackingStoreException;
import java.util.prefs.Preferences;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* A simple implementation for the preferences API. That stores preferences
* in propery files. We do not have to worry about sharing the preferencese
* with other JVM instance so there is no need for any kind of synchronising
* or locking.
*/
public class PropertyPreferences extends AbstractPreferences {
Andere Tipps
Es ist immer möglich java.util.prefs.AbstractPreferences zu verlängern.
Eine Alternative könnte die Konfigurationspaket von Apache Commons benutzen Sie und lesen können schreiben Konfigurationsdaten von / zu verschiedenen Quellen.