다음을 통해 공유


BCryptQueryContextFunctionConfiguration 함수(bcrypt.h)

[BCryptQueryContextFunctionConfiguration 은 요구 사항 섹션에 지정된 운영 체제에서 사용할 수 있습니다. 이후 버전에서는 변경되거나 제공되지 않을 수 있습니다.]

BCryptQueryContextFunctionConfiguration 함수는 기존 CNG 컨텍스트에 대한 암호화 함수 구성 정보를 가져옵니다.

구문

NTSTATUS BCryptQueryContextFunctionConfiguration(
  [in]      ULONG                          dwTable,
  [in]      LPCWSTR                        pszContext,
  [in]      ULONG                          dwInterface,
  [in]      LPCWSTR                        pszFunction,
  [in, out] ULONG                          *pcbBuffer,
  [in, out] PCRYPT_CONTEXT_FUNCTION_CONFIG *ppBuffer
);

매개 변수

[in] dwTable

컨텍스트가 있는 구성 테이블을 식별합니다. 다음 값 중 하나일 수 있습니다.

의미
CRYPT_LOCAL
컨텍스트는 로컬 머신 구성 테이블에 있습니다.
CRYPT_DOMAIN
이 값은 사용할 수 없습니다.

[in] pszContext

함수 구성 정보를 가져올 컨텍스트의 식별자를 포함하는 null로 끝나는 유니코드 문자열에 대한 포인터입니다.

[in] dwInterface

함수 구성 정보를 가져올 암호화 인터페이스를 식별합니다. 다음 값 중 하나일 수 있습니다.

의미
BCRYPT_ASYMMETRIC_ENCRYPTION_INTERFACE
비대칭 암호화 함수 목록에서 함수 구성 정보를 가져옵니다.
BCRYPT_CIPHER_INTERFACE
암호 함수 목록에서 함수 구성 정보를 가져옵니다.
BCRYPT_HASH_INTERFACE
해시 함수 목록에서 함수 구성 정보를 가져옵니다.
BCRYPT_RNG_INTERFACE
난수 생성기 함수 목록에서 함수 구성 정보를 가져옵니다.
BCRYPT_SECRET_AGREEMENT_INTERFACE
비밀 계약 함수 목록에서 함수 구성 정보를 가져옵니다.
BCRYPT_SIGNATURE_INTERFACE
서명 함수 목록에서 함수 구성 정보를 가져옵니다.
NCRYPT_KEY_STORAGE_INTERFACE
키 스토리지 함수 목록에서 함수 구성 정보를 가져옵니다.
NCRYPT_SCHANNEL_INTERFACE
Schannel 함수 목록에서 함수 구성 정보를 가져옵니다.

[in] pszFunction

구성 정보를 가져올 암호화 함수의 식별자를 포함하는 null로 끝나는 유니코드 문자열에 대한 포인터입니다.

[in, out] pcbBuffer

항목에서 ppBuffer가 가리키는 버퍼의 크기(바이트)를 포함하는 ULONG 변수의 주소입니다. 이 크기가 컨텍스트 정보를 보유할 만큼 크지 않으면 이 함수는 STATUS_BUFFER_TOO_SMALL 함께 실패합니다.

이 함수가 반환된 후 이 변수에는 ppBuffer 버퍼에 복사된 바이트 수가 포함됩니다.

[in, out] ppBuffer

이 함수에서 검색한 함수 구성 정보를 수신하는 CRYPT_CONTEXT_FUNCTION_CONFIG 구조체에 대한 포인터의 주소입니다. pcbBuffer 매개 변수가 가리키는 값에는 이 버퍼의 크기가 포함됩니다.

이 매개 변수가 가리키는 값이 NULL이면 이 함수는 필요한 메모리를 할당합니다. 이 포인터를 BCryptFreeBuffer 함수에 전달하여 더 이상 필요하지 않은 경우 이 메모리를 해제해야 합니다.

이 매개 변수가 NULL인 경우 이 함수는 pcbBuffer 매개 변수가 가리키는 변수에 필요한 크기(바이트)를 배치하고 STATUS_BUFFER_TOO_SMALL 반환합니다.

이 매개 변수의 사용에 대한 자세한 내용은 비고를 참조하세요.

반환 값

함수의 성공 또는 실패를 나타내는 상태 코드를 반환합니다.

가능한 반환 코드에는 다음이 포함되지만 이에 국한되지는 않습니다.

반환 코드 설명
STATUS_SUCCESS
함수가 성공했습니다.
STATUS_BUFFER_TOO_SMALL
ppBuffer 매개 변수가 NULL이 아니며 pcbBuffer 매개 변수가 가리키는 값이 컨텍스트 집합을 보유할 만큼 크지 않습니다.
STATUS_INVALID_PARAMETER
하나 이상의 매개 변수가 유효하지 않습니다.
STATUS_NO_MEMORY
메모리 할당 오류가 발생했습니다.
STATUS_NOT_FOUND
지정된 컨텍스트 또는 함수를 찾을 수 없습니다.

설명

각 암호화 함수에는 구성 정보 집합이 하나만 있으므로 ppBuffer 매개 변수가 배열로 사용되는 것처럼 보이지만 이 함수는 이를 하나의 요소만 있는 배열로 처리합니다. 다음 예제에서는 이 매개 변수를 사용하는 방법을 명확히 하는 데 도움이 됩니다.

// Get the function configuration information.
CRYPT_CONTEXT_FUNCTION_CONFIG FuncConfig;
ULONG uSize = sizeof(FuncConfig);
PCRYPT_CONTEXT_FUNCTION_CONFIG pFuncConfig = &FuncConfig;
status = BCryptQueryContextFunctionConfiguration(
    CRYPT_LOCAL, 
    pszContext, 
    NCRYPT_SCHANNEL_INTERFACE,
    pszFunction,
    &uSize, 
    &pFuncConfig);

BCryptQueryContextFunctionConfiguration 은 사용자 모드에서만 호출할 수 있습니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows Vista [데스크톱 앱만 해당]
지원되는 최소 서버 Windows Server 2008 [데스크톱 앱만 해당]
대상 플랫폼 Windows
헤더 bcrypt.h
라이브러리 Bcrypt.lib
DLL Bcrypt.dll

추가 정보

CRYPT_CONTEXT_FUNCTION_CONFIG