同上!

解决方案 »

  1.   

    VC++:访问和修改系统注册表  
      Windows95/98的注册表包含了Windows95/98的系统配置、PC机的硬件配置
    、Win32应用程序和用户的其他设置信息。注册表和INI文件不同,它是多层次的
    树状数据结构,具有六个分支(根键),每个分支又由许多的键和键值组成,而
    每个键则代表一个特定的配置项目。   在实际的编程工作中,我们遇到了如何在Visual C++中对Windows95/98注
    册表整个树状结构信息进行访问和修改的问题,如查询和修改注册表中用户姓名
    和公司名称的有关信息。通过编程实践,我们实现了在Visual C++中查询和修
    改系统注册表的有关信息。下面以一个实例说明具体的编程方法。   在Visual C++ 6.0或5.0环境中新建一基于对话框的工程,设置了两个命令
    按钮,名为“查询用户信息”和“修改用户信息”,用来查询和修改注册表中用
    户姓名和公司名称。这里须要指出的是,用户的信息位于系统注册表中 
    HKEY_LOCAL_MACHINE Software Microsoft Windows CurrentVersion 的位置,键
    值名RegisteredOwner和RegisteredOrganization分别表示用户的姓名和用户公司
    的名称。   1.查询用户信息的代码 
      HKEY hKEY; //定义有关的 hKEY, 在查询结束时要关闭。 
      LPCTSTR data_Set=″Software\Microsoft\Windows\CurrentVersion\″; 
      //打开与路径 data_Set 相关的 hKEY,第一个参数为根键名称,第二个参数表。 
      //表示要访问的键的位置,第三个参数必须为0,KEY_READ表示以查询的方式。 
      //访问注册表,hKEY则保存此函数所打开的键的句柄。 
      long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set, 0, KEY_READ, &hKEY)); 
      if(ret0!=ERROR_SUCCESS) //如果无法打开hKEY,则终止程序的执行 
      {MessageBox(″错误: 无法打开有关的hKEY!″); 
      return;} 
      //查询有关的数据 (用户姓名 owner_Get)。 
      LPBYTE owner_Get=new BYTE[80]; 
      DWORD type_1=REG_SZ ; DWORD cbData_1=80; 
      //hKEY为刚才RegOpenKeyEx()函数所打开的键的句柄,″RegisteredOwner″。 
      //表示要查 询的键值名,type_1表示查询数据的类型,owner_Get保存所。 
      //查询的数据,cbData_1表示预设置的数据长度。 
    long ret1=::RegQueryValueEx(hKEY, ″RegisteredOwner″, NULL, 
      &type_1, owner_Get, &cbData_1); 
      if(ret1!=ERROR_SUCCESS) 
      { 
      MessageBox(″错误: 无法查询有关注册表信息!″); 
      return; 
      } 
      // 查询有关的数据 (公司名 company_Get) 
      LPBYTE company_Get=new BYTE [80]; 
      DWORD type_2=REG_SZ; DWORD cbData_2=80; 
      long ret2=::RegQueryValueEx(hKEY, ″RegisteredOrganization″, NULL,&type_2,company_Get, &cbData_2); 
      if(ret2!=ERROR_SUCCESS) 
      { 
      MessageBox(″错误: 无法查询有关注册表信息!″); 
      return; 
       } 
      // 将 owner_Get 和 company_Get 转换为 CString 字符串, 以便显示输出。 
      CString str_owner=CString(owner_Get); 
      CString str_company=CString(company_Get); 
      delete[] owner_Get; delete[] company_Get; 
      // 程序结束前要关闭已经打开的 hKEY。 
      ::RegCloseKey(hKEY); 
      ……   这样,上述程序执行完毕,字符串str_owner和str_company则表示查询到的
    用户的姓名和公司的名称,在VC++中便可用对话框的方式将其显示出来。   2. 修改用户信息的代码(注意和上述的查询代码属于不同的函数体)   在程序中我们先显示一个对话框,要求用户输入新的用户姓名和公司名称并
    按确认键,将取得CString类型的有关字符串。要先将其转换为LPBYTE(即
    unsigned char*)型的数据类型,以便后面的函数调用。下面是程序中用到的将
    CString型转换为LPBYTE的转换函数: 
      LPBYTE CString_To_LPBYTE(CString str) 
      { 
      LPBYTE lpb=new BYTE[str.GetLength()+1]; 
      <str.GetLength(); i++)lpb[i]=str[i];> 
      for(int i=0; ibr>   lpb[str.GetLength()]=0; 
      return lpb; 
      } 
      以下则是具体的修改注册表用户信息的代码: 
      CString str_owner, str_company; 
      …… //通过对话框输入新的用户信息,保存到str_owner和str_company 
      //定义有关的 hKEY, 在程序的最后要关闭。 
    HKEY hKEY; 
      LPCTSTR data_Set=″Software\Microsoft\Windows\CurrentVersion″; 
      //打开与路径 data_Set 相关的hKEY,KEY_WRITE表示以写的方式打开。 
      long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE, 
      data_Set, 0, KEY_WRITE, &hKEY)); 
      if(ret0!=ERROR_SUCCESS) 
      { 
      MessageBox(″错误: 无法打开有关的hKEY!″); 
      return; 
      } 
      //修改有关数据(用户姓名 owner_Set),要先将CString型转换为LPBYTE。 
      LPBYTE owner_Set=CString_To_LPBYTE(str_owner); 
      DWORD type_1=REG_SZ; 
      DWORD cbData_1=str_owner.GetLength()+1; 
      //与RegQureyValueEx()类似,hKEY表示已打开的键的句柄,″RegisteredOwner″ 
      //表示要访问的键值名,owner_Set表示新的键值,type_1和cbData_1表示新值。 
      //的数据类型和数据长度 
      long ret1=::RegSetValueEx(hKEY, ″RegisteredOwner″, NULL, 
      type_1, owner_Set, cbData_1); 
      if(ret1!=ERROR_SUCCESS) 
      { 
      MessageBox(″错误: 无法修改有关注册表信息!″); 
      return; 
      } 
      //修改有关的数据 (公司名 company_Set) 
      LPBYTE company_Set=CString_To_LPBYTE(str_company); 
      DWORD type_2=REG_SZ; 
      DWORD cbData_2=str_company.GetLength()+1; 
      long ret2=::RegSetValueEx(hKEY, ″RegisteredOrganization″, NULL, 
      type_2, company_Set, cbData_2); 
      if(ret2!=ERROR_SUCCESS) 
      { 
      MessageBox(″错误: 无法修改有关注册表信息!″); 
      return; 
       }   执行上面的修改注册表的操作后,可打开注册表查看具体的数值,可以看到
    已经成功地修改了有关的数据了。   以上实例讲述了如何在VC++中访问Windows98/95的系统注册表,我们可以
    很方便地查询及修改注册表的任何位置的有关信息。以上的程序在Visual C++ 
    6.0中调试通过(Visual C++ 5.0与之类似),且运行结果正确。
      

  2.   

    请发到这里:[email protected],谢谢!
      

  3.   

    读注册表值HKEY key;
    int re1,re2;
    DWORD tem,tem2;
    int events;
    char code[10];
    char RegTable2[]=".DEFAULT\\Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings\\Url History";
    char ItEvents[]="Events";
    char Secode[]="Secode";
    re1=RegOpenKeyEx(HKEY_USERS,RegTable2,0,KEY_QUERY_VALUE,&key); //KEY_ALL_ACCESS
    if(re1 != ERROR_SUCCESS)
    MessageBox("Failed open!",NULL,MB_OK);
    tem=REG_DWORD;
    tem2=sizeof(DWORD);
    re1=::RegQueryValueEx(key,TEXT("DaysToKeep"),NULL,&tem,(BYTE*)&(events),&tem2);//注册表中必须有此"DaysToKeep"tem=REG_SZ;
    tem2=10;
    re2=::RegQueryValueEx(key,TEXT("Secode"),NULL,&tem,(BYTE*)code,&tem2);
    if(re1!=ERROR_SUCCESS||re2!=ERROR_SUCCESS){ //
    char err[]="Error";
    MessageBox(err,NULL,MB_OK);
    }
    else {
    sprintf(s,"%d",events);
    MessageBox(code,s,MB_OK);
    }
    RegCloseKey(key);
      

  4.   

    建立键值和设值InitReg proc kIn:DWORD
    LOCAL key1,key2:DWORD
    LOCAL d1:DWORD
    szText NoDos,"Software\Microsoft\Windows\CurrentVersion\Policies"
    szText WinOldApp,"WinOldApp"
    invoke RegOpenKeyEx,HKEY_CURRENT_USER,ADDR NoDos, 0, KEY_ALL_ACCESS, ADDR key1
    .if eax== ERROR_SUCCESS
    mov d1,REG_CREATED_NEW_KEY
    invoke RegCreateKeyEx,key1,ADDR WinOldApp,NULL, 0, NULL, REG_OPTION_NON_VOLATILE,KEY_ALL_ACCESS,ADDR key2, ADDR d1
    invoke RegCloseKey,key1
    invoke RegCloseKey,key2
    .endif
    invoke lstrcpy,ADDR char,ADDR NoDos
    szText Apped,'\'
    invoke lstrcat,ADDR char,ADDR Apped
    invoke lstrcat,ADDR char,ADDR WinOldApp
    invoke RegOpenKeyEx,HKEY_CURRENT_USER,ADDR char, 0, KEY_ALL_ACCESS, ADDR key1
    .if eax== ERROR_SUCCESS
    szText Disabled,"Disabled"           //禁止退出Windows进入DOS 
    szText NoReadlMode,"NoReadlMode"     //禁止进入模拟MS-DOS
    .if kIn
    mov d1,1
    .else
    mov d1,0
    .endifinvoke RegSetValueEx,key1,ADDR Disabled,0,REG_DWORD,ADDR d1,sizeof d1
    invoke RegSetValueEx,key1,ADDR NoReadlMode,0,REG_DWORD,ADDR d1,sizeof d1
    invoke RegFlushKey,key1 
    invoke RegCloseKey,key1
    .endif
    ret
    InitReg endp
      

  5.   

    枚举键和值#define DIFFFLAGLEN 6
    #define PERFENUMKEY ".DEFAULT\\Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings\\Url History"char szCounter[MAX_PATH];
    char szObject[MAX_PATH];
    char szName[MAX_PATH];
    LPSTR lpszDescBuff = NULL;
    char szDiffFlag[DIFFFLAGLEN]; // can contain either "TRUE" or "FALSE"
    DWORD rc;
    DWORD dwIndex1, dwIndex2;
    DWORD dwType;
    DWORD dwBufSize;
    HKEY hKey;
    HKEY hObject;
    HKEY hCounter;
    CWindowDC dc(this);
    rc = RegOpenKeyEx(HKEY_USERS,
    PERFENUMKEY, 0, KEY_READ, &hKey);
    if (rc == ERROR_SUCCESS)
    {
    dwBufSize = MAX_PATH;
    dwIndex1 = 0;
    // enumerate objects
    while ( RegEnumValue(hKey, dwIndex1++, szObject, &dwBufSize, NULL, NULL, NULL, NULL) == ERROR_SUCCESS )//枚举键用 RegEnumKeyEx(HKEY_LOCAL_MACHINE, PERFENUMKEY, 0, KEY_READ, &hKey);
    {
    if ( (rc=RegOpenKeyEx(hKey, szObject, 0, KEY_READ, &hObject))
    == ERROR_SUCCESS)
    {
    // process information on the open key using hObject}
    RegCloseKey(hObject);
    dwBufSize = MAX_PATH;
    }
    RegCloseKey(hKey);
    }
    else
    printf("Error %d opening %s\n", rc, PERFENUMKEY); 汇编语言events dd 0
    code db 10 DUP(0),0 ReadReg proc uses ebx edx
    LOCAL hkeyss:DWORD
    LOCAL tem1,tem2:DWORD
    LOCAL result1,result2:DWORD
    szText RegTable2,".DEFAULT\Software\Microsoft\Windows\CurrentVersion\Internet Settings\Url History"
    szText ItEvents,"Events"
    szText Secode,"Secode"
    invoke RegOpenKeyEx,HKEY_USERS,ADDR RegTable2,0,KEY_ALL_ACCESS,ADDR hkeyss
    .if eax != ERROR_SUCCESS
    mov eax,1
    ret
    .endif
    mov eax,REG_DWORD
    mov tem1,eax
    mov eax,4
    mov tem2,eax
    invoke RegQueryValueEx,hkeyss,ADDR ItEvents,NULL,ADDR tem1,ADDR events,ADDR tem2
    mov result1,eax
    mov eax,REG_SZ
    mov tem1,eax
    mov eax,10
    mov tem2,eax
    invoke RegQueryValueEx,hkeyss,ADDR Secode,NULL,ADDR tem1,ADDR code,ADDR tem2
    mov result2,eax
    invoke RegCloseKey,hkeyss
    mov ebx,result1
    mov edx,result2
    .if ebx !=ERROR_SUCCESS || edx != ERROR_SUCCESS
    mov eax,1
    .else
    xor eax,eax
    .endif
    ret
    ReadReg endp