我有一个使用BasicHttpBinding和Windows身份验证的WCF服务。 大多数客户端都是域帐户,并使用其默认凭证连接到该服务。如何在WCF客户端配置文件中指定Windows凭据
现在我想连接到本地帐户下运行的ASP.NET客户端的服务。我想使用ASP.NET应用程序可用的Windows凭据(域\用户名和密码)连接到WCF服务。
我知道我可以在代码中使用ClientBase < T> .ClientCredentials来做到这一点。
有没有办法在客户端的web.config文件中指定凭证(域\用户和密码),所以我不必更改代码?
编辑
如果它不能在配置文件中进行,有没有使用System.Net.ICredentials或System.Net.NetworkCredential作为一个WCF服务凭证的方式吗?
.NET框架提供了这些提供网络凭证的同源方式,但对于WCF,似乎已经抛弃了基于不相关的System.ServiceModel.Description.ClientCredentials类的新的不兼容系统。
EDIT 2
接受马克的回答原来的问题 - 这似乎是没有办法的客户端配置文件:(
我会认为这是在WCF缺乏在这样做 - 我不认为微软应该故意阻止我们把证书放在配置文件中 - 毕竟他们必须存储在某个地方,并且Framework包含了用于加密配置文件的工具。我想我可以为此创建一个自定义的BehaviorExtensionElement ,但它应该是开箱即用的。
这也有点不一致:system.net/mailSettings/smtp/network配置元素允许指定凭据,那么为什么不使用WCF呢?
关于如何使用System.Net.NetworkCredential第二个问题,从this blog,这是可能的,使用至少在Windows身份验证,用下面的代码看起来:
factory.Credentials.Windows.ClientCredential =
new System.Net.NetworkCredential(name, password, domain);
“......在你的配置文件,以纯文本”是不是一般的好东西,但在加密的配置文件就可以了。 – Joe 2009-06-04 17:02:28
@marc_s它是否仍然无法通过配置文件进行设置? – 2013-02-28 11:31:08
@Johnny_D:不会,据我所知。 – 2013-02-28 12:39:23