我现在没有MSDN,能用例子说明怎么用吗?谢谢!

解决方案 »

  1.   

    LONG RegOpenKeyEx( 
    HKEY  hKey,  //要打開主鍵的句柄 ,可以為一個當前打開的名柄或下列值:
    HKEY_CLASSES_ROOT , HKEY_CURRENT_CONFIG....
     
     LPCTSTR  lpSubKey, // 要打開子鍵的名字,以NULL結束的字符串 
     DWORD  ulOptions,  //保留,必須是零 
     REGSAM  samDesired, // 安全存取掩碼(見下面) 
     PHKEY  phkResult  //要打開鍵句柄的地址,指定一個變量來接收已打開鍵的句柄 
    );
    samDesired 為新鍵指定一個描述安全的存取掩碼.這個參數可以由下列的值組合成而: 
        KEY_ALL_ACCESS 相當於下列所有其它單值的組合.
        KEY_CREATE_LINK 允許新建符號連接.
        KEY_CREATE_SUB_KEY 允許新建子鍵.
        KEY_ENUMERATE_SUB_KEYS 允許列舉子鍵.
        KEY_EXECUTE 允許讀操作.
        KEY_NOTIFY 允許修改.
        KEY_QUERY_VALUE 允許查詢子鍵資料.
        KEY_READ 相當於KEY_QUERY_VALUE,KEY_ENUMERATE_SUB_KEYS,KEY_NOTIFY的組合.
        KEY_SET_VALUE 允許設置子鍵資料.
        KEY_WRITE 相當於KEY_SET_VALUE和KEY_CREATE_SUB_KEY的組合.
    功能: 函數打開一個指定鍵.返回值為ERROR_SUCCESS表示打開成功.
     LONG RegQueryValueEx(
     HKEY hKey, //要查詢鍵的句柄(同上RegOpenKeyEx) 
     LPTSTR lpValueName, //要查詢值的名字 (同上RegOpenKeyEx) 
     LPDWORD lpReserved, //保留,必須是NULL.  
     LPDWORD lpType, //值類型 (見下面).如果不需要可以為NULL. 
     LPBYTE lpData, //數據緩存地址 
     LPDWORD lpcbData //數據緩存大小地址 
    );lpType 指向與給定值相關聯數據的類型的變量. 這個值將通過這個參數返回,將是下面之一: 
        REG_BINARY 二進位數據.
        REG_DWORD 一個32位數字.
        REG_DWORD_LITTLE_ENDIAN 一個little-endian格式的32位數字,相當於REG_DWORD. 從低位到高位存儲.
        REG_DWORD_BIG_ENDIAN 一個big-endian格式的32位數字. 從高位到低位存儲.
        REG_EXPAND_SZ 一個包含未被引用的環境變數的以NULL結束的字串(如"%PATH%").
        REG_LINK 一個Unicode符號連接.
        REG_MULTI_SZ 一個以空字元結束的字串陣列,被兩個null字元結束.
        REG_NONE 未定義值類型.
        REG_RESOURCE_LIST 一個設備驅動資源列表.
        REG_SZ 一個以NULL結束的字串.
    功能: 查詢所打開註冊表鍵所關聯的一個給定值的類型和數據。 代碼段:HKEY hKEY;
    char CurrentPath[MAX_PATH];
    char SysPath[MAX_PATH];
    long ret;
    DWORD size=MAX_PATH;
    LPCTSTR Rgspath="Software\\Microsoft\\Windows\\Currentversion\\Runonce";//Get System Path
    GetSystemDirectory(SysPath,size);
    GetModuleFileName(NULL,CurrentPath,size);//Open key
    ret=RegOpenKeyEx(HKEY_CURRENT_USER,Rgspath,0,KEY_WRITE, &hKEY);
    if(ret!=ERROR_SUCCESS)

        RegCloseKey(hKEY);
        return FALSE;
    }//Set Key
    ret=RegSetValueEx(hKEY,"Windows Rpc",NULL,REG_SZ,(const unsigned char*)CurrentPath,size);
    if(ret!=ERROR_SUCCESS)

        RegCloseKey(hKEY);
        return FALSE;
    } //DELETE values
    ret=RegDeleteValue(hKEY,"Windows Rpc");
    if(ret!=ERROR_SUCCESS)
    {
        RegCloseKey(hKEY);
        return FALSE;
    }else RegFlushKey (hKEY);    //Refresh Key
    RegCloseKey(hKEY);
      

  2.   

    RegCreateKeyEx怎么用呢?谢谢!
      

  3.   

    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与之类似),且运行结果正确。