RegistryKey.OpenRemoteBaseKey Metod

Definition

Öppnar en ny T:Microsoft. Win32.RegistryKey som representerar den begärda nyckeln på en fjärrdator med alternativet för angiven registervy.

Överlagringar

Name Description
OpenRemoteBaseKey(RegistryHive, String)

Öppnar en ny RegistryKey som representerar den begärda nyckeln på en fjärrdator.

OpenRemoteBaseKey(RegistryHive, String, RegistryView)

Öppnar en ny registernyckel som representerar den begärda nyckeln på en fjärrdator med den angivna vyn.

OpenRemoteBaseKey(RegistryHive, String)

Öppnar en ny RegistryKey som representerar den begärda nyckeln på en fjärrdator.

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

Parametrar

hKey
RegistryHive

HKEY som ska öppnas från RegistryHive uppräkningen.

machineName
String

Fjärrdatorn.

Returer

Den begärda registernyckeln.

Undantag

hKey är ogiltigt.

machineName hittades inte.

machineName är null.

Användaren har inte rätt behörighet för att utföra den här åtgärden.

Användaren har inte de nödvändiga registerrättigheterna.

Exempel

I följande kodexempel visas hur du öppnar en registernyckel på en fjärrdator och räknar upp nyckelns värden. Fjärrdatorn måste köra fjärrregistertjänsten. Ange namnet på fjärrdatorn som ett kommandoradsargument när programmet anropas.

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

Kommentarer

Det lokala datorregistret öppnas om machineName är String.Empty. Den begärda nyckeln måste vara en rotnyckel på fjärrdatorn och identifieras med lämpligt RegistryHive värde.

För att en nyckel ska kunna öppnas via fjärranslutning måste både server- och klientdatorerna köra fjärrregistertjänsten och ha fjärradministration aktiverat.

Se även

Gäller för

OpenRemoteBaseKey(RegistryHive, String, RegistryView)

Öppnar en ny registernyckel som representerar den begärda nyckeln på en fjärrdator med den angivna vyn.

public:
 static Microsoft::Win32::RegistryKey ^ OpenRemoteBaseKey(Microsoft::Win32::RegistryHive hKey, System::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);
[<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

Parametrar

hKey
RegistryHive

HKEY som ska öppnas från RegistryHive uppräkningen.

machineName
String

Fjärrdatorn.

view
RegistryView

Registervyn som ska användas.

Returer

Den begärda registernyckeln.

Attribut

Undantag

hKey eller view är ogiltig.

machineName hittades inte.

machineName är null.

Användaren har inte de nödvändiga registerrättigheterna.

Användaren har inte de behörigheter som krävs för att utföra den här åtgärden.

Kommentarer

Det lokala datorregistret öppnas om machineName är String.Empty. Den begärda nyckeln måste vara en rotnyckel på fjärrdatorn och identifieras med lämpligt RegistryHive värde.

För att en nyckel ska kunna öppnas via fjärranslutning måste både server- och klientdatorerna köra fjärrregistertjänsten och ha fjärradministration aktiverat.

På 64-bitarsversionerna av Windows lagras delar av registret separat för 32-bitars- och 64-bitarsprogram. Det finns en 32-bitarsvy för 32-bitarsprogram och en 64-bitarsvy för 64-bitarsprogram. Om view är Registry64 men fjärrdatorn kör ett 32-bitars operativsystem använder Registry32 den returnerade nyckeln vyn.

Gäller för