2011-10-25 62 views
2

我想加載一個脫機的NTUSER.DAT文件(然後修改它),但我無法得到這個工作。 RegLoadKey返回8589934592,我不知道它是什麼意思。這是一個失敗行:從C#加載註冊表配置單元失敗

long retVal = RegLoadKey(HKEY_USERS, "123test", @"D:\temp\NTUSER.DAT"); 

以下是完整的測試代碼:

public class RegistryTest 
{ 
    [StructLayout(LayoutKind.Sequential)] 
    private struct LUID 
    { 
     public uint LowPart; 
     public int HighPart; 
    } 

    [StructLayout(LayoutKind.Sequential)] 
    private struct LUID_AND_ATTRIBUTES 
    { 
     public LUID pLuid; 
     public UInt32 Attributes; 
    } 

    [StructLayout(LayoutKind.Sequential, Pack = 1)] 
    private struct TokPriv1Luid 
    { 
     public int Count; 
     public LUID Luid; 
     public UInt32 Attr; 
    } 

    private const Int32 ANYSIZE_ARRAY = 1; 
    private const UInt32 SE_PRIVILEGE_ENABLED = 0x00000002; 
    private const UInt32 TOKEN_ADJUST_PRIVILEGES = 0x0020; 
    private const UInt32 TOKEN_QUERY = 0x0008; 

    private const uint HKEY_USERS = 0x80000003; 
    private const string SE_RESTORE_NAME = "SeRestorePrivilege"; 
    private const string SE_BACKUP_NAME = "SeBackupPrivilege"; 

    [DllImport("kernel32.dll")] 
    static extern IntPtr GetCurrentProcess(); 

    [DllImport("advapi32.dll", SetLastError = true)] 
    [return: MarshalAs(UnmanagedType.Bool)] 
    static extern bool OpenProcessToken(IntPtr ProcessHandle, UInt32 DesiredAccess, out IntPtr TokenHandle); 

    [DllImport("advapi32.dll", SetLastError = true, CharSet = CharSet.Auto)] 
    [return: MarshalAs(UnmanagedType.Bool)] 
    static extern bool LookupPrivilegeValue(string lpSystemName, string lpName, out LUID lpLuid); 

    [DllImport("advapi32.dll", ExactSpelling = true, SetLastError = true)] 
    static extern bool AdjustTokenPrivileges(
     IntPtr htok, 
     bool disableAllPrivileges, 
     ref TokPriv1Luid newState, 
     int len, 
     IntPtr prev, 
     IntPtr relen); 

    [DllImport("advapi32.dll", SetLastError = true)] 
    static extern long RegLoadKey(UInt32 hKey, String lpSubKey, String lpFile); 

    [DllImport("advapi32.dll", SetLastError = true)] 
    static extern long RegUnLoadKey(UInt32 hKey, string lpSubKey); 

    private IntPtr _myToken; 
    private TokPriv1Luid _tokenPrivileges = new TokPriv1Luid(); 
    private TokPriv1Luid _tokenPrivileges2 = new TokPriv1Luid(); 

    private LUID _restoreLuid; 
    private LUID _backupLuid; 

    public RegistryTest() 
    { 
     if (!OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, out _myToken)) 
      Console.WriteLine("OpenProcess Error"); 

     if (!LookupPrivilegeValue(null, SE_RESTORE_NAME, out _restoreLuid)) 
      Console.WriteLine("LookupPrivilegeValue Error"); 

     if (!LookupPrivilegeValue(null, SE_BACKUP_NAME, out _backupLuid)) 
      Console.WriteLine("LookupPrivilegeValue Error"); 

     _tokenPrivileges.Attr = SE_PRIVILEGE_ENABLED; 
     _tokenPrivileges.Luid = _restoreLuid; 
     _tokenPrivileges.Count = 1; 

     _tokenPrivileges2.Attr = SE_PRIVILEGE_ENABLED; 
     _tokenPrivileges2.Luid = _backupLuid; 
     _tokenPrivileges2.Count = 1; 

     if (!AdjustTokenPrivileges(_myToken, false, ref _tokenPrivileges, 0, IntPtr.Zero, IntPtr.Zero)) 
      Console.WriteLine("AdjustTokenPrivileges Error: " + Marshal.GetLastWin32Error()); 

     if (!AdjustTokenPrivileges(_myToken, false, ref _tokenPrivileges2, 0, IntPtr.Zero, IntPtr.Zero)) 
      Console.WriteLine("AdjustTokenPrivileges Error: " + Marshal.GetLastWin32Error()); 

     // --> RegLoadKey fails with return value 8589934592 <-- 
     long retVal = RegLoadKey(HKEY_USERS, "123test", @"D:\temp\NTUSER.DAT"); 
     if (retVal != 0) 
      Console.WriteLine("RegLoadKey Error:" + retVal); 

     string test = Registry.GetValue(@"HKEY_LOCAL_MACHINE\123test\Environment", "TEMP", "") as string; 
     retVal = RegUnLoadKey(HKEY_USERS, "123test"); 
    } 
} 

我缺少什麼?請幫忙!!如果任何人有工作C#示例代碼加載配置單元和修改值,甚至更好。

謝謝。

+0

請務必閱讀:http://msdn.microsoft.com/en-us/library/windows/desktop/ms724889(v=vs.85).aspx –

回答

8

8589934592是0x200000000,長度超過32位。

RegLoadKey返回一個win32「long」值,它是32位。你已經聲明這個函數返回一個64位的C#long。如果您修復RegLoadKey聲明以返回一個int,您將得到預期值爲0的值。

+0

我認爲十六進制值需要另一個'0' –

+1

@EvanM你說得對,我無法計數。文本已更新。 – arx

+0

ARX,就是這樣!謝謝!!! – Lars