BCryptEnumRegisteredProviders 함수(bcrypt.h)
BCryptEnumRegisteredProviders 함수는 등록된 공급자에 대한 정보를 검색합니다.
구문
NTSTATUS BCryptEnumRegisteredProviders(
[in, out] ULONG *pcbBuffer,
[in, out] PCRYPT_PROVIDERS *ppBuffer
);
매개 변수
[in, out] pcbBuffer
항목에서 ppBuffer 매개 변수가 가리키는 버퍼의 크기(바이트)를 포함하는 ULONG 값에 대한 포인터입니다. 종료 시 이 값은 버퍼에 복사된 바이트 수 또는 버퍼의 필요한 크기(바이트)를 받습니다.
[in, out] ppBuffer
등록된 공급자의 컬렉션을 설명하는 CRYPT_PROVIDERS 구조 및 기타 데이터를 수신하는 버퍼 포인터에 대한 포인터입니다.
이 매개 변수가 NULL인 경우 이 함수는 STATUS_BUFFER_TOO_SMALL 반환하고 모든 데이터의 필요한 크기(바이트)인 pcbBuffer 매개 변수가 가리키는 값에 배치합니다.
이 매개 변수가 NULL 포인터의 주소인 경우 이 함수는 필요한 메모리를 할당하고, 메모리를 공급자에 대한 정보로 채우고, 이 매개 변수에 이 메모리에 대한 포인터를 배치합니다. 이 메모리 사용을 마쳤으면 이 포인터를 BCryptFreeBuffer 함수에 전달하여 해제합니다.
이 매개 변수가 NULL 이 아닌 포인터의 주소인 경우 이 함수는 공급자 정보를 이 버퍼에 복사합니다. pcbBuffer 매개 변수는 전체 버퍼의 크기(바이트)를 포함해야 합니다. 버퍼가 모든 공급자 정보를 저장할 만큼 크지 않은 경우 이 함수는 STATUS_BUFFER_TOO_SMALL 반환합니다.
반환 값
함수의 성공 또는 실패를 나타내는 상태 코드를 반환합니다.
가능한 반환 코드에는 다음이 포함되지만 이에 국한되지는 않습니다.
반환 코드 | 설명 |
---|---|
|
함수가 성공했습니다. |
|
pcbBuffer 매개 변수에 지정된 크기가 모든 데이터를 저장할 만큼 크지 않습니다. |
|
하나 이상의 매개 변수가 유효하지 않습니다. |
설명
BCryptEnumRegisteredProviders 함수는 다음 두 가지 방법 중 하나로 호출할 수 있습니다.
-
첫 번째는 BCryptEnumRegisteredProviders 함수가 메모리를 할당하도록 하는 것입니다. 이 작업은 ppBuffer 매개 변수에 대한 NULL 포인터의 주소를 전달하여 수행됩니다.
다음 예제에서는 BCryptEnumRegisteredProviders 함수를 사용하여 ppBuffer 매개 변수에 대한 NULL 포인터의 주소를 전달하여 메모리를 할당하는 방법을 보여줍니다.
PCRYPT_PROVIDERS pBuffer = NULL; BCryptEnumRegisteredProviders(/*...*/, &pBuffer);
이 코드는 CRYPT_PROVIDERS 구조체 및 연결된 문자열에 필요한 메모리를 할당합니다. 이러한 방식으로 BCryptEnumRegisteredProviders 함수를 사용하는 경우 ppBuffer 를 BCryptFreeBuffer 함수에 전달하여 더 이상 필요하지 않은 경우 메모리를 해제해야 합니다.
- 두 번째 방법은 필요한 메모리를 직접 할당하는 것입니다. 이 작업은 ppBuffer 매개 변수에 대해 NULL을 사용하여 BCryptEnumRegisteredProviders 함수를 호출하여 수행됩니다. BCryptEnumRegisteredProviders 함수는 CRYPT_PROVIDERS 구조체 및 모든 문자열의 pcbBuffer 매개 변수, 필요한 크기(바이트)가 가리키는 값에 배치됩니다. 그런 다음 필요한 메모리를 할당하고 BCryptEnumRegisteredProviders 함수에 대한 두 번째 호출에서 ppBuffer 매개 변수에 대한 이 버퍼 포인터의 주소를 전달합니다.
BCryptEnumRegisteredProviders 는 사용자 모드에서만 호출할 수 있습니다.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows Vista [데스크톱 앱만 해당] |
지원되는 최소 서버 | Windows Server 2008 [데스크톱 앱만 해당] |
대상 플랫폼 | Windows |
헤더 | bcrypt.h |
라이브러리 | Bcrypt.lib |
DLL | Bcrypt.dll |