Funzione RegOpenKeyExA (winreg.h)
Apre la chiave del Registro di sistema specificata. Si noti che i nomi delle chiavi non fanno distinzione tra maiuscole e minuscole.
Per eseguire operazioni del Registro di sistema transazioni su una chiave, chiamare la funzione regOpenKeyTransacted
Sintassi
LSTATUS RegOpenKeyExA(
[in] HKEY hKey,
[in, optional] LPCSTR lpSubKey,
[in] DWORD ulOptions,
[in] REGSAM samDesired,
[out] PHKEY phkResult
);
Parametri
[in] hKey
Handle per una chiave del Registro di sistema aperta. Questo handle viene restituito dalla funzione RegCreateKeyEx
HKEY_CLASSES_ROOTHKEY_CURRENT_CONFIGHKEY_CURRENT_USERHKEY_LOCAL_MACHINEHKEY_USERS
[in, optional] lpSubKey
Nome della sottochiave del Registro di sistema da aprire.
I nomi delle chiavi non fanno distinzione tra maiuscole e minuscole.
Se il parametro lpSubKey è NULL o un puntatore a una stringa vuota e se hKey è una chiave predefinita, il sistema aggiorna la chiave predefinita e phkResult riceve lo stesso handle hKey passato alla funzione. In caso contrario, phkResult riceve un nuovo handle per la chiave aperta.
Per altre informazioni, vedere Limiti delle dimensioni degli elementi del Registro di sistema .
[in] ulOptions
Specifica l'opzione da applicare quando si apre la chiave. Impostare questo parametro su zero o su quanto segue:
Valore | Significato |
---|---|
|
La chiave è un collegamento simbolico. I collegamenti simbolici del Registro di sistema devono essere usati solo quando sono assolutamente necessari. |
[in] samDesired
Maschera che specifica i diritti di accesso desiderati per la chiave da aprire. La funzione ha esito negativo se il descrittore di sicurezza della chiave non consente l'accesso richiesto per il processo chiamante. Per altre informazioni, vedere sicurezza delle chiavi del Registro di sistema e diritti di accesso.
[out] phkResult
Puntatore a una variabile che riceve un handle per la chiave aperta. Se la chiave non è una delle chiavi predefinite del Registro di sistema, chiamare la funzione regCloseKey
Valore restituito
Se la funzione ha esito positivo, il valore restituito è ERROR_SUCCESS.
Se la funzione ha esito negativo, il valore restituito è un codice di errore diverso da zero definito in Winerror.h. È possibile usare la funzione FormatMessage
Nota
Nelle versioni legacy di Windows, questa API viene esposta anche da kernel32.dll.
Osservazioni
A differenza della funzione regCreateKeyEx
Alcune operazioni del Registro di sistema eseguono controlli di accesso sul descrittore di sicurezza della chiave, non sulla maschera di accesso specificata quando è stato ottenuto l'handle per la chiave. Ad esempio, anche se una chiave viene aperta con un samDesired di KEY_READ, può essere usata per creare chiavi del Registro di sistema se il descrittore di sicurezza della chiave è consentito. Al contrario, la funzione
Se il servizio o l'applicazione rappresenta utenti diversi, non usare questa funzione con HKEY_CURRENT_USER. Chiamare invece la funzione RegOpenCurrentUser
Si noti che le operazioni che accedono a determinate chiavi del Registro di sistema vengono reindirizzate. Per altre informazioni, vedere Registry Virtualization e dati dell'applicazione a 32 bit e a 64 bit nel Registro di sistema.
Esempi
lResult = RegOpenKeyEx (hKeyRoot, lpSubKey, 0, KEY_READ, &hKey);
if (lResult != ERROR_SUCCESS)
{
if (lResult == ERROR_FILE_NOT_FOUND) {
printf("Key not found.\n");
return TRUE;
}
else {
printf("Error opening key.\n");
return FALSE;
}
}
Per visualizzare questo esempio nel contesto, vedere Eliminazione di una chiave con sottochiavi.
Nota
L'intestazione winreg.h definisce RegOpenKeyEx come alias che seleziona automaticamente la versione ANSI o Unicode di questa funzione in base alla definizione della costante del preprocessore UNICODE. La combinazione dell'utilizzo dell'alias indipendente dalla codifica con il codice non indipendente dalla codifica può causare mancate corrispondenze che generano errori di compilazione o di runtime. Per altre informazioni, vedere convenzioni di per i prototipi di funzioni.
Fabbisogno
Requisito | Valore |
---|---|
client minimo supportato | Windows 2000 Professional [solo app desktop] |
server minimo supportato | Windows 2000 Server [solo app desktop] |
piattaforma di destinazione | Finestre |
intestazione |
winreg.h (include Windows.h) |
libreria |
Advapi32.lib |
dll | Advapi32.dll |