Partager via


RegistryKey.OpenRemoteBaseKey Méthode

Définition

Ouvre une nouvelle T:Microsoft.Win32.RegistryKey qui représente la clé demandée sur un ordinateur distant, avec l'option d'affichage de Registre spécifié.

Surcharges

OpenRemoteBaseKey(RegistryHive, String)

Ouvre une nouvelle RegistryKey qui représente la clé demandée sur un ordinateur distant.

OpenRemoteBaseKey(RegistryHive, String, RegistryView)

Ouvre une nouvelle clé de Registre qui représente la clé demandée sur un ordinateur distant avec l'affichage spécifié.

OpenRemoteBaseKey(RegistryHive, String)

Source:
RegistryKey.cs

Ouvre une nouvelle RegistryKey qui représente la clé demandée sur un ordinateur distant.

public:
 static Microsoft::Win32::RegistryKey ^ OpenRemoteBaseKey(Microsoft::Win32::RegistryHive hKey, System::String ^ machineName);
public static Microsoft.Win32.RegistryKey OpenRemoteBaseKey (Microsoft.Win32.RegistryHive hKey, string machineName);
static member OpenRemoteBaseKey : Microsoft.Win32.RegistryHive * string -> Microsoft.Win32.RegistryKey
Public Shared Function OpenRemoteBaseKey (hKey As RegistryHive, machineName As String) As RegistryKey

Paramètres

hKey
RegistryHive

Clé HKEY à ouvrir à partir de l'énumération RegistryHive.

machineName
String

Ordinateur distant.

Retours

Clé de Registre demandée.

Exceptions

hKey n'est pas valide.

machineName est introuvable.

machineName a la valeur null.

L'utilisateur ne dispose pas des autorisations nécessaires pour exécuter cette opération.

L'utilisateur ne dispose pas des droits d'accès à la base de registres appropriés.

Exemples

L’exemple de code suivant montre comment ouvrir une clé de Registre sur un ordinateur distant et énumérer les valeurs de la clé. L’ordinateur distant doit exécuter le service de Registre distant. Spécifiez le nom de l’ordinateur distant en tant qu’argument de ligne de commande lors de l’appel du programme.

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

Remarques

Le registre de l’ordinateur local est ouvert si machineName a la valeur String.Empty. La clé demandée doit être une clé racine sur l’ordinateur distant et est identifiée par la valeur appropriée RegistryHive .

Pour qu’une clé soit ouverte à distance, le serveur et les ordinateurs clients doivent exécuter le service de Registre distant et avoir l’administration à distance activée.

Voir aussi

S’applique à

OpenRemoteBaseKey(RegistryHive, String, RegistryView)

Source:
RegistryKey.cs

Ouvre une nouvelle clé de Registre qui représente la clé demandée sur un ordinateur distant avec l'affichage spécifié.

public:
 static Microsoft::Win32::RegistryKey ^ OpenRemoteBaseKey(Microsoft::Win32::RegistryHive hKey, System::String ^ machineName, Microsoft::Win32::RegistryView view);
public static Microsoft.Win32.RegistryKey OpenRemoteBaseKey (Microsoft.Win32.RegistryHive hKey, string machineName, Microsoft.Win32.RegistryView view);
[System.Runtime.InteropServices.ComVisible(false)]
public static Microsoft.Win32.RegistryKey OpenRemoteBaseKey (Microsoft.Win32.RegistryHive hKey, string machineName, Microsoft.Win32.RegistryView view);
static member OpenRemoteBaseKey : Microsoft.Win32.RegistryHive * string * Microsoft.Win32.RegistryView -> Microsoft.Win32.RegistryKey
[<System.Runtime.InteropServices.ComVisible(false)>]
static member OpenRemoteBaseKey : Microsoft.Win32.RegistryHive * string * Microsoft.Win32.RegistryView -> Microsoft.Win32.RegistryKey
Public Shared Function OpenRemoteBaseKey (hKey As RegistryHive, machineName As String, view As RegistryView) As RegistryKey

Paramètres

hKey
RegistryHive

HKEY à ouvrir à partir de l’énumération RegistryHive.

machineName
String

Ordinateur distant.

view
RegistryView

Affichage du Registre à utiliser.

Retours

Clé de Registre demandée.

Attributs

Exceptions

hKey ou view n'est pas valide.

machineName est introuvable.

machineName a la valeur null.

L'utilisateur ne dispose pas des droits d'accès à la base de registres appropriés.

L'utilisateur ne dispose pas des autorisations requises pour exécuter cette opération.

Remarques

Le registre de l’ordinateur local est ouvert si machineName a la valeur String.Empty. La clé demandée doit être une clé racine sur l’ordinateur distant et est identifiée par la valeur appropriée RegistryHive .

Pour qu’une clé soit ouverte à distance, le serveur et les ordinateurs clients doivent exécuter le service de Registre distant et avoir l’administration à distance activée.

Sur les versions 64 bits de Windows, des parties du Registre sont stockées séparément pour les applications 32 bits et 64 bits. Il existe une vue 32 bits pour les applications 32 bits et une vue 64 bits pour les applications 64 bits. Si view est Registry64 que l’ordinateur distant exécute un système d’exploitation 32 bits, la clé retournée utilise la Registry32 vue.

S’applique à