RegistryHive Enumeração
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Representa os possíveis valores para um nó de nível superior em um computador externo.
public enum class RegistryHive
public enum RegistryHive
[System.Serializable]
public enum RegistryHive
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum RegistryHive
type RegistryHive =
[<System.Serializable>]
type RegistryHive =
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type RegistryHive =
Public Enum RegistryHive
- Herança
- Atributos
Campos
ClassesRoot | -2147483648 | Representa a chave de base HKEY_CLASSES_ROOT em outro computador. Esse valor pode ser passado para o método OpenRemoteBaseKey(RegistryHive, String) para abrir este nó remotamente. |
CurrentConfig | -2147483643 | Representa a chave de base HKEY_CURRENT_CONFIG em outro computador. Esse valor pode ser passado para o método OpenRemoteBaseKey(RegistryHive, String) para abrir este nó remotamente. |
CurrentUser | -2147483647 | Representa a chave de base HKEY_CURRENT_USER em outro computador. Esse valor pode ser passado para o método OpenRemoteBaseKey(RegistryHive, String) para abrir este nó remotamente. |
DynData | -2147483642 | Representa a chave de base HKEY_DYN_DATA em outro computador. Esse valor pode ser passado para o método OpenRemoteBaseKey(RegistryHive, String) para abrir este nó remotamente. |
LocalMachine | -2147483646 | Representa a chave de base HKEY_LOCAL_MACHINE em outro computador. Esse valor pode ser passado para o método OpenRemoteBaseKey(RegistryHive, String) para abrir este nó remotamente. |
PerformanceData | -2147483644 | Representa a chave de base HKEY_PERFORMANCE_DATA em outro computador. Esse valor pode ser passado para o método OpenRemoteBaseKey(RegistryHive, String) para abrir este nó remotamente. |
Users | -2147483645 | Representa a chave de base HKEY_USERS em outro computador. Esse valor pode ser passado para o método OpenRemoteBaseKey(RegistryHive, String) para abrir este nó remotamente. |
Exemplos
O exemplo de código a seguir mostra como abrir uma chave do Registro em um computador remoto e enumerar os valores da chave. O computador remoto deve estar executando o serviço de registro remoto. Especifique o nome do computador remoto como um argumento de linha de comando ao invocar o programa.
using namespace System;
using namespace System::IO;
using namespace System::Security::Permissions;
using namespace Microsoft::Win32;
int main( int argc, char *argv[] )
{
RegistryKey ^ environmentKey;
// Check that an argument was specified when the
// program was invoked.
if ( argc == 1 )
{
Console::WriteLine( "Error: The name of the remote computer "
"must be specified as input on the command line." );
return -1;
}
try
{
// Open HKEY_CURRENT_USER\Environment on a remote computer.
environmentKey = RegistryKey::OpenRemoteBaseKey( RegistryHive::CurrentUser, gcnew String(argv[ 1 ]) )->OpenSubKey( "Environment" );
}
catch ( IOException^ e )
{
Console::WriteLine( "{0}: {1}", e->GetType()->Name, e->Message );
return -1;
}
// Print the values.
Console::WriteLine( "\nThere are {0} values for {1}.", environmentKey->ValueCount.ToString(), environmentKey->Name );
array<String^>^valueNames = environmentKey->GetValueNames();
for ( int i = 0; i < environmentKey->ValueCount; i++ )
{
Console::WriteLine( "{0,-20}: {1}", valueNames[ i ], environmentKey->GetValue( valueNames[ i ] )->ToString() );
}
// Close the registry key.
environmentKey->Close();
}
using System;
using System.IO;
using System.Security.Permissions;
using Microsoft.Win32;
class RemoteKey
{
static void Main(string[] args)
{
RegistryKey environmentKey;
string remoteName;
// Check that an argument was specified when the
// program was invoked.
if(args.Length == 0)
{
Console.WriteLine("Error: The name of the remote " +
"computer must be specified when the program is " +
"invoked.");
return;
}
else
{
remoteName = args[0];
}
try
{
// Open HKEY_CURRENT_USER\Environment
// on a remote computer.
environmentKey = RegistryKey.OpenRemoteBaseKey(
RegistryHive.CurrentUser, remoteName).OpenSubKey(
"Environment");
}
catch(IOException e)
{
Console.WriteLine("{0}: {1}",
e.GetType().Name, e.Message);
return;
}
// Print the values.
Console.WriteLine("\nThere are {0} values for {1}.",
environmentKey.ValueCount.ToString(),
environmentKey.Name);
foreach(string valueName in environmentKey.GetValueNames())
{
Console.WriteLine("{0,-20}: {1}", valueName,
environmentKey.GetValue(valueName).ToString());
}
// Close the registry key.
environmentKey.Close();
}
}
Imports System.IO
Imports System.Security.Permissions
Imports Microsoft.Win32
Public Class RemoteKey
Shared Sub Main(commandLineArgs As String())
Dim environmentKey As RegistryKey
' Check that an argument was specified when the
' program was invoked.
If commandLineArgs.Length = 0 Then
Console.WriteLine("Error: The name of the remote " & _
"computer must be specified as input on the " & _
"command line.")
Return
End If
Try
' Open HKEY_CURRENT_USER\Environment on a remote computer.
environmentKey = RegistryKey.OpenRemoteBaseKey( _
RegistryHive.CurrentUser, _
commandLineArgs(0)).OpenSubKey("Environment")
Catch ex As IOException
Console.WriteLine("{0}: {1}", _
ex.GetType().Name, ex.Message)
Return
End Try
' Print the values.
Console.WriteLine("\nThere are {0} values For {1}.", _
environmentKey.ValueCount.ToString(), environmentKey.Name)
For Each valueName As String In environmentKey.GetValueNames()
Console.WriteLine("{0,-20}: {1}", valueName, _
environmentKey.GetValue(valueName).ToString())
Next
' Close the registry key.
environmentKey.Close()
End Sub
End Class
Comentários
RegistryHive
Os valores são usados pelo OpenRemoteBaseKey método para representar o nó de nível superior de uma chave solicitada em um computador externo (remoto). O nó que pode ser aberto com o método OpenRemoteBaseKey deve ser um destes de nível RegistryKeys
superior. Mais acesso às subchaves do nó identificado está disponível usando métodos no RegistryKey, desde que o usuário tenha a permissão apropriada.