[英]WCF Error A SOAP 1.2 message is not valid when sent to a SOAP 1.1 only using wsHttpBinding
我正在尝试使用我无法控制的服务,并且只获得了 WSDL 可以使用。 该服务需要用于身份验证的证书。 我的证书配置很好,当我尝试调用服务时出现错误,如下所示:
响应消息的内容类型 text/xml;charset=UTF-8 与绑定的内容类型不匹配(application/soap+xml; charset=utf-8)。 如果使用自定义编码器,请确保正确实现 IsContentTypeSupported 方法。 响应的前 274 个字节是:“soap:VersionMismatchA SOAP 1.2 消息在发送到 SOAP 1.1 only 端点时无效。”。
我已经尝试过不同的方法,比如使用 customBinding,但我遇到了更多新的错误,并且觉得无论如何都没有得到。 你能帮忙吗?
客户端配置:
<system.serviceModel>
<client>
<endpoint name="IDeliveryServiceImplPort"
address="WebServiceUrl"
binding="wsHttpBinding"
bindingConfiguration="wsHttpBinding"
behaviorConfiguration="wsHttpCertificateBehavior"
contract="IDeliveryService">
<identity>
<dns value="MyIdentity" />
</identity>
</endpoint>
</client>
<bindings>
<wsHttpBinding>
<binding name="wsHttpBinding" closeTimeout="00:01:00" openTimeout="00:01:00"
receiveTimeout="00:10:00" sendTimeout="00:01:00"
bypassProxyOnLocal="false" transactionFlow="false"
hostNameComparisonMode="StrongWildcard"
maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
messageEncoding="Text" textEncoding="utf-8"
useDefaultWebProxy="true" allowCookies="false">
<readerQuotas
maxDepth="32" maxStringContentLength="8192"
maxArrayLength="16384" maxBytesPerRead="4096"
maxNameTableCharCount="16384" />
<reliableSession enabled="false" ordered="true" inactivityTimeout="00:10:00" />
<security mode="Transport">
<message clientCredentialType="Certificate" />
</security>
</binding>
</wsHttpBinding>
<customBinding>
<binding name="WsHttpSoap11" closeTimeout="00:01:00" openTimeout="00:01:00"
receiveTimeout="00:10:00" sendTimeout="00:01:00">
<textMessageEncoding messageVersion="Soap11WSAddressing10" />
<security authenticationMode="MutualCertificate" />
<httpsTransport requireClientCertificate="true" />
</binding>
</customBinding>
</bindings>
<behaviors>
<endpointBehaviors>
<behavior name="wsHttpCertificateBehavior">
<clientCredentials>
<clientCertificate x509FindType="FindBySubjectName" findValue="MyIdentity" storeLocation="LocalMachine" storeName="My" />
<serviceCertificate>
<defaultCertificate x509FindType="FindBySubjectName" findValue="MyIdentity" storeLocation="LocalMachine" storeName="My" />
<authentication certificateValidationMode="PeerOrChainTrust" revocationMode="NoCheck" trustedStoreLocation="LocalMachine" />
</serviceCertificate>
</clientCredentials>
</behavior>
</endpointBehaviors>
</behaviors>
</system.serviceModel>
我已经设法通过调整和试验来解决这个问题。 为了解决,我更改为 basicHttpsBinding 花了我一两天的时间来弄清楚默认传输 clientCredentialType 是 None 并且您需要配置一个自定义绑定,如下所示。 我希望 WCF 能告诉你原因或解决你遇到的错误,因为这太痛苦了。 从一个错误描述到下一个不间断。
<bindings>
<basicHttpsBinding>
<binding name="SecureHubBinding">
<security>
<transport clientCredentialType="Certificate" />
<message clientCredentialType="Certificate" />
</security>
</binding>
</basicHttpsBinding>
</bindings>
这些配置是通过添加服务引用自动生成的吗? 我们可以使用服务的WSDL文件生成服务端使用的绑定信息,并添加服务引用生成客户端代理class。
另外,如果具有传输安全模式的服务使用证书对客户端进行身份验证,请保证满足以下要求。
如果有什么我可以帮忙的,请随时告诉我。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.