[英]C# Get BaseKey from RegistryKey
我有一個打開的注冊表子項,例如 HKEY_CURRENT_USER\SOFTWARE\Microsoft。 如何擺脫它的基本注冊表項或注冊表 Hive?
RegistryKey.OpenBaseKey(RegistryHive, RegistryView) 方法沒有將 RegistryKey 或字符串傳遞給它的重載。
我寫了以下代碼:
// OUR INPUT:
RegistryKey inputKey = Registry.CurrentUser.OpenSubKey("SOFTWARE\\Microsoft");
string subKeyName = subkey.ToString();
string hiveName = subKeyName.Substring(0, subKeyName.IndexOf('\\'));
RegistryHive regHive;
switch (hiveName)
{
case "HKEY_CLASSES_ROOT": regHive = RegistryHive.ClassesRoot; break;
case "HKEY_CURRENT_USER": regHive = RegistryHive.CurrentUser; break;
case "HKEY_LOCAL_MACHINE": regHive = RegistryHive.LocalMachine; break;
case "HKEY_USERS": regHive = RegistryHive.Users; break;
case "PerformanceData": regHive = RegistryHive.LocalMachine; break;
case "CurrentConfig": regHive = RegistryHive.CurrentConfig; break;
case "DynData": regHive = RegistryHive.DynData; break;
default: throw new System.ArgumentOutOfRangeException();
}
// OUR TARGET:
RegistryKey baseKey = RegistryKey.OpenBaseKey(regHive, RegistryView.Default);
它有效,但在我看來應該有更好的解決方案。
也許您知道另一種解決方案?
您基本上走在正確的軌道上,並且正在做所有可以做的事情。
注冊表class 只是win32 API的包裝,這里沒有真正的魔法,它適用於注冊表和hives的字符串路徑。
更多鏈接:
您可以在此處查看文檔, RegistryKey Class
在此處深入了解源代碼, registrykey.cs
這里madreflection添加的Win32注冊表api, winreg.h header
正如您已經指出的那樣,沒有更簡單的方法可以實現您的預期目標
@TheGeneral,感謝您提供源代碼鏈接。 在registry.cs中,我找到了一種可以滿足我需求的方法。 不幸的是,它是私有方法,我們需要在我們的項目中再次重寫它:
微軟解決方案:
// Following function will parse a keyName and returns the basekey for it.
// It will also store the subkey name in the out parameter.
// If the keyName is not valid, we will throw ArgumentException.
// The return value shouldn't be null.
//
[System.Security.SecurityCritical] // auto-generated
private static RegistryKey GetBaseKeyFromKeyName(string keyName, out string subKeyName) {
if( keyName == null) {
throw new ArgumentNullException("keyName");
}
string basekeyName;
int i = keyName.IndexOf('\\');
if( i != -1) {
basekeyName = keyName.Substring(0, i).ToUpper(System.Globalization.CultureInfo.InvariantCulture);
}
else {
basekeyName = keyName.ToUpper(System.Globalization.CultureInfo.InvariantCulture);
}
RegistryKey basekey = null;
switch(basekeyName) {
case "HKEY_CURRENT_USER":
basekey = Registry.CurrentUser;
break;
case "HKEY_LOCAL_MACHINE":
basekey = Registry.LocalMachine;
break;
case "HKEY_CLASSES_ROOT":
basekey = Registry.ClassesRoot;
break;
case "HKEY_USERS":
basekey = Registry.Users;
break;
case "HKEY_PERFORMANCE_DATA":
basekey = Registry.PerformanceData;
break;
case "HKEY_CURRENT_CONFIG":
basekey = Registry.CurrentConfig;
break;
case "HKEY_DYN_DATA":
basekey = RegistryKey.GetBaseKey(RegistryKey.HKEY_DYN_DATA);
break;
default:
throw new ArgumentException(Environment.GetResourceString("Arg_RegInvalidKeyName", "keyName"));
}
if( i == -1 || i == keyName.Length) {
subKeyName = string.Empty;
}
else {
subKeyName = keyName.Substring(i + 1, keyName.Length - i - 1);
}
return basekey;
}
我的解決方案:我將其重寫為擴展方法:
public static RegistryHive GetRegistryHive(this RegistryKey key)
{
if (key == null)
{
throw new System.ArgumentNullException(nameof(key));
}
int i = key.Name.IndexOf('\\');
string basekeyName = (i != -1) ? key.Name.Substring(0, i) : key.Name;
switch (basekeyName)
{
case "HKEY_CLASSES_ROOT": return RegistryHive.ClassesRoot;
case "HKEY_CURRENT_USER": return RegistryHive.CurrentUser;
case "HKEY_LOCAL_MACHINE": return RegistryHive.LocalMachine;
case "HKEY_USERS": return RegistryHive.Users;
case "HKEY_PERFORMANCE_DATA": return RegistryHive.LocalMachine;
case "HKEY_CURRENT_CONFIG": return RegistryHive.CurrentConfig;
case "HKEY_DYN_DATA": return RegistryHive.DynData;
default: throw new System.ArgumentException(nameof(basekeyName));
}
}
public static RegistryKey OpenBaseKey(this RegistryKey key)
{
return RegistryKey.OpenBaseKey(GetRegistryHive(key), key.View);
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.