WCF sobre HTTPS y firma del cuerpo.

Tengo un servicio SOAP al que quiero conectarme. Debe accederse a través de https y debe tener su cuerpo firmado por un certificado.

He probado el siguiente código:

<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>

Configurar mi cliente de la siguiente manera:

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");

Incluso cambié mi Reference.cs para incluir elProtectionLevel=ProtectionLevel.Sign en ServiceContractAttribute y OperationContractAttribute.

Lo que sucede es que se crea el encabezado wse: security, pero el cuerpo no se está firmando. El servicio devuelveElement http://schemas.xmlsoap.org/soap/envelope/Body must be signed.

¿Qué me falta para que el cuerpo se firme correctamente?

Respuestas a la pregunta(1)

Su respuesta a la pregunta