18

java.util.Preferences APIを使用したいのですが、プログラムでWindowsレジストリの読み取りまたは書き込みを試みたくありません。どうすればいいですか?

4

2 に答える 2

17

Java を使用して Windows レジストリへの読み取り/書き込みを行ったことがあると思いますが、 java.util.PreferencesAPIを使用するときにレジストリ以外のバックエンドを使用したいと考えています。

この記事で説明されているように、BernhardCroftが行ったように、 PreferenceAPIを拡張できます。

Preferences APIはバックエンドに依存しないため、データがファイル、データベース テーブル、または Windows レジストリなどのプラットフォーム固有のストレージに格納されているかどうかを気にする必要はありません。

newPreferencesによる拡張の例は、ここで見ることができます

別の API を使用するよりも、IMO の方が優れています。


たとえば、次を拡張するクラスを検索しますjava.util.prefs.AbstractPreferences

  • XML ファイルに基づくプリファレンス ストアを使用できます。

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);
  }

  • または、これらの設定を LDAP に保存することもできます。

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;

  • または、単純なプロパティ ファイルを使用できます。

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 {
于 2008-10-16T12:11:56.257 に答える
4

java.util.prefs.AbstractPreferencesを拡張することは常に可能です。

別の方法として、Apache Commonsの構成パッケージを使用して、さまざまなソースとの間で構成データを読み書きできます。

于 2008-10-16T12:04:58.703 に答える