我无法从WCF客户端连接到第三方WSE 3.0 Web服务。我已经实现了这个知识库文章中指出的自定义绑定类:
http://msdn.microsoft.com/en-us/library/ms734745.aspx
问题似乎与Web服务使用的安全断言有关 - UsernameOverTransport。
当我尝试调用方法时,我得到以下异常:
System.InvalidOperationException:The 'WseHttpBinding'。 '[命名空间]' 绑定的 'MyWebServiceSoap'。 '[命名空间]' 合同配置了一个 需要的身份验证模式 运输水平的完整性和 保密。然而运输 无法提供诚信和 保密..
期待用户名,密码和CN号码。在供应商提供给我们的示例代码中,这些凭据捆绑在Microsoft.Web.Services3.Security.Tokens.UsernameToken中。以下是供应商提供的示例:
MyWebServiceWse proxy = new MyWebServiceWse();
UsernameToken token = new UsernameToken("Username", "password", PasswordOption.SendPlainText);
token.Id = "<supplied CN Number>";
proxy.SetClientCredential(token);
proxy.SetPolicy(new Policy(new UsernameOverTransportAssertion(), new RequireActionHeaderAssertion()));
MyObject mo = proxy.MyMethod();
这适用于安装了WSE 3.0的2.0应用程序。以下是我的WCF客户端代码片段:
EndpointAddress address = new EndpointAddress(new Uri("<web service uri here>"));
WseHttpBinding binding = new WseHttpBinding(); // This is the custom binding I created per the MS KB article
binding.SecurityAssertion = WseSecurityAssertion.UsernameOverTransport;
binding.EstablishSecurityContext = false;
// Not sure about the value of either of these next two
binding.RequireDerivedKeys = true;
binding.MessageProtectionOrder = MessageProtectionOrder.SignBeforeEncrypt;
MembershipServiceSoapClient proxy = new MembershipServiceSoapClient(binding, address);
// This is where I believe the problem lies – I can’t seem to properly setup the security credentials the web service is expecting
proxy.ClientCredentials.UserName.UserName = "username";
proxy.ClientCredentials.UserName.Password = "pwd";
// How do I supply the CN number?
MyObject mo = proxy.MyMethod(); // this throws the exception
我在网上搜索这个问题的答案。一些消息来源让我接近(如MS KB文章),但我似乎无法克服困难。有人可以帮助我吗?
答案 0 :(得分:9)
我在类似情况下使用以下绑定配置获得了成功:
<bindings>
<customBinding>
<binding name="FNCEWS40MTOMBinding">
<security enableUnsecuredResponse="true" authenticationMode="UserNameOverTransport"
allowInsecureTransport="true" messageProtectionOrder="SignBeforeEncrypt">
<secureConversationBootstrap />
</security>
<mtomMessageEncoding messageVersion="Soap12WSAddressingAugust2004"
maxBufferSize="2147483647" />
<httpTransport maxReceivedMessageSize="2147483647" />
</binding>
</customBinding>
</bindings>
希望它也适合你。
答案 1 :(得分:1)
错误消息指的是传输级别安全性,这通常意味着https。
您尚未显示配置文件。但我猜你已经将安全配置为传输(或者需要作为另一种选择的后果)并使用了http而不是https的地址。