我在项目中添加了服务参考。
我需要按照以下
来传递安全标头<soapenv:Header>
<oas:Security>
<oas:UsernameToken>
<oas:Username>username</oas:Username>
<oas:Password>!password</oas:Password>
</oas:UsernameToken>
</oas:Security>
我该如何设置。如果您查看我如何设置请求,那么可以以某种方式使用标头进行相同的操作。
安全XSD嵌入到WSDL中。
http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wss-wsssecurity-secext-1.0.xsd
和
http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wss-wsssecurity-utility-1.0.xsd。
按照以下内容填充了对服务操作的请求:
MyWebService.PortTypeClient client = new MyWebService.PortTypeClient();
MyWebService.SecurityHeaderType secHeader = new MyWebService.SecurityHeaderType();
RetrieveOperationRequest detailsRequest = new RetrieveOperationRequest ();
detailsRequest.inputParam1 = "1234";
var result = client.RetrieveOperation(secHeader, detailsRequest);
我如何生成标头零件?
您可以看到我通过安全标头,因为Web服务需要这。
谢谢。
我设法找到了解决方案/解决方案。
这是在web.config文件中设置的。
<client>
<endpoint address="http://localhost:6478/service/1.0"
binding="basicHttpBinding" bindingConfiguration="ServiceEndpointBinding"
contract="TestService.PortType" name="ServiceEndpoint">
<headers>
<ns2:Security xmlns:ns2="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"
xmlns:ns1="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
<ns2:UsernameToken>
<ns2:Username>username</ns2:Username>
<ns2:Password>!password</ns2:Password>
</ns2:UsernameToken>
</ns2:Security>
</headers>
</endpoint>
</client>
不幸的是,我再也找不到该解决方案的来源了。我只是解决这个问题。