1

これが非常に一般的なシナリオであることはわかっていますが、2 日間検索しても、この問題の解決策は見つかりませんでした。

SSL とクライアント証明書を使用して、WCF サービスとクライアント (Web サイト) を用意しました。

関連するサービス構成セクション:

<system.serviceModel>
    <bindings>
        <basicHttpBinding>
            <binding name="HOLBinding">
                <security mode="Transport">
                    <transport clientCredentialType="Certificate" />
                </security>
            </binding>
        </basicHttpBinding>
    </bindings>
    <behaviors>
      <serviceBehaviors>
        <behavior name="HOLServiceBehaviour">
          <serviceCredentials>
            <clientCertificate>
        <authentication certificateValidationMode="PeerOrChainTrust" trustedStoreLocation="LocalMachine" />
        </clientCertificate>
          </serviceCredentials>
          <serviceMetadata httpGetEnabled="false" httpsGetEnabled="false" />
          <serviceDebug includeExceptionDetailInFaults="false" />
        </behavior>
      </serviceBehaviors>
<services>
      <service name="HOL.Core.Service.HOLService" behaviorConfiguration="HOLServiceBehaviour">
        <endpoint address="bh" bindingConfiguration="HOLBinding" binding="basicHttpBinding" contract="HOL.Core.Service.IHOLService" />
        <endpoint address="wb" behaviorConfiguration="WebBehaviour" binding="webHttpBinding" contract="HOL.Core.Service.IHOLService" />
      </service>
    </services>

関連するクライアント サービス構成:

<system.serviceModel>
    <behaviors>
      <endpointBehaviors>
        <behavior name="HOLServiceEndpointBehaviour">
          <clientCredentials>
            <clientCertificate storeLocation="LocalMachine" 
                   findValue="mythumbprint" 
                               x509FindType="FindByThumbprint" storeName="TrustedPeople" />

            <serviceCertificate>
               <authentication certificateValidationMode="PeerOrChainTrust"/>
            </serviceCertificate>
          </clientCredentials>
        </behavior>
      </endpointBehaviors>
    </behaviors>
    <bindings>
      <basicHttpBinding>
        <binding name="BasicHttpBinding_IHOLService" maxBufferPoolSize="20000000" maxReceivedMessageSize="20000000">
            <security mode="Transport">
        <transport clientCredentialType="Certificate" />
         </security>
        </binding>
      </basicHttpBinding>
    </bindings>
    <client>
      <endpoint address="https://www.myhttpsite.co.uk/Service/HOLService.svc/bh" binding="basicHttpBinding" 
                bindingConfiguration="BasicHttpBinding_IHOLService" contract="HOLCoreService.IHOLService" 
                name="BasicHttpBinding_IHOLService" behaviorConfiguration="HOLServiceEndpointBehaviour">
    </endpoint>
    </client>
  </system.serviceModel>

私の証明書は見つかっているので、それは問題ではありません (その問題を修正するのにも 1 日かかりました!)

エラーは、WCF サービスを呼び出しているクライアントが認証のために正しい詳細を送信していないということだと思いますが、なぜですか?

4

0 に答える 0