BCryptGetProperty 함수는 CNG 개체의 명명된 속성 값을 검색합니다.
문법
NTSTATUS BCryptGetProperty(
[in] BCRYPT_HANDLE hObject,
[in] LPCWSTR pszProperty,
[out] PUCHAR pbOutput,
[in] ULONG cbOutput,
[out] ULONG *pcbResult,
[in] ULONG dwFlags
);
매개 변수
[in] hObject
속성 값을 가져올 CNG 개체를 나타내는 핸들입니다.
[in] pszProperty
검색할 속성의 이름을 포함하는 null로 끝나는 유니코드 문자열에 대한 포인터입니다. 미리 정의된 암호화 기본 속성 식별자 또는 사용자 지정 속성 식별자 중 하나일 수 있습니다.
[out] pbOutput
속성 값을 받는 버퍼의 주소입니다. cbOutput 매개 변수에는 이 버퍼의 크기가 포함됩니다.
[in] cbOutput
pbOutput 버퍼의 크기(바이트)입니다.
[out] pcbResult
pbOutput 버퍼에 복사된 바이트 수를 받는 ULONG 변수에 대한 포인터입니다.
pbOutput 매개 변수인 경우 이 함수는 NULL
이 매개 변수가 가리키는 위치에 필요한 크기(바이트)를 배치합니다.
[in] dwFlags
이 함수의 동작을 수정하는 플래그 집합입니다. 이 함수에 대한 플래그는 정의되지 않습니다.
ML-KEM의 경우 이 매개 변수를 0으로 설정해야 합니다.
반환 값
함수의 성공 또는 실패를 나타내는 상태 코드를 반환합니다.
가능한 반환 코드는 다음을 포함하지만 제한되지는 않습니다.
반환 코드 | 설명 |
---|---|
STATUS_SUCCESS | 함수가 성공했습니다. |
STATUS_BUFFER_TOO_SMALL | cbOutput 매개 변수로 지정된 버퍼 크기가 속성 값을 보유할 만큼 크지 않습니다. |
STATUS_INVALID_HANDLE | hObject 매개 변수의 핸들이 잘못되었습니다. |
파라미터 값이 잘못되었습니다 | 하나 이상의 매개 변수가 잘못되었습니다. |
STATUS_NOT_SUPPORTED | pszProperty 매개 변수로 지정된 속성은 지원되지 않습니다. |
비고
속성에 필요한 크기를 가져오려면 pbOutput 매개 변수를 전달 NULL
합니다. 이 함수는 pcbResult 매개 변수가 가리키는 값에 필요한 크기(바이트)를 배치합니다.
공급자가 지원하는 프로세서 모드에 따라 BCryptGetProperty 는 사용자 모드 또는 커널 모드에서 호출할 수 있습니다. 커널 모드 호출자는 PASSIVE_LEVELIRQL 또는 DISPATCH_LEVEL IRQL에서 실행할 수 있습니다. 현재 IRQL 수준이 DISPATCH_LEVEL 경우 BCryptGetProperty 함수에 전달된 포인터는 페이지가 없는(또는 잠긴) 메모리를 참조해야 합니다. hObject 매개 변수에 지정된 개체가 핸들인 경우 BCRYPT_PROV_DISPATCH 플래그를 사용하여 열어야 합니다.
BCRYPT_PARAMETER_SET_NAME 속성을 사용하려면 먼저 BCrypt ML-DSA 키에 설정해야 합니다. 해당 데이터는 키 개체에서 검색할 수 있습니다.
커널 모드에서 이 함수를 호출하려면 DDK(드라이버 개발 키트)의 일부인 함수를 사용합니다 Cng.lib
.
Windows Server 2008 및 Windows Vista: 커널 모드에서 이 함수를 호출하려면 .를 사용합니다 Ksecdd.lib
.
요구 사항
요구 사항 | 가치 |
---|---|
지원되는 최소 클라이언트 | Windows Vista [데스크톱 앱 | UWP 앱] |
지원되는 최소 서버 | Windows Server 2008 [데스크톱 앱 | UWP 앱] |
대상 플랫폼 | 윈도우즈 |
헤더 | bcrypt.h |
라이브러리 | Bcrypt.lib |
DLL | Bcrypt.dll |