我的程序在WIN2000 PROFESSIONAL版本下操作注册表一切正常,
而在WIN2000 SERVER版本下操作注册表,无一成功,我用的是
Administrator权限登录操作系统;     请各位帮忙解决一下,要是分不够,可以继续加!!!!!

解决方案 »

  1.   

    不会吧,你的程序可能有问题,你也可以看看注册表,用编辑器regedit或regedt32
      

  2.   

    没有呀,将我的部分程序粘出:unsigned char tmp[256]="hello";
    HKEY hKEY;
    DWORD type=REG_SZ;
    DWORD size=80;
    LPCTSTR path="Software\\Microsoft\\MS Setup (ACME)\\User Info" ;long ret=::RegOpenKeyEx(HKEY_CURRENT_USER,path,0,KEY_WRITE|KEY_READ, &hKEY);
    if(ret!=ERROR_SUCCESS) return false; 
    ret=::RegQueryValueEx(hKEY,"AdminUserName", NULL,&type,tmp,&size);
    if(ret!=ERROR_SUCCESS)     return false;::RegCloseKey(hKEY);
      

  3.   

    我不熟悉win2000pro 但在win2000server中 是localsystem最大 许多键在默认情况下 administrator都无法读取 当然 administrator可以夺回来 请用regedt32进行权限修改
      

  4.   

    我不熟悉win2000pro 但在win2000server中 是localsystem最大 许多键在默认情况下 administrator都无法读取 当然 administrator可以夺回来 请用regedt32进行权限修改 当然可以用程序来提升权限
      

  5.   

    请问 tanghui21(blueman) 如何修改权限
      

  6.   

    首先根据我的经验,pro与server的注册表访问机制没有什么不同,但有时你的访问参数也可能导致访问失败.你看看用下面的代码能不能行.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; 
       }   执行上面的修改注册表的操作后,可打开注册表查看具体的数值,可以看到已经成功地修改了有关的数据了。  
      

  7.   

    还是不行;
    必须用LYBYTE类型吗?
    REG_SZ就不行吗
      

  8.   

    你的机器是联网的吗?如果联入一个域中,并且用域分配的帐号登陆的话,本地Administrator和Local System也会有权限问题的,最好的办法是把信息写在LocalMachine下面,CurrentUser恐怕不能保证一定可以访问的。