我已经成功创建了一个 WS 客户端,该客户端在不使用身份验证时可以正常工作。
但是,服务器(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>
我已经下载并安装了 Microsoft 的 WSE 3.0 SDK,并在我的 Visual Studio 2005 项目中添加了对该 DLL 的引用。
我现在可以访问 Microsoft.Web.Services3.* 命名空间,但目前我不知道如何继续。
客户端代码是通过网络引用自动生成的,因此我只需做少量工作即可将消息发送到服务器未经验证的:
WS.FooResultHttpService ws = new WS.FooResultHttpService();
ws.Url = "http://foo.bar.baz";
ws.SendSomething(message);
我刚刚开始调查使用Microsoft.Web.Services3.Security.Tokens.UsernameTokenManager
,但到目前为止我还没有能够启动并运行任何东西。
任何提示将不胜感激,因为我似乎无法在网上找到任何好的食谱。
Thanks!
确保你的代理类继承自Microsoft.Web.Services3.WebServicesClientProtocol
.
您可以通过更改代理类本身或通过命令行生成它来完成此操作wsewsdl3.exe http://msdn.microsoft.com/en-us/library/aa529578.aspx与/type:webClient
转变。
然后您可以像这样传递凭据:
using Microsoft.Web.Services3;
using Microsoft.Web.Services3.Security.Tokens;
using Microsoft.Web.Services3.Security;
.
.
.
WS.FooResultHttpService ws = new WS.FooResultHttpService();
ws.RequestSoapContext.Security.Tokens.Add(new UsernameToken("blah", "blah", PasswordOption.SendPlainText));
这就是我过去为让 WSE3.0 在 Studio 2008 中运行而所做的事情。希望有所帮助。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)