次の方法で共有


ICertProperty::SetValueOnCertificate メソッド (certenroll.h)

SetValueOnCertificate メソッドは、プロパティ値を既存の証明書に関連付けます。

構文

HRESULT SetValueOnCertificate(
  [in] VARIANT_BOOL MachineContext,
  [in] EncodingType Encoding,
  [in] BSTR         strCertificate
);

パラメーター

[in] MachineContext

証明書ストアがローカル コンピューター用か現在のユーザー用かを示す VARIANT_BOOL 値。 コンピューター のVARIANT_TRUE とユーザーの VARIANT_FALSE を指定します。

[in] Encoding

strCertificate パラメーターで識別される証明書文字列に適用される Unicode エンコードの種類を指定する EncodingType 列挙値。

[in] strCertificate

DER でエンコードされた証明書を含む BSTR 変数。

Windows 7 および Windows Server 2008 R2 以降では、エンコードされた証明書ではなく、証明書のサムプリントまたはシリアル番号を指定できます。 これにより、関数は適切なローカル ストアで一致する証明書を検索します。 以下の点に注意してください。

  • BSTR は偶数の 16 進数である必要があります。
  • 16 進数のペア間の空白は無視されます。
  • Encoding パラメーターは、XCN_CRYPT_STRING_HEXRAWに設定する必要があります。
  • MachineContext パラメーターは、ユーザーまたはコンピューター ストア、またはその両方を検索するかどうかを決定します。
  • 秘密キーが必要な場合は、個人用ストアと要求ストアのみが検索されます。
  • 秘密キーが必要ない場合は、ルートおよび中間 CA ストアも検索されます。

戻り値

関数が成功した場合、関数は S_OKを返します。

関数が失敗した場合は、エラーを示す HRESULT 値を返します。 有効な値を次の表に示しますが、これ以外にもあります。 一般的なエラー コードの一覧については、「 共通の HRESULT 値」を参照してください。

リターン コード/値 Description
CRYPT_E_NOT_FOUND
証明書が見つかりませんでした。
CRYPT_E_UNEXPECTED_MSG_TYPE
証明書が見つかりましたが、秘密キーを読み込めませんでした。

注釈

InitializeDecode メソッドまたは InitializeFromCertificate メソッドを呼び出して、プロパティ値を作成します。 いずれかのメソッドを呼び出す前に、まず PropertyId プロパティを設定して、初期化するプロパティ値を指定する必要があります。

要件

要件
サポートされている最小のクライアント Windows Vista [デスクトップ アプリのみ]
サポートされている最小のサーバー Windows Server 2008 [デスクトップ アプリのみ]
対象プラットフォーム Windows
ヘッダー certenroll.h
[DLL] CertEnroll.dll

こちらもご覧ください

ICertProperties

ICertProperty