Share via


bCryptQueryContextConfiguration 函式 (bcrypt.h)

[BCryptQueryContextConfiguration 可用於需求一節中指定的操作系統。 後續版本可能會變更或無法使用。]

BCryptQueryContextConfiguration 函式會擷取指定 CNG 內容的目前組態。

語法

NTSTATUS BCryptQueryContextConfiguration(
  [in]      ULONG                 dwTable,
  [in]      LPCWSTR               pszContext,
  [in, out] ULONG                 *pcbBuffer,
  [in, out] PCRYPT_CONTEXT_CONFIG *ppBuffer
);

參數

[in] dwTable

識別內容存在於中的組態數據表。 這可以是下列其中一個值。

意義
CRYPT_LOCAL
內容存在於本機計算機組態數據表中。
CRYPT_DOMAIN
這個值無法使用。

[in] pszContext

Null 終止 Unicode 字串的指標,其中包含要取得組態資訊的內容識別碼。

[in, out] pcbBuffer

在專案上, ULONG 變數的位址包含 ppBuffer 所指向緩衝區的大小,以位元組為單位。 如果這個大小不夠大,無法保存內容資訊,此函式將會因為 STATUS_BUFFER_TOO_SMALL而失敗。

在此函式傳回之後,此變數會包含複製到 ppBuffer 緩衝區的位元組數目。

[in, out] ppBuffer

接收此函式所擷取之內容組態資訊的 CRYPT_CONTEXT_CONFIG 結構的指標位址。 由參數所指向的值包含這個緩衝區的大小。

如果此參數所指向的值是 NULL,此函式會配置所需的記憶體。 當不再需要此記憶體時,必須將此指標傳遞至 BCryptFreeBuffer 函 式來釋放。

如果此參數為 NULL,則此函式會將所需的大小,以位元組為單位,放在 由STATUS_BUFFER_TOO_SMALL參數 所指向的變數中,並傳回 STATUS_BUFFER_TOO_SMALL

如需此參數使用方式的詳細資訊,請參閱。

傳回值

傳回狀態代碼,指出函式的成功或失敗。

可能的傳回碼包括但不限於下列專案。

傳回碼 Description
STATUS_SUCCESS
函式成功。
STATUS_BUFFER_TOO_SMALL
ppBuffer 參數不是 NULL而由其所指向的值不夠大,無法保存一組內容。
STATUS_INVALID_PARAMETER
一或多個參數無效。
STATUS_NO_MEMORY
發生記憶體配置失敗。
STATUS_NOT_FOUND
找不到指定的內容。

備註

每個內容只有一組組態資訊,因此雖然 ppBuffer 參數似乎做為數位使用,但此函式會將此視為只有一個元素的數位。 下列範例有助於釐清此參數的使用方式。

// Get the configuration information for the context.
CRYPT_CONTEXT_CONFIG config;
ULONG uSize = sizeof(config);
PCRYPT_CONTEXT_CONFIG pConfig = &config;
status = BCryptQueryContextConfiguration(
    CRYPT_LOCAL, 
    pszContextID, 
    &uSize, 
    &pConfig);

BCryptQueryContextConfiguration 只能在使用者模式中呼叫。

規格需求

需求
最低支援的用戶端 Windows Vista [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2008 [僅限傳統型應用程式]
目標平台 Windows
標頭 bcrypt.h
程式庫 Bcrypt.lib
Dll Bcrypt.dll