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
識別內容存在於中的組態數據表。 這可以是下列其中一個值。
值 | 意義 |
---|---|
|
內容存在於本機計算機組態數據表中。 |
|
這個值無法使用。 |
[in] pszContext
Null 終止 Unicode 字串的指標,其中包含要取得函式組態資訊的內容識別符。
[in] dwInterface
識別要為其取得函式組態信息的密碼編譯介面。 這可以是下列其中一個值。
[in] pszFunction
Null 終止 Unicode 字串的指標,其中包含要取得組態信息的密碼編譯函式標識符。
[in, out] pcbBuffer
在專案上, ULONG 變數的位址包含 ppBuffer 所指向緩衝區的大小,以位元組為單位。 如果這個大小不夠大,無法保存內容資訊,此函式將會因為 STATUS_BUFFER_TOO_SMALL而失敗。
在此函式傳回之後,此變數會包含複製到 ppBuffer 緩衝區的位元組數目。
[in, out] ppBuffer
接收此函式所擷取之函式組態資訊 之CRYPT_CONTEXT_FUNCTION_CONFIG 結構的指標位址。 由參數所指向的值包含這個緩衝區的大小。
如果此參數所指向的值是 NULL,此函式會配置所需的記憶體。 當不再需要此記憶體時,必須將此指標傳遞至 BCryptFreeBuffer 函 式來釋放。
如果此參數為 NULL,則此函式會將所需的大小,以位元組為單位,放在 由STATUS_BUFFER_TOO_SMALL參數 所指向的變數中,並傳回 STATUS_BUFFER_TOO_SMALL。
如需此參數使用方式的詳細資訊,請參閱。
傳回值
傳回狀態代碼,指出函式的成功或失敗。
可能的傳回碼包括但不限於下列專案。
傳回碼 | Description |
---|---|
|
函式成功。 |
|
ppBuffer 參數不是 NULL,而由其所指向的值不夠大,無法保存一組內容。 |
|
一或多個參數無效。 |
|
發生記憶體配置失敗。 |
|
找不到指定的內容或函式。 |
備註
每個密碼編譯函式只有一組組態資訊,因此雖然 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 |