从WCF客户端连接到WSE 3.0 Web服务

时间:2009-08-07 19:52:38

标签: wcf web-services wse

我无法从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文章),但我似乎无法克服困难。有人可以帮助我吗?

2 个答案:

答案 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的地址。