我有一个安全的 METRO 2.1 Web 服务,我想开发一个可以使用它的 .NET (3.5) 客户端。如果 WS 不安全,我已经成功了,但是一旦我得到
安全机制是Username Authentication with Symmetric Key
并且它正在使用Development Defaults
如何在 .NET 中设置安全性?我一直在阅读 METRO 指南,但我只发现示例的链接断开,并且指南没有让我通过。我用 成功生成了一个代理类svcutil
,但我不知道如何使用它。
svcutil 警告:
警告 1 自定义工具警告:已为端点导入安全策略。安全策略包含无法在 Windows Communication Foundation 配置中表示的要求。在生成的配置文件中查找有关 SecurityBindingElement 参数的注释。使用代码创建正确的绑定元素。配置文件中的绑定配置不安全。
警告 2 自定义工具警告:wsam:Addressing 元素需要 wsp:Policy 子元素,但没有子元素。
编辑
我已经非常接近解决这个问题(我认为)。我导出了默认的 GlassFish 证书keytool.exe
:
keytool -exportcert -alias xws-security-server -storepass changeit -keystore keystore.jks -file server.cer
keytool -printcert -file server.cer //This line shows it's content
我server.cer
在客户端使用证书:
KDTreeWSClient wsClient = new KDTreeWSClient();
X509Certificate2 server_cert = new X509Certificate2("FullPathToCertificate/server.cer", "changeit");
wsClient.ClientCredentials.ServiceCertificate.DefaultCertificate = server_cert;
wsClient.ClientCredentials.UserName.UserName = "wsitUser"; //Default GF username
wsClient.ClientCredentials.UserName.Password = "changeit"; //Default GF password
问题这会导致MessageSecurityException
,因为端点的预期 DNS 身份是localhost
,但是端点具有xwssecurityserver
。我可以将其设置为localhost
/xwssecurityserver
手动吗?
任何帮助,将不胜感激!在此先感谢,丹尼尔