发信人: lofe ()感激生活(), 信区: BorlandDev
标  题: BCB中注册表的 使用
发信站: 哈工大紫丁香 (Sun Sep  3 07:57:46 2000), 转信

在WIN9x和WINNT中,许多高级一点的功能都要通过对注册表的操作来实现,在WinAPI中
有RegCgreateKey()、RegOpenKey()、RegQueryValue()等等函数,但是,如果用这些函
数来实现那将是非常的麻烦,幸亏我们有C++Builder,它提供了TRegistry类,有了TRe
gistry类,对注册表的操作就非常的简单了,下面我就以一个实例来说明TRegistry类的
用法。
首先,先介绍一下TRegistry的属性和方法:
TRegistry类一共有四个属性。
属性 类型 描述
CurrentKey int 包含当前键值的值,但它的意思不太好懂,所以不太常用
RootKey int 当前键值的根键,BCB定义有枚举常量:HKEY_CURRENT_USER、HKEY_CLASS
ES_ROOT、HKEY_LOCAL_MACHINE、HKEY_USERS、HKEY_CURRENT_CONFIG、HKEY_DYN_DATA、
HKEY_USERS。分别对应注册表中相应的主键。生成一个TRegistry类的实例时RootKye缺
省值为HKEY_CURRENT_USER
CurrentPath AnsiString 当前键值的文本描述,\HKEY_CURRENT_USER\Software\Borla
nd的CurrentPath="Software\Borland",而RootKey=HKEY_CURRENT_USER
LazyWrite bool 值为true:只要关闭一个键,就立即返回应用程序。值为false:必须
写完注册表后才返回。其缺省值为true。
TRegistry类的方法比较多,择其常用的简要说明如下:
方法 描述
CloseKey() 关闭一个键值并向键值写数据,只要对键值操作完毕后就应该关闭它,不过
你可以不必调用此方法,因为TRegistry的析构函数会自动调用它。
DeleteKey(AnsiString) 删除键值,参数为要删除的键值,如果参数为空字符串,则删
除当前键值
OpenKey(Ansistring,bool) 打开一个键值,如果这个键值不存在,将由第二个参数决定
是否自动建立。
LoadKey(AnsiString,AnsiString) 从文件装入键值,第一个参数为键值,第二个参数为
文件名
KeyExists(AnsiString) 检测一个键值是否存在。
SaveKey(AnsiString,AnsiString) 把一个键值保存到文件,参数说明参见LoadKey()
ReadInteger(AnsiString) 读出一个键值为整数,如果失败将抛出异常。同此函数类似
的还有ReadBool()、ReadString()、ReadFloat()、ReadDateTome()、ReadBinaryData(
)等,用来读出不同类型的键值。
ValueExists(AnsiString) 检测一个值是否存在。
WriteInteger(AnsiString,int) 写一个键值为整数,如果失败将抛出异常。同此函数类
似的还有WriteBool()、WriteString()、WriteFloat()、WriteDateTome()、WriteBina
ryData()等,用来写入不同类型的键值。
利用TRegistry是很容易的,一般来说,有以下四步操作:
1) 建立TRegistry类。2)利用OpenKey()方法打开一个键值。3)用ReadType()和WriteTy
pe()读写键值。4)调用CloseKey()关闭一个键值。
值得注意的是:在使用TRegistry类时,必须要加入此类的头文件:#include<Rgistry.
hpp>,否则会发生什么,只要稍有C语言基础都会明白。
好了,说了那么多,也该举一个实例来说明,下面我就以我的《WinNT自动登录》来说明
TRegistry类的用法。
WinNT的用户都知道,WinNT在启动时需要按Ctrl +Alt+ Del登录,即便没有密码也是如此
.虽然WinNT不会象 WIN9X那样经常死机,但每次开机都要这样还是有点烦.能 不能让Win
NT每次启动自动登录呢?其实只要把注册表的一 个属性AutoAdminLogon的值设置为"1"即
可,可惜的是这 样做只能管一次,每次启动后WinNT就会自动把它的值改为 "0"(该死的B
ill!).如果每次都要修改注册表,还不如每次手动登录呢!写个程序在启动后自动修改这
个值就OK了。
首先新建一个工程,在窗体放入4个文本框,分别命名为:edUser、edPasswd、edRePas
swd、edDomain。分别用来输入用户名、登录口令、重输口令和域,把edPasswd和edReP
asswd的PasswordChar属性改为"*"(密码方式输入)。再加入2个复选框来选择是否自动登
录(chkAuto)和自动运行(chkAutorun),一个定时器(Timer1),2个按纽(bbtOK、bbtCan
cel)和一些Label,调整布局如下图:
打开代码窗口,在头部输入以下代码:
#include<Registry.hpp>
TRegistry &regkey=* new TRegistry();//定义全局变量:注册表类。
int delay=0;//定义全局变量,延时时间
然后选择窗体的OnCreat事件,输入以下代码:
    regkey.RootKey=HKEY_LOCAL_MACHINE;//设置根键
    //打开自动登录所在的键
    regkey.OpenKey("SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Winlogo
n",true);
    //以下3句打开Windows自动运行的键值。
    TRegistry &AutoRun=* new TRegistry();
    AutoRun.RootKey=HKEY_LOCAL_MACHINE;
    AutoRun.OpenKey("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run",true
);
    if(strlen(CmdLine)>Application->ExeName.Length()+3)//如果带参数运行则是要
卸载
    {
        AutoRun.DeleteValue("Windows NT Auto Logon");//删除自己加入的属性
        regkey.DeleteValue("Windows NT Auto Logon");
    delete &AutoRun;
    Application->Terminate();//终止应用程序
    return;
    }
    //把本程序写入自动运行。
    AutoRun.WriteString("Windows NT Auto Logon",Application->ExeName);
    delete &AutoRun;
    edDomain->Text=regkey.ReadString("DefaultDomainName"); //读出域名
    edUser->Text=regkey.ReadString("DefaultUserName"); //读出用户名
    chkAuto->Checked=true;
    chkAutorun->Checked=regkey.ReadString("Windows NT Auto Logon")=="1"?true
:false; //本程序是否自动运行
    edPasswd->Text=regkey.ReadString("DefaultPasswd"); //读出口令
    setControl(!chkAutorun->Checked); //如果是自动运行状态把其他屏蔽,反之亦

    if(chkAutorun->Checked)
    {
        Timer1->Enabled=true; //自动运行开始计时
        edRePasswd->Text=edPasswd->Text;
    }
其中setControl()的功能是屏蔽几个组件,定义如下:
首先在窗体的头文件窗体类定义加入void setControl(bool);
其函数体如下(窗体名为fmMain):
void TfmMain::setControl(bool t)
{
edUser->Enabled= t;
edRePasswd->Enabled= t;
edPasswd->Enabled= t;
edDomain->Enabled= t;
chkAuto->Enabled= t;
}
在chkAutoRun的OnClick事件中根据是否选择了自动运行来决定是否启动定时器
setControl(!chkAutorun->Checked);//如果是自动运行状态把其他屏蔽,反之亦然
if(!chkAutorun->Checked)
{
Timer1->Enabled=false;//如果不是自动运行,定时器失效
delay=0;
}
else
Timer1->Enabled=true;//否则定时器有效
在按纽bbtOK的OnClick事件中输入以下代码,其功能是写入注册表。
if(edRePasswd->Text==edPasswd->Text)//如果密码正确
{
regkey.WriteString("DefaultDomainName",edDomain->Text);//写入域名
regkey.WriteString("DefaultUserName",edUser->Text);//写入用户名
regkey.WriteString("AutoAdminLogon",chkAuto->Checked?"1":"0");//写入是否自动
登录
regkey.WriteString("Windows NT Auto Logon",chkAutorun->Checked?"1":"0");//写
入是否自动运行
regkey.WriteString("DefaultPasswd",edPasswd->Text);//写入密码
if(!chkAutorun->Checked)//如果不自动运行
{
TRegistry &AutoRun=* new TRegistry();
AutoRun.RootKey=HKEY_LOCAL_MACHINE;
                        //找到自动启动
AutoRun.OpenKey("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run",true);
AutoRun.DeleteValue("Windows NT Auto Logon");//删除自己加入的属性
delete &AutoRun;
}
Application->Terminate();//程序终止。
}
else
{
ShowMessage("密码错误!");
edPasswd->Text="";
}
当程序自动运行时,延时3秒后写入注册表,在Timer1的OnTimer事件中写入如下代码:

delay++;
if(delay>=3)//延时三秒到
    bbtOK->Click();//单击《确定》按纽,写入注册表
然后在bbtCancel中加入终止程序的代码:Application->Terminate();我们的程序就算
完成了,真的完了吗?NO!我们在开始的时侯用new生成了regkey,应该要用delete删除
它,所以在窗体的OnClose事件中加入delete &regkey就OK了。
如果选择了自动运行,程序就能在每次启动时延时3秒,然后在修改注册表中相应的项后
退出,释放系统资源。
怎么样?很简单吧!如果我们平时注意收集《电脑报》等报刊杂志上的有关注册表设置
的文章,再有了功能强大使用方便的C++Builder,我们也可以写出什么"Windows 超级设
置"之类的程序了。

--

--
人生得意需尽欢,
    莫使金樽空对月。 
※ 修改:.haojs 于 Sep  3 07:55:22 修改本文.[FROM: bbs.hit.edu.cn]
--
※ 转寄:.武汉白云黄鹤站 bbs.whnet.edu.cn.[FROM: bbs.hit.edu.cn]

--
☆ 来源:.哈工大紫丁香 bbs.hit.edu.cn.[FROM: haojs.bbs@bbs.whnet.]
[百宝箱] [返回首页] [上级目录] [根目录] [返回顶部] [刷新] [返回]
Powered by KBS BBS 2.0 (http://dev.kcn.cn)
页面执行时间:7.199毫秒