WCF przez HTTPS i podpisywanie treści
Mam usługę SOAP, z którą chcę się połączyć. Musi być dostępny przez https i musi mieć podpisany certyfikat.
Wypróbowałem następujący kod:
<basicHttpBinding>
<binding name="P4Binding" closeTimeout="00:01:00" openTimeout="00:01:00"
receiveTimeout="00:10:00" sendTimeout="00:01:00" allowCookies="false"
bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard"
maxBufferSize="65536" maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered"
useDefaultWebProxy="true">
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
<security mode="TransportWithMessageCredential">
<transport clientCredentialType="None" proxyCredentialType="None"
realm="" />
<message clientCredentialType="Certificate" algorithmSuite="Default" />
</security>
</binding>
</basicHttpBinding>
Skonfiguruj mojego klienta w następujący sposób:
P4_ServiceReference.P4PortTypeClient client = new P4_ServiceReference.P4PortTypeClient();
client.ClientCredentials.ServiceCertificate.Authentication.CertificateValidationMode = System.ServiceModel.Security.X509CertificateValidationMode.None;
client.ClientCredentials.ServiceCertificate.DefaultCertificate = new X509Certificate2(@"[..].cer");
client.ClientCredentials.ClientCertificate.Certificate = new X509Certificate2(@"[..]", "somepass");
Zmienił nawet moje Reference.cs, aby zawierałProtectionLevel=ProtectionLevel.Sign
na atrybut ServiceContractAttribute i OperationContractAttribute.
Dzieje się tak, że tworzony jest nagłówek bezpieczeństwa wse:, ale treść nie jest podpisywana. Usługa wracaElement http://schemas.xmlsoap.org/soap/envelope/Body must be signed
.
Czego mi brakuje, aby ciało zostało prawidłowo podpisane?