RegistryKey.OpenRemoteBaseKey Yöntem
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Belirtilen kayıt defteri görünümü seçeneğiyle uzak bir makinede istenen anahtarı temsil eden yeni bir T:Microsoft.Win32.RegistryKey açar.
Aşırı Yüklemeler
OpenRemoteBaseKey(RegistryHive, String) |
Uzak makinede istenen anahtarı temsil eden yeni RegistryKey bir anahtar açar. |
OpenRemoteBaseKey(RegistryHive, String, RegistryView) |
Belirtilen görünüme sahip bir uzak makinede istenen anahtarı temsil eden yeni bir kayıt defteri anahtarı açar. |
OpenRemoteBaseKey(RegistryHive, String)
- Kaynak:
- RegistryKey.cs
Uzak makinede istenen anahtarı temsil eden yeni RegistryKey bir anahtar açar.
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
Parametreler
- hKey
- RegistryHive
Numaralandırmadan RegistryHive açılacak HKEY.
- machineName
- String
Uzak makine.
Döndürülenler
İstenen kayıt defteri anahtarı.
Özel durumlar
hKey
geçersizdir.
machineName
bulunamadı.
machineName
, null
değeridir.
Kullanıcının bu işlemi gerçekleştirmek için uygun izinleri yok.
Kullanıcının gerekli kayıt defteri hakları yok.
Örnekler
Aşağıdaki kod örneği, uzak bir bilgisayarda bir kayıt defteri anahtarının nasıl açılıp anahtarın değerlerinin numaralandırılıp numaralandırılamını gösterir. Uzak bilgisayar uzak kayıt defteri hizmetini çalıştırıyor olmalıdır. Program çağrılırken uzak bilgisayarın adını komut satırı bağımsız değişkeni olarak belirtin.
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
Açıklamalar
Yerel makine kayıt defteri ise machineName
String.Emptyaçılır. İstenen anahtar uzak makinede bir kök anahtar olmalıdır ve uygun RegistryHive değerle tanımlanır.
Bir anahtarın uzaktan açılması için hem sunucu hem de istemci makinelerinin uzak kayıt defteri hizmetini çalıştırıyor olması ve uzaktan yönetimin etkin olması gerekir.
Ayrıca bkz.
Şunlara uygulanır
OpenRemoteBaseKey(RegistryHive, String, RegistryView)
- Kaynak:
- RegistryKey.cs
Belirtilen görünüme sahip bir uzak makinede istenen anahtarı temsil eden yeni bir kayıt defteri anahtarı açar.
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
Parametreler
- hKey
- RegistryHive
Numaralandırmadan RegistryHive açılacak HKEY.
- machineName
- String
Uzak makine.
- view
- RegistryView
Kullanılacak kayıt defteri görünümü.
Döndürülenler
İstenen kayıt defteri anahtarı.
- Öznitelikler
Özel durumlar
hKey
veya view
geçersiz.
machineName
bulunamadı.
machineName
, null
değeridir.
Kullanıcının gerekli kayıt defteri hakları yok.
Kullanıcının bu işlemi gerçekleştirmek için gerekli izinleri yok.
Açıklamalar
Yerel makine kayıt defteri ise machineName
String.Emptyaçılır. İstenen anahtar uzak makinede bir kök anahtar olmalıdır ve uygun RegistryHive değerle tanımlanır.
Bir anahtarın uzaktan açılması için hem sunucu hem de istemci makinelerinin uzak kayıt defteri hizmetini çalıştırıyor olması ve uzaktan yönetimin etkin olması gerekir.
Windows'un 64 bit sürümlerinde, kayıt defterinin bölümleri 32 bit ve 64 bit uygulamalar için ayrı olarak depolanır. 32 bit uygulamalar için 32 bit görünüm ve 64 bit uygulamalar için 64 bit görünüm vardır. Ancak Registry64 uzak makine 32 bit işletim sistemi çalıştırıyorsaview
, döndürülen anahtar görünümü kullanırRegistry32.