Nasıl Yapılır: Visual Basic'te Kayıt Defteri Anahtarı Oluşturma ve Değerini Ayarlama
CreateSubKey
Nesnenin My.Computer.Registry
yöntemi, bir kayıt defteri anahtarı oluşturmak için kullanılabilir.
Yordam
Kayıt defteri anahtarı oluşturmak için
Anahtarın
CreateSubKey
altına hangi kovanın yerleştirileceğini ve anahtarın adını belirterek yöntemini kullanın. ParametresiSubkey
büyük/küçük harfe duyarlı değil. Bu örnek, HKEY_CURRENT_USER altında kayıt defteri anahtarınıMyTestKey
oluşturur.My.Computer.Registry.CurrentUser.CreateSubKey("MyTestKey")
Kayıt defteri anahtarı oluşturmak ve içinde bir değer ayarlamak için
Anahtarın
CreateSubkey
altına hangi kovanın yerleştirileceğini ve anahtarın adını belirterek yöntemini kullanın. Bu örnek, HKEY_CURRENT_USER altında kayıt defteri anahtarınıMyTestKey
oluşturur.My.Computer.Registry.CurrentUser.CreateSubKey("MyTestKey")
yöntemiyle
SetValue
değerini ayarlayın. Bu örnek, dize değerini ayarlar. "MyTestKeyValue" için "Bu bir test değeridir".My.Computer.Registry.SetValue("HKEY_CURRENT_USER\MyTestKey", "MyTestKeyValue", "This is a test value.")
Örnek
Bu örnek, HKEY_CURRENT_USER altında kayıt defteri anahtarını MyTestKey
oluşturur ve dize değerini MyTestKeyValue
olarak This is a test value
ayarlar.
My.Computer.Registry.CurrentUser.CreateSubKey("MyTestKey")
' Change MyTestKeyValue to This is a test value.
My.Computer.Registry.SetValue("HKEY_CURRENT_USER\MyTestKey",
"MyTestKeyValue", "This is a test value.")
Güçlü Programlama
Anahtarınız için uygun bir konum bulmak için kayıt defteri yapısını inceleyin. Örneğin, geçerli kullanıcının HKEY_CURRENT_USER\Yazılım anahtarını açmak ve şirketinizin adını içeren bir anahtar oluşturmak isteyebilirsiniz. Ardından kayıt defteri değerlerini şirketinizin anahtarına ekleyin.
Bir Web uygulamasından kayıt defterini okurken, geçerli kullanıcı Web uygulamasında uygulanan kimlik doğrulamasına ve kimliğe bürünme işlemine bağlıdır.
Verileri yerel bilgisayara () yazmak yerine kullanıcı klasörüne (CurrentUserLocalMachine) yazmak daha güvenlidir.
Bir kayıt defteri değeri oluşturduğunuzda, bu değer zaten varsa ne yapacağınıza karar vermeniz gerekir. Başka bir işlem( belki de kötü amaçlı bir işlem) değeri zaten oluşturmuş ve buna erişimi olabilir. Verileri kayıt defteri değerine yerleştirdiğinizde, veriler diğer işlem tarafından kullanılabilir. Bunu önlemek için yöntemini kullanın GetValue . Anahtar henüz mevcut değilse döndürür Nothing
.
Kayıt defteri anahtarı ACL'ler (Erişim Denetim Listeleri) tarafından korunsa bile, parolalar gibi gizli dizileri kayıt defterinde düz metin olarak depolamak güvenli değildir.
Aşağıdaki koşullar özel bir duruma neden olabilir:
Anahtarın
Nothing
adı : (ArgumentNullException).Kullanıcının kayıt defteri anahtarları (SecurityException) oluşturma izinleri yok.
Anahtar adı 255 karakter sınırını (ArgumentException ) aşıyor.
Anahtar kapatıldı (IOException).
Kayıt defteri anahtarı salt okunur (UnauthorizedAccessException).
.NET Framework Güvenliği
Bu işlemi çalıştırmak için derlemeniz sınıf tarafından RegistryPermission verilen bir ayrıcalık düzeyi gerektirir. Kısmi güven bağlamında çalıştırıyorsanız, işlem yetersiz ayrıcalıklar nedeniyle bir özel durum oluşturabilir. Benzer şekilde, kullanıcının ayarlar oluşturmak veya ayarlara yazmak için doğru ACL'lere sahip olması gerekir. Örneğin, kod erişimi güvenlik iznine sahip yerel bir uygulamanın işletim sistemi izni olmayabilir. Daha fazla bilgi için bkz . Kod Erişimi Güvenliğiyle ilgili Temel Bilgiler.
Not
Kod Erişim Güvenliği (CAS), .NET Framework ve .NET'in tüm sürümlerinde kullanım dışı bırakılmıştır. .NET'in son sürümleri CAS ek açıklamalarını dikkate almaz ve CAS ile ilgili API'ler kullanılırsa hata üretir. Geliştiriciler, güvenlik görevlerini yerine getirmek için alternatif yöntemler aramalıdır.