`
envoydada
  • 浏览: 65387 次
社区版块
存档分类
最新评论

JAVA访问注册表

阅读更多

JAVA访问注册表

--------------------------------------------------------------------------------
  (转载: fengmin  2005-12-13 10:06:00 )

JDK1.4下实现访问WIN32注册表 
(通过  JSR  10)为  Java  1.4  增加的  java.util.prefs  包,通过提供对特定于实现的注册表(例如,Windows  平台上的  Windows  注册表)的访问能力,使您能够操作用户首选项数据和配置数据。 
您是不是曾经需要保存程序的配置数据但却不知应将数据存储在哪里?  虽然您可以使用属性文件或资源束获取这些信息,但  Java  平台从未指定过用于存储这些文件的标准位置。JSR  10  出现后一切都变了,它为  Java  1.4  API  提供增加的  java.util.prefs  包。存储机制是特定于实现的细节,但程序员不必知道,也不必操心。对于  Windows  平台,它的位置是在“Windows  注册表”。  您虽然不能够对注册表自由控制,但您的确可以通过一个公共根节点访问所有的应用程序。 
 
开始 
命名很恰当的  Preferences  类提供操作首选项的基本框架。这个类提供了一系列静态和抽象方法来操作两套首选项(其中一套是用户首选项,另一套是系统首选项)中的其中一套。  使用静态方法,您会得到一个特定于平台的实现,就象  WindowsPreferences  类;  然后您可以使用由这个特定于平台的实现实现的抽象方法来做这项工作。 
 
用包将程序的首选项分组是个好习惯,可以避免与其它应用程序的命名冲突。  当您查找  Preferences  对象时,只需传递包的名称。在使用非静态方法时,  您可以传递对自身的引用(this),程序将为您确定查找的是哪个包,如清单  1  所示。 
 
清单  1.  从非静态方法获取  Preferences  对象   

Preferences  userPrefs  =  Preferences.userNodeForPackage(this);  
Preferences  sysPrefs  
=  Preferences.systemNodeForPackage(this);  

但是,如果您使用的是静态方法,您就必须得到根节点并自己提供包,如清单  2  所示。 
 
清单  2.  从静态方法获取  Preferences  对象   

Preferences  userPrefs  =  Preferences.userRoot().node("/net/zukowski/ibm");  
Preferences  sysPrefs  
=  Preferences.systemRoot().node("/net/zukowski/ibm");  

有了进行操作的节点后,您就可以轻松地设置、获取、除去和转储设置选项。只要把  Preferences  对象当作一个大的键  —  值散列表(这个表把树形结构中的键组织起来)。可它不是“集合框架”(  Collections  Framework)的部件,(关于“集合框架”的更多信息,请参阅参考资料)。 
 
写数据 
我们将从讨论如何存储首选项开始。Preferences  类提供一系列  put()  方法,如下所示,用于存储值。除支持基本的字符串之外,您还可以存储布尔值、双精度数、浮点数、整型数、长整型数和字节数组(考虑序列化)。助手方法采用适当的数据类型并执行必要的转换以便将数据存储为字符串。  

put(String  key,  String  value)    
putBoolean(String  key,  
boolean  value)    
putByteArray(String  key,  
byte  value[])    
putDouble(String  key,  
double  value)    
putFloat(String  key,  
float  value)    
putInt(String  key,  
int  value)    
putLong(String  key,  
long  value)  

所有的  put()  方法都返回一个  void。如果存储机制不可用,将抛出一个BackingStoreException。 
 
注意:一个特定首选项的键长度被限制为  Preferences.MAX_KEY_LENGTH(80)个字符,而它的值被限制为  Preferences.MAX_VALUE_LENGTH(8192)个字符。 
 
读数据 
可通过下面所示的一系列  get()  方法获取特定的首选项。与写数据相似,每种受支持的数据类型,都有自己的与众不同的方法。但与获取数据时不同的是,在备用存储不可用,或有些东西尚未保存时您必须提供缺省值。这要求您确保自己的程序至少要有合理的缺省设置选项。  

get(String  key,  String  default)    
getBoolean(String  key,  
boolean  default)    
getByteArray(String  key,  
byte  default[])    
getDouble(String  key,  
double  default)    
getFloat(String  key,  
float  default)    
getInt(String  key,  
int  default)    
getLong(String  key,  
long  default)  

如果您对首选项名称不确定,您可以用  keys()  方法查找一列与节点相关联的键。这个方法返回节点的  String[]。  除获取和存储个别首选项以及获取一列关键字之外,您还可以用  clear()、remove()  和  removeNode()  除去节点和值。 
 
转储数据 
如果您想在系统提供的备用存储器之外保存和恢复首选项,您可以在  XML  格式的文档中执行这些操作。您可以用  exportNode()  导出一个节点或用  exportSubtree()  导出整个子树。信息以  UTF-8  格式存储。然后,当您想恢复信息时,可使用  importPreferences()  方法。 
 
侦听 
“好奇心会害死一只猫”,但如果您对弄清除首选项何时改变很感兴趣,您可以注册一个  NodeChangeListener  或  PreferenceChangeListener,而不考虑随之而来的后果。NodeChangeListener  负责通知您节点被添加和除去的时间,  而  PreferenceChangeListener  告诉您值的变化。这些都紧跟着基本  JavaBeans  组件事件用  add/removeNodeChangeListener(NodeChangeListener)  和  add/removePreferenceChangeListener()  方法处理结构之后发生。基本上,您先实现侦听器,然后注册侦听器,这样您会发现将来的变化。 
 
完整的示例 
真的就这些。清单  3  为您提供了一个完整的示例来试验新功能(也可从参考资料下载)。程序运行后会自己清除,所以如果您想在注册表中找到值,请注释掉程序尾部的清除代码。 
 
清单  3.  完整的示例   

 1 package  net.zukowski.ibm;  
 2  
 3 import  java.io.*;  
 4 import  java.util.prefs.*;  
 5  
 6 public  class  Prefs  {  
 7    public  static  void  main(String  args[])  {  
 8        String  denominations[]  =    
 9            {"One",  "Two",  "Five",  "Ten",  "Twenty"};  
10        String  pictures[]  =    
11            {"Washington",  "Jefferson",  "Lincoln",  "Hamilton",  "Jackson"};  
12  
13        NodeChangeListener  nodeChangeListener  =    
14            new  NodeChangeListener()  {  
15                public  void  childAdded(NodeChangeEvent  event)  {  
16                    Preferences  parent  =  event.getParent();  
17                    Preferences  child    =  event.getChild();  
18                    System.out.println(parent.name()  +  "  has  a  new  child  "  +  
19                        child.name());  
20                }  
21                public  void  childRemoved(NodeChangeEvent  event)  {  
22                    Preferences  parent  =  event.getParent();  
23                    Preferences  child    =  event.getChild();  
24                    System.out.println(parent.name()  +  "  lost  a  child  "  +  
25                        child.name());  
26                }  
27            };  
28  
29        PreferenceChangeListener  preferenceChangeListener  =    
30            new  PreferenceChangeListener()  {  
31                public  void  preferenceChange(PreferenceChangeEvent  event)  {  
32                    String  key  =  event.getKey();  
33                    String  value  =  event.getNewValue();  
34                    Preferences  node  =  event.getNode();  
35                    System.out.println(node.name()  +  "  now  has  a  value  of  "  +    
36                        value  +  "  for  "  +  key);  
37                }  
38            };  
39  
40        //  Look  up  user  root  
41        Preferences  prefs  =    
42            Preferences.userRoot().node("/net/zukowski/ibm");  
43  
44        //  Add  listeners  
45        prefs.addNodeChangeListener(nodeChangeListener);  
46        prefs.addPreferenceChangeListener(preferenceChangeListener);  
47  
48        //  Save  a  bunch  of  key-value  pairs  
49        for  (int  i=0,  n=denominations.length;  i  <  n;  i++)  {  
50            prefs.put(denominations[i],  pictures[i]);  
51        }  
52  
53        //  Display  all  the  entries  
54        try  {  
55            String  keys[]  =  prefs.keys();  
56            for  (int  i=0,  n=keys.length;  i  <  n;  i++)  {  
57                System.out.println(keys[i]  +  ":  "  +  prefs.get(keys[i],  "Unknown"));  
58            }  
59        }  catch  (BackingStoreException  e)  {  
60            System.err.println("Unable  to  read  backing  store:  "  +  e);  
61        }  
62  
63        //  Create  child  
64        Preferences  child  =  Preferences.userRoot().node("/net/zukowski/ibm/foo");  
65  
66        //  Save  to  XML  file  
67        try  {  
68            FileOutputStream  fos  =  new  FileOutputStream("prefs.out");  
69            prefs.exportNode(fos);  
70        }  catch  (Exception  e)  {  
71            System.err.println("Unable  to  export  nodes:  "  +  e);  
72        }  
73  
74        //  Clean  up  
75        try  {  
76            prefs.removeNode();  
77        }  catch  (BackingStoreException  e)  {  
78            System.err.println("Unable  to  access  backing  store:  "  +  e);  
79        }  
80  
81    }  
82 
83 
分享到:
评论

相关推荐

    Java 访问注册表所需要用到的架包regist.jar

    Java 访问注册表所需要用到的架包regist.jar

    JAVA访问WINDOWS注册表

    需要注意的是,访问注册表需要相应的权限,因此在实际应用中需要确保程序有足够的权限运行。 另外,提供的“用Java操作Windows注册表.rar”可能包含了一个完整的示例项目,你可以解压并学习其中的代码,了解如何...

    java 本地代码访问注册表

    这是一个java通过本地接口访问的源代码,在windows操作系统上试验成功,对于想学本地方法的有 帮助,代码中有JAVA与C语言的原始数据、对象及数组交互,有本地库中抛出例外,构造器调用等知识点,比较全面。

    java读取注册表信息

    JNA是Java与本机平台接口交互的一个库,它允许Java代码调用操作系统函数,包括访问注册表。首先,我们需要引入JNA库,然后通过其提供的`com.sun.jna.platform.win32.WinReg`类来操作注册表。例如,以下代码展示了...

    JAVA操作注册表的神器

    Java作为一种跨平台的语言,虽然不能直接访问注册表,但通过特定的库和方法,我们可以实现对Windows注册表的操作。本篇文章将详细介绍如何利用Java来操作注册表,并介绍一个名为"JAVA操作注册表的神器"的工具。 ...

    Java直接访问Windows注册表

    Jave的Preferences只在Software\JavaSoft\Prefs操作,反射WindowsPreferences能够操作Windows注册表的其他节点. 方法: 1.public static void put(int root,String path,String key,String val) 2.public static ...

    Java操作注册表插件

    然而,操作系统级别的任务,如操作注册表,通常不是Java的强项,因为注册表是Windows操作系统的核心组件,主要用于存储系统和应用程序设置。在Windows上,Java开发者可能会遇到需要读取或修改注册表键值的情况,这时...

    java读取注册表工具.zip

    6. **安全性考虑**:由于访问注册表涉及到系统安全,因此在实际应用中,需要确保只读取和写入必要的键,并处理可能的安全风险。 这个工具可能具有以下功能: - 读取指定的注册表键值 - 获取注册表子键 - 处理多层...

    (java)注册表清理

    Java并不直接支持访问注册表,但可以通过Java的JNI(Java Native Interface)或者JNA(Java Native Access)库来调用Windows API,实现对注册表的读取和修改。JNI允许Java代码调用本地(即非Java)代码,而JNA则提供...

    java如何操作注册表源代码

    在 Java 中操作注册表,通常需要借助第三方库,例如 JRegistryKey,这是一个开源的 Java 注册表库,它允许 Java 应用程序以类似文件系统的方式访问 Windows 注册表。以下是一些关键知识点: 1. **JRegistryKey 库**...

    java读取注册表的简单方法

    1. **JNA(Java Native Access)库**:由于Java本身不支持直接访问操作系统级别的功能,如读写注册表,所以我们需要借助于像JNA这样的库。JNA允许Java代码与本地操作系统API交互,无需编写C/C++的中间层。 2. **JNA...

    JAVA注册表垃圾清理

    同时,"另附jRegistryKey的操作API使用说明"表明该软件可能使用了名为jRegistryKey的库来操作注册表,这个库提供了Java API来访问和修改注册表项,对于学习Java与注册表交互的开发者来说,这部分资料尤为珍贵。...

    java操作注册表简单示例

    2. **定义注册表访问接口**:使用JNA的`com.sun.jna.platform.win32.WinReg`接口,它可以提供访问注册表的关键函数,如`HKEY_CURRENT_USER`、`RegOpenKeyEx`、`RegQueryValueEx`等。 3. **打开注册表键**:使用`...

    java 读取注册表(源码 + jar + dll)

    这里提到的"java 读取注册表(源码 + jar + dll)"就是一种解决方案,它结合了Java代码和DLL动态链接库来实现对Windows注册表的访问。 首先,`jRegistryKey.dll`是一个Windows平台下的动态链接库,它提供了底层的...

    Java操作windows注册表

    Java操作注册表时,通常会访问这些根键下的特定分支,如`HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Prefs`或`HKEY_CURRENT_USER\Software\JavaSoft\Prefs`,用于存储与Java应用相关的配置信息。 #### 二、Java操作...

    java操作注册表

    在 Java 中操作 Windows 注册表,需要注意 Java 的平台独立性质和 Windows 注册表的访问限制。Java 不能直接任意操作 Windows 注册表,其中 java.util.prefs 中的 Preferences 类只可以操作部分注册表。

    JAVA操作windows注册表

    首先,由于Java本身并不直接支持对Windows注册表的访问,我们需要借助第三方库,如`JRegistryKey`,这是一个开源的Java库,允许开发者通过Java代码读取和修改Windows注册表。要使用这个库,你需要将其导入到你的项目...

    java注册表修改

    2. **系统集成服务**:开发与操作系统紧密集成的服务时,可能需要访问注册表中的关键信息,如驱动程序路径、服务状态等。 3. **自动化脚本**:在批处理任务或自动化测试中,可能需要修改注册表来调整系统行为或验证...

    JRegistry-1.8.3_src-bin_x86__x86-64源码加dll.zip

    java访问注册表类库。JRegistry-1.8.3_src-bin_x86__x86-64 java程序访问注册表(win10) jregistry是一款强大的jar,,,相当好用,,,没有限制,,可以随心所欲访问注册表 【3】将jar放添加到项目中...

    主要原理是Java通过修改注册表实现的,简单、安全、可靠。.

    com.ice.jni.registry包是通过JNI(Java native interface)实现的Windows注册表操作API,可以用来访问、修改和导出Windows注册表。现在这个包已经公开了,可以放心的使用而不必担心license的问题,并且包括一个构建好...

Global site tag (gtag.js) - Google Analytics