PFN_CMSG_EXPORT_KEY_TRANS コールバック関数 (wincrypt.h)
PFN_CMSG_EXPORT_KEY_TRANSコールバック関数は、エンベロープされたメッセージのキー トランスポート受信者のコンテンツ暗号化キーを暗号化してエクスポートします。 PFN_CMSG_EXPORT_KEY_TRANS は、 CryptoAPIオブジェクト識別子 (OID) を使用してインストールできます。 この関数は、dwMsgType パラメーターが CMSG_ENVELOPED に設定されている場合に、CryptMsgOpenToEncode 関数によって呼び出されます。
構文
PFN_CMSG_EXPORT_KEY_TRANS PfnCmsgExportKeyTrans;
BOOL PfnCmsgExportKeyTrans(
[in] PCMSG_CONTENT_ENCRYPT_INFO pContentEncryptInfo,
[in] PCMSG_KEY_TRANS_RECIPIENT_ENCODE_INFO pKeyTransEncodeInfo,
[in, out] PCMSG_KEY_TRANS_ENCRYPT_INFO pKeyTransEncryptInfo,
[in] DWORD dwFlags,
void *pvReserved
)
{...}
パラメーター
[in] pContentEncryptInfo
コンテンツ暗号化キーを含む CMSG_CONTENT_ENCRYPT_INFO 構造体へのポインター。
[in] pKeyTransEncodeInfo
コンテンツ暗号化キーの暗号化に使用される受信者公開キーを指定する CMSG_KEY_TRANS_RECIPIENT_ENCODE_INFO 構造体へのポインター。
[in, out] pKeyTransEncryptInfo
暗号化されたコンテンツ暗号化キーを含む CMSG_KEY_TRANS_ENCRYPT_INFO 構造体へのポインター。
[in] dwFlags
この値は使用されません。 0 に設定します。
pvReserved
この値は予約されています。 これを NULL に設定します。
戻り値
関数が成功した場合、戻り値は 0 以外 (TRUE) になります。
関数が失敗した場合、戻り値は 0 (FALSE) になります。 拡張エラー情報については、 GetLastError を呼び出します。
注釈
PFN_CMSG_EXPORT_KEY_TRANS関数は、pKeyTransEncryptInfo パラメーターが指すCMSG_KEY_TRANS_ENCRYPT_INFO構造体の EncryptedKey メンバーを更新する必要があります。 この関数は、pContentEncryptInfo パラメーターが指すCMSG_CONTENT_ENCRYPT_INFO構造体の pfnAlloc および pfnFree メンバーを使用して、暗号化されたキーのメモリ割り当てを管理する必要があります。
OID サポート関数を使用して、このコールバック関数を展開できます。 Wincrypt.h では、この目的のために次の定数を定義します。
CAPI1 キーと Cryptography API: Next Generation (CNG) キーには、さまざまなコールバック関数を定義する必要があります。 どちらの関数も同じシグネチャを持ちますが、OID は異なります。 呼び出される関数は、pContentEncryptInfo パラメーターが指すCMSG_CONTENT_ENCRYPT_INFO構造体の fCNG メンバーの値によって異なります。 次の表は、コールバック関数と fCNG メンバーの値の関係を示しています。
fCNG 値 | 常時 | 定義 |
---|---|---|
FALSE | CMSG_OID_EXPORT_KEY_TRANS_FUNCまたはCMSG_OID_CAPI1_EXPORT_KEY_TRANS_FUNC | "CryptMsgDllExportKeyTrans" |
TRUE | CMSG_OID_CNG_EXPORT_KEY_TRANS_FUNC | "CryptMsgDllCNGExportKeyTrans" |
要件
要件 | 値 |
---|---|
サポートされている最小のクライアント | Windows XP (デスクトップ アプリのみ) |
サポートされている最小のサーバー | Windows Server 2003 (デスクトップ アプリのみ) |
対象プラットフォーム | Windows |
ヘッダー | wincrypt.h |
フィードバック
https://aka.ms/ContentUserFeedback」を参照してください。
以下は間もなく提供いたします。2024 年を通じて、コンテンツのフィードバック メカニズムとして GitHub の issue を段階的に廃止し、新しいフィードバック システムに置き換えます。 詳細については、「フィードバックの送信と表示