方法 : デジタル署名の暗号化を無効にする

既定では、メッセージは署名され、署名はデジタル暗号化されます。これは、AsymmetricSecurityBindingElement または SymmetricSecurityBindingElement のインスタンスを使用してカスタム バインディングを作成し、いずれかのクラスの MessageProtectionOrder プロパティを MessageProtectionOrder 列挙値に設定することによって制御されます。既定値は SignBeforeEncryptAndEncryptSignature です。このプロセスは、単に署名して暗号化する場合よりも、メッセージ全体のサイズによって最大で 30 パーセントほど長い時間がかかります (メッセージが小さいほどパフォーマンスへの影響は大きくなります)。ただし、署名の暗号化を無効にすると、攻撃者がメッセージの内容を予想できるようになる危険性があります。その理由は、メッセージ内のすべての署名部分のプレーン テキストのハッシュ コードが署名要素に含まれるからです。たとえば、メッセージ本体は既定で暗号化されますが、暗号化されていない署名には、暗号化される前のメッセージ本体のハッシュ コードが含まれます。署名および暗号化された部分に指定できる一連の値が小さい場合、攻撃者にハッシュ値を参照され、内容を推測されてしまうおそれがあります。署名を暗号化すると、このような攻撃は軽減します。

そのため、署名の暗号化を無効にするのは、コンテンツの重要性が低いか、または指定できる一連のコンテンツの値が大きくて非決定性があり、前述の攻撃を軽減するよりもパフォーマンスの向上が重要な場合に限定してください。

Aa738768.note(ja-jp,VS.90).gifメモ :
メッセージ内に暗号化する対象が存在しない場合は、System.ServiceModel.Channels.AsymmetricSecurityBindingElement.MessageProtectionOrder プロパティまたは System.ServiceModel.Channels.SymmetricSecurityBindingElement.MessageProtectionOrder プロパティが SignBeforeEncryptAndEncryptSignature に設定されていても、署名要素は暗号化されません。この動作は、システム指定のバインディングでも発生します。すべてのシステム指定のバインディングには、メッセージを保護する順序が SignBeforeEncryptAndEncryptSignature に設定されています。ただし、WCF が生成する Web サービス記述言語 (WSDL) には、依然として <sp:EncryptSignature> アサーションが含まれます。

デジタル署名を無効にするには

  1. CustomBinding を作成します。詳細な情報については、次のページを参照してください。 「方法 : SecurityBindingElement を使用してカスタム バインディングを作成する」を参照してください。

  2. AsymmetricSecurityBindingElement または SymmetricSecurityBindingElement をバインディング コレクションに追加します。

  3. System.ServiceModel.Channels.AsymmetricSecurityBindingElement.MessageProtectionOrder プロパティを SignBeforeEncrypt に設定するか、または System.ServiceModel.Channels.SymmetricSecurityBindingElement.MessageProtectionOrder プロパティを SignBeforeEncrypt に設定します。

関連項目

その他の技術情報

カスタム バインディングを使用したセキュリティ機能