7

我正在将应用程序从 .net 1.1 升级到 3.5。此应用程序连接到 WCF 服务。以前,Web 服务客户端配置为使用安全令牌,如下所示:

RegistrationWSWse registrationService = new RegistrationWSWse();
Microsoft.Web.Services2.Security.Tokens.UsernameToken token = new Microsoft.Web.Services2.Security.Tokens.UsernameToken("some username", "some password", Microsoft.Web.Services2.Security.Tokens.PasswordOption.SendPlainText );
registrationService.RequestSoapContext.Security.MustUnderstand=false;
registrationService.RequestSoapContext.Security.Tokens.Add(token);

现在,我在 Visual Studio 中向 Web 服务添加了一个新的服务引用,但自动生成的代码没有提供任何设置安全标头的方法,如上所示。

这是需要在配置文件system.serviceModel部分中配置的东西吗?


更新

我没有看到用户名/密码属性的原因是因为我使用的是服务接口,而不是实际的实现类。

我可以通过将实例转换为类型来设置这些东西,如下所示:

((RegistrationWSClient)registrationWs).ChannelFactory.Credentials.UserName.UserName = userName;
((RegistrationWSClient)registrationWs).ChannelFactory.Credentials.UserName.Password = password;

您必须做的另一件重要事情是更新您的客户端 app.config 文件。如果您不这样做,则不会在 SOAP 标头中设置用户名/密码。例子:

<security mode="TransportWithMessageCredential" />
4

1 回答 1

0

查看MSDN 上的这篇文章这篇文章也有一些关于你的问题的好信息。

于 2010-11-08T18:07:07.977 回答