BCryptEnumContextFunctionProviders 함수(bcrypt.h)
BCryptEnumContextFunctionProviders 함수는 지정된 구성 테이블의 컨텍스트에 대한 암호화 함수에 대한 공급자를 가져옵니다.
구문
NTSTATUS BCryptEnumContextFunctionProviders(
[in] ULONG dwTable,
[in] LPCWSTR pszContext,
[in] ULONG dwInterface,
[in] LPCWSTR pszFunction,
[in, out] ULONG *pcbBuffer,
[in, out] PCRYPT_CONTEXT_FUNCTION_PROVIDERS *ppBuffer
);
매개 변수
[in] dwTable
컨텍스트 함수 공급자를 검색할 구성 테이블을 식별합니다. 다음 값 중 하나일 수 있습니다.
값 | 의미 |
---|---|
|
로컬 머신 구성 테이블에서 컨텍스트 함수를 검색합니다. |
|
이 값은 사용할 수 없습니다. |
[in] pszContext
함수 공급자를 열거할 컨텍스트의 식별자를 포함하는 null로 끝나는 유니코드 문자열에 대한 포인터입니다.
[in] dwInterface
함수 공급자를 검색할 암호화 인터페이스를 식별합니다. 다음 값 중 하나일 수 있습니다.
값 | 의미 |
---|---|
|
비대칭 암호화 함수 공급자를 검색합니다. |
|
암호 함수 공급자를 검색합니다. |
|
해시 함수 공급자를 검색합니다. |
|
난수 생성기 함수 공급자를 검색합니다. |
|
비밀 계약 함수 공급자를 검색합니다. |
|
서명 함수 공급자를 검색합니다. |
|
키 스토리지 함수 공급자를 검색합니다. |
|
Schannel 함수 공급자를 검색합니다. |
[in] pszFunction
공급자를 열거할 함수의 식별자를 포함하는 null로 끝나는 유니코드 문자열에 대한 포인터입니다.
[in, out] pcbBuffer
항목에서 ppBuffer가 가리키는 버퍼의 크기(바이트)를 포함하는 ULONG 변수의 주소입니다. 이 크기가 컨텍스트 식별자 집합을 보유할 만큼 크지 않으면 이 함수는 STATUS_BUFFER_TOO_SMALL 함께 실패합니다.
이 함수가 반환된 후 이 값에는 ppBuffer 버퍼에 복사된 바이트 수가 포함됩니다.
[in, out] ppBuffer
이 함수에서 검색한 컨텍스트 함수 공급자 집합을 수신하는 CRYPT_CONTEXT_FUNCTION_PROVIDERS 구조체에 대한 포인터의 주소입니다. pcbBuffer 매개 변수가 가리키는 값에는 이 버퍼의 크기가 포함됩니다.
이 매개 변수가 가리키는 값이 NULL이면 이 함수는 필요한 메모리를 할당합니다. 이 포인터를 BCryptFreeBuffer 함수에 전달하여 더 이상 필요하지 않은 경우 이 메모리를 해제해야 합니다.
이 매개 변수가 NULL인 경우 이 함수는 pcbBuffer 매개 변수가 가리키는 변수에 필요한 크기(바이트)를 배치하고 STATUS_BUFFER_TOO_SMALL 반환합니다.
반환 값
함수의 성공 또는 실패를 나타내는 상태 코드를 반환합니다.
가능한 반환 코드에는 다음이 포함되지만 이에 국한되지는 않습니다.
반환 코드 | 설명 |
---|---|
|
함수가 성공했습니다. |
|
ppBuffer 매개 변수가 NULL이 아니며 pcbBuffer 매개 변수가 가리키는 값이 컨텍스트 집합을 보유할 만큼 크지 않습니다. |
|
하나 이상의 매개 변수가 유효하지 않습니다. |
|
메모리 할당 오류가 발생했습니다. |
|
지정된 조건과 일치하는 컨텍스트 함수 공급자를 찾을 수 없습니다. |
설명
BCryptEnumContextFunctionProviders는 사용자 모드에서만 호출할 수 있습니다.
예제
다음 예제에서는 BCryptEnumContextFunctionProviders 함수를 사용하여 로컬 컴퓨터 구성 테이블의 모든 컨텍스트에 대한 모든 키 스토리지 함수에 대한 공급자를 열거하는 방법을 보여 줍니다.
#include <windows.h>
#include <stdio.h>
#include <ntstatus.h>
#include <Bcrypt.h>
#pragma comment(lib, "Bcrypt.lib")
#ifndef NT_SUCCESS
#define NT_SUCCESS(Status) ((NTSTATUS)(Status) >= 0)
#endif
NTSTATUS EnumContextFunctionProviders()
{
NTSTATUS status;
ULONG uSize = 0;
ULONG uTable = CRYPT_LOCAL;
PCRYPT_CONTEXTS pContexts = NULL;
// Get the contexts for the local machine.
// CNG will allocate the memory for us.
status = BCryptEnumContexts(uTable, &uSize, &pContexts);
if(NT_SUCCESS(status))
{
// Enumerate the context identifiers.
for(ULONG a = 0;
a < pContexts->cContexts;
a++)
{
ULONG uInterface = NCRYPT_SCHANNEL_INTERFACE;
wprintf(L"Context functions for %s:\n",
pContexts->rgpszContexts[a]);
// Get the functions for this context.
// CNG will allocate the memory for us.
PCRYPT_CONTEXT_FUNCTIONS pContextFunctions = NULL;
status = BCryptEnumContextFunctions(
uTable,
pContexts->rgpszContexts[a],
uInterface,
&uSize,
&pContextFunctions);
if(NT_SUCCESS(status))
{
// Enumerate the functions.
for(ULONG b = 0;
b < pContextFunctions->cFunctions;
b++)
{
wprintf(L"\tFunction providers for %s:\n",
pContextFunctions->rgpszFunctions[b]);
// Get the providers for this function.
PCRYPT_CONTEXT_FUNCTION_PROVIDERS pProviders;
pProviders = NULL;
status = BCryptEnumContextFunctionProviders(
uTable,
pContexts->rgpszContexts[a],
uInterface,
pContextFunctions->rgpszFunctions[b],
&uSize,
&pProviders);
if(NT_SUCCESS(status))
{
for(ULONG c = 0;
c < pProviders->cProviders;
c++)
{
wprintf(L"\t\t%s\n",
pProviders->rgpszProviders[c]);
}
}
else if(STATUS_NOT_FOUND == status)
{
wprintf(L"\t\tNone found.\n");
}
}
// Free the context functions buffer.
BCryptFreeBuffer(pContextFunctions);
}
}
// Free the contexts buffer.
BCryptFreeBuffer(pContexts);
}
return status;
}
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows Vista [데스크톱 앱만 해당] |
지원되는 최소 서버 | Windows Server 2008 [데스크톱 앱만 해당] |
대상 플랫폼 | Windows |
헤더 | bcrypt.h |
라이브러리 | Bcrypt.lib |
DLL | Bcrypt.dll |