如何在使用SOAP Web服务时在C#中设置密码类型

问题描述 投票:2回答:2

我试图在我的C#控制台应用程序中使用第三方SOAP Web服务。我尝试了两种不同的传递凭证的方式,如下所示。

//Method 1 - passing security credentials
myCardService.Credentials = new System.Net.NetworkCredential("username", 
"password");

//Method 2 - passing security credentials
System.Net.CredentialCache myCredentials = new System.Net.CredentialCache();
NetworkCredential netCred = new NetworkCredential("username", "password");
myCredentials.Add(new Uri(myCardService.Url), "Basic", netCred);
myCardService.Credentials = myCredentials;

在这两种情况下,我都遇到了这个例外:

System.Web.Services.Protocols.SoapHeaderExceptions:SecurityHeader中的错误:提供了无效的安全令牌

当我尝试使用SOAP UI来使用服务时,我也遇到了同样的错误。但是,当我在工具的“属性”窗口中创建WSS-Password Type = PasswordText时,它才起作用。我没有看到任何方法在C#代码中的凭证对象中进行此设置。任何帮助是极大的赞赏。

c# web-services soap-client
2个回答
0
投票

我的理解是,在您定义服务绑定到身份验证类型之后。

binding.Security.Transport.ClientCredentialType = HttpClientCredentialType.Basic;

定义身份验证类型后,您将创建Web服务客户端并执行以下操作:

client.ClientCredentials.Username.Username = networkCredential.Username;
client.ClientCredentials.Password.Password = networkCredential.Password;

这应该是传递这些凭据的适当方式。


0
投票

https://www.microsoft.com/en-us/download/details.aspx?id=14089安装WSE 3.0并将Web引用从System.Web.Services.Protocols.SoapHttpClientProtocol手动更改为Reference.cs文件中的Microsoft.Web.Services3.WebServicesClientProtocol后,问题得以解决。

© www.soinside.com 2019 - 2024. All rights reserved.