我已经成功创建了一个无需使用身份验证即可正常工作的WS客户端。使用WSE 3.0添加SOAP:HEADER用户名和密码
但是,服务器(WebSphere)现在需要添加一个ws-security用户名令牌,并且我很难做到这一点。得到的SOAP消息应该是这个样子:
<soapenv:Envelope
xmlns:ns="http://foo.bar/1.0"
xmlns:ns1="http://www.witsml.org/schemas/140"
xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/">
<soapenv:Header>
<wsse:Security soapenv:mustUnderstand="1" xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
<wsse:UsernameToken wsu:Id="UsernameToken-2" xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
<wsse:Username>foo</wsse:Username>
<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">bar</wsse:Password>
<wsse:Nonce EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary">foooooobar==</wsse:Nonce>
<wsu:Created>2010-01-25T13:09:24.860Z</wsu:Created>
</wsse:UsernameToken>
</wsse:Security>
</soapenv:Header>
<soapenv:Body>
<ns:fooBar>...</ns:fooBar>
</soapenv:Body>
我已经下载并安装微软的WSE 3.0 SDK,并在我的Visual Studio 2005项目添加到该DLL的引用。
我现在可以访问Microsoft.Web.Services3。*命名空间,但是我目前很难理解如何继续。
客户端代码已被Web引用自动生成的,所以我只能做的工作较少量将消息发送到服务器未经认证:
WS.FooResultHttpService ws = new WS.FooResultHttpService();
ws.Url = "http://foo.bar.baz";
ws.SendSomething(message);
我刚开始调查使用Microsoft.Web.Services3.Security.Tokens.UsernameTokenManager
,但到目前为止,我还没有能够得到任何东西和运行。
任何提示将不胜感激,因为我似乎无法在网上找到任何好的食谱。
谢谢!
谢谢,这非常有帮助! – csl 2010-01-26 14:44:03
+1非常有用。如果在VS2010上使用WseWsdl3.exe生成代理问题,则通过在注册表中添加条目来解决此问题。在HKEY_LOCAL_MACHINE \ SOFTWARE \ Microsoft \ .NETFramework \中添加名为“sdkInstallRootv2.0”的字符串键值为“C:\ Program Files \ Microsoft SDKs \ Windows \ v6.0A” – Siva 2012-04-02 13:52:13