vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Top-Preis! AP-Access-Tools-CD Volume 1  
 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

Visual-Basic Einsteiger
Re: Registry auslesen 
Autor: brave@heart
Datum: 30.06.04 16:23

hi knuddel!

ich hab da mal was "zusammengewurschtelt"
Const ERROR_NO_MORE_ITEMS = 259&
Const HKEY_CURRENT_CONFIG = &H80000005
Const HKEY_LOCAL_MACHINE = &H80000002
Const HKEY_CURRENT_USER = &H80000001
Const REG_SZ = 1 ' Unicode nul terminated string
Const REG_BINARY = 3 ' Free form binary
 
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 RegQueryValueEx Lib "advapi32.dll" Alias _
"RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal _
lpReserved As Long, lpType As Long, lpData As Any, lpcbData As Long) As Long
 
Dim hKey As Long, Cnt As Long, sName As String, sData As String, Ret As Long, _
  RetData As Long
Dim initkey As String
 
Private Sub Form_Load()
  Const BUFFER_SIZE As Long = 255
  Ret = BUFFER_SIZE
  initkey = "Software\Microsoft\Windows\CurrentVersion\Uninstall"
  If RegOpenKey(HKEY_LOCAL_MACHINE, initkey, hKey) <> 0 Then
    RegCloseKey hKey
    Exit Sub
  End If
  sName = Space(BUFFER_SIZE)
  RegOpenKey HKEY_LOCAL_MACHINE, initkey, hKey
  While RegEnumKeyEx(hKey, Cnt, sName, Ret, ByVal 0&, vbNullString, ByVal 0&, _
    ByVal 0&) <> ERROR_NO_MORE_ITEMS
      List1.AddItem "  " + Left$(sName, Ret)
      Cnt = Cnt + 1
      sName = Space(BUFFER_SIZE)
      Ret = BUFFER_SIZE
  Wend
  RegCloseKey hKey
End Sub
 
Private Sub List1_Click()
    Text1.Text = GetString(HKEY_LOCAL_MACHINE, initkey & "\" & Mid(List1.List( _
      List1.ListIndex), 3), "DisplayName")
End Sub
 
Function RegQueryStringValue(ByVal hKey As Long, ByVal strValueName As String) _
  As String
    Dim lResult As Long, lValueType As Long, strBuf As String, lDataBufSize As _
    Long
    'retrieve nformation about the key
    lResult = RegQueryValueEx(hKey, strValueName, 0, lValueType, ByVal 0, _
      lDataBufSize)
    If lResult = 0 Then
        If lValueType = REG_SZ Then
            'Create a buffer
            strBuf = String(lDataBufSize, Chr$(0))
            'retrieve the key's content
            lResult = RegQueryValueEx(hKey, strValueName, 0, 0, ByVal strBuf, _
              lDataBufSize)
            If lResult = 0 Then
                'Remove the unnecessary chr$(0)'s
                RegQueryStringValue = Left$(strBuf, InStr(1, strBuf, Chr$(0)) - _
                  1)
            End If
        ElseIf lValueType = REG_BINARY Then
            Dim strData As Integer
            'retrieve the key's value
            lResult = RegQueryValueEx(hKey, strValueName, 0, 0, strData, _
              lDataBufSize)
            If lResult = 0 Then
                RegQueryStringValue = strData
            End If
        End If
    End If
End Function
Function GetString(hKey As Long, strPath As String, strValue As String)
    Dim Ret
    'Open the key
    RegOpenKey hKey, strPath, Ret
    'Get the key's content
    GetString = RegQueryStringValue(Ret, strValue)
    'Close the key
    RegCloseKey Ret
End Function

mfg
brave@heart

...bis zur unendlichkeit und noch viel weiter...

alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Registry auslesen704Knuddel30.06.04 15:07
Re: Registry auslesen624brave@heart30.06.04 16:23
Re: Registry auslesen488Knuddel01.07.04 11:11
Re: Registry auslesen486brave@heart01.07.04 15:42
Re: Registry auslesen475Knuddel01.07.04 15:55
Re: Registry auslesen484Knuddel01.07.04 15:40

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