IVdsServiceIscsi::SetInitiatorSharedSecret メソッド (vds.h)
[Windows 8とWindows Server 2012以降、仮想ディスク サービス COM インターフェイスは Windows Storage Management API に置き換えられます。
イニシエーターがターゲットを認証するときに相互 CHAP 認証に使用されるイニシエーター CHAP 共有シークレットを設定します。
構文
HRESULT SetInitiatorSharedSecret(
[in] VDS_ISCSI_SHARED_SECRET *pInitiatorSharedSecret,
[in] VDS_OBJECT_ID targetId
);
パラメーター
[in] pInitiatorSharedSecret
共有シークレットを含む VDS_ISCSI_SHARED_SECRET 構造体のアドレス。 pSharedSecret メンバーが NULL で、ulSharedSecretSize が 0 の場合、SetInitiatorSharedSecret メソッドは既存のシークレットをクリアします。 このパラメーターが NULL で、 targetId パラメーターが GUID_NULLされていない場合、 SetInitiatorSharedSecret はイニシエーターとターゲットの間の関連付けをクリアします。
[in] targetId
ターゲットの VDS_OBJECT_ID 。 共有シークレットがターゲット固有でない場合、このパラメーターは GUID_NULL に設定されます。
戻り値
このメソッドは、E_INVALIDARGやE_OUTOFMEMORYなどの標準の HRESULT 値と、 VDS 固有の戻り値を返すことができます。 また、HRESULT_FROM_WIN32 マクロを使用して、変換されたシステム エラー コードを返すこともできます。 エラーは、VDS 自体または使用されている基になる VDS プロバイダー から発生する可能性があります。 可能な戻り値は次のとおりです。
リターン コード/値 | 説明 |
---|---|
|
共有シークレットが正常に設定されました。 |
|
VDS の初期化に失敗しました。 サービスの初期化が完了する前にアプリケーションがこのメソッドを呼び出すと、初期化が完了するまでメソッドはブロックされます。 初期化が失敗した場合、このエラーが返されます。 |
|
イニシエーター サービスでは、ターゲット固有の共有シークレットの設定はサポートされていません。 |
解説
イニシエーターは、ターゲットごとに異なる CHAP 共有シークレットの設定をサポートできます。
イニシエーターがターゲット固有のシークレットをサポートしているかどうかをプログラムで判断する方法はありません。 SetInitiatorSharedSecret の呼び出しがVDS_E_TARGET_SPECIFIC_NOT_SUPPORTEDを返す場合は、もう一度 メソッドを呼び出し、targetId パラメーターを GUID_NULL に設定します。
Microsoft iSCSI ソフトウェア イニシエーターでは、ターゲット固有のシークレットの設定はサポートされていません。
要件
サポートされている最小のクライアント | Windows Vista [デスクトップ アプリのみ] |
サポートされている最小のサーバー | Windows Server 2003 R2 [デスクトップ アプリのみ] |
対象プラットフォーム | Windows |
ヘッダー | vds.h |
Library | Uuid.lib |
再頒布可能パッケージ | VDS 1.1 |
関連項目
IVdsIscsiTarget::RememberInitiatorSharedSecret
IVdsIscsiTarget::SetSharedSecret