vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
SEPA-Dateien erstellen inkl. IBAN-, BLZ-/Kontonummernprüfung  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

Allgemeine Diskussionen
so, jetzt hab ich dir was zusammen gebastelt 
Autor: newbie
Datum: 02.10.02 20:59

bei diesem beispiel würde der schlüssel "Run" und alle seine
unterschlüssel gelöscht (also mit vorsicht zu genießen). die
funktion gibt True zurück wenn sie erfolgreich war.
Const ERROR_NO_MORE_ITEMS = 259&
Const HKEY_CURRENT_CONFIG = &H80000005
Const HKEY_LOCAL_MACHINE = &H80000002
Const HKEY_CURRENT_USER = &H80000001
Private Declare Function RegCloseKey Lib "advapi32.dll" (ByVal hKey As Long) As _
  Long
Private Declare Function RegOpenKey Lib "advapi32.dll" Alias "RegOpenKeyA" ( _
ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
Private Declare Function RegEnumKeyEx Lib "advapi32.dll" Alias "RegEnumKeyExA" ( _
ByVal hKey As Long, ByVal dwIndex As Long, ByVal lpName As String, lpcbName As _
Long, ByVal lpReserved As Long, ByVal lpClass As String, lpcbClass As Long, _
lpftLastWriteTime As Any) As Long
Private Declare Function RegDeleteKey Lib "advapi32.dll" Alias "RegDeleteKeyA" ( _
ByVal hKey As Long, ByVal lpSubKey As String) As Long
 
Private Function delregkeytree(mainkey As Long, initkey As String) As Boolean
  Dim notpossible As Boolean
  Dim hKey As Long
  Dim Cnt As Long
  Dim sName As String
  Dim Ret As Long
  Dim initlen As Long
  Const BUFFER_SIZE As Long = 255
  Ret = BUFFER_SIZE
  initlen = Len(Left(initkey, InStrRev(initkey, "\") - 1))
  If RegOpenKey(mainkey, initkey, hKey) <> 0 Then
    RegCloseKey hKey
    delregkeytree = False
    Exit Function
  End If
  RegCloseKey hKey
  sName = Space(BUFFER_SIZE)
  Do
    RegOpenKey mainkey, initkey, hKey
    While RegEnumKeyEx(hKey, Cnt, sName, Ret, ByVal 0&, vbNullString, ByVal 0&, _
      ByVal 0&) <> ERROR_NO_MORE_ITEMS
        success = RegDeleteKey(hKey, Left(sName, Ret))
        If success <> 0 Then
          If notpossible = False Then
            initkey = initkey & "\" & Left(sName, Ret)
          End If
          Cnt = Cnt + 1
          notpossible = True
        End If
        sName = Space(BUFFER_SIZE)
        Ret = BUFFER_SIZE
    Wend
    If notpossible = False Then
      lastkey = Right(initkey, Len(initkey) - InStrRev(initkey, "\"))
      initkey = Left(initkey, InStrRev(initkey, "\") - 1)
      RegOpenKey mainkey, initkey, hKey
      success = RegDeleteKey(hKey, lastkey)
    End If
    Cnt = 0
    RegCloseKey hKey
    notpossible = False
  Loop Until Len(initkey) = initlen
  delregkeytree = True
End Function
 
Private Sub Command1_Click()
  Debug.Print delregkeytree(HKEY_CURRENT_USER, _
    "SOFTWAREMicrosoftWindowsCurrentVersionRun")
End Sub
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
fehler von visual basic?112georg-3001.10.02 20:32
Re: fehler von visual basic?84newbie02.10.02 09:11
Re: fehler von visual basic?59georg-3002.10.02 09:22
Re: fehler von visual basic?63newbie02.10.02 10:00
Re: fehler von visual basic?63georg-3002.10.02 10:19
Re: fehler von visual basic?81georg-3002.10.02 10:27
so, jetzt hab ich dir was zusammen gebastelt126newbie02.10.02 20:59

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2025 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel