代码:
security = Security()
token = UsernameToken('b77a5c561934e089', 'kmfHkNZyn1U/pGAiY3+h0BoHdKI=')
security.tokens.append(token)
client.set_options(wsse=security)我的问题是:当包含UsernameToken时,我会收到这样的报头:
<SOAP-ENV:Header>
<wsse:Security mustUnderstand="true">
<wsse:UsernameToken>
<wsse:Username>b77a5c561934e089</wsse:Username>
<wsse:Password>kmfHkNZyn1U/pGAiY3+h0BoHdKI=</wsse:Password>
</wsse:UsernameToken>
</wsse:Security>
</SOAP-ENV:Header>但我需要的是对web服务的这个需求的响应:
<sp:SignedSupportingTokens xmlns:sp="http://schemas.xmlsoap.org/ws/2005/07/securitypolicy">
<wsp:Policy>
<sp:UsernameToken sp:IncludeToken="http://schemas.xmlsoap.org/ws/2005/07/securitypolicy/IncludeToken/AlwaysToRecipient">
<wsp:Policy>
<sp:WssUsernameToken10 />
</wsp:Policy>
</sp:UsernameToken>
</wsp:Policy>
</sp:SignedSupportingTokens>我怎样才能用肥皂来做到这一点呢?我找遍了整个互联网,但没有找到解决方案。
发布于 2017-05-24 10:46:08
您的代码是SOAP通用解决方案。您的web服务似乎需要自定义响应。
我想你的认证不起作用了吧?
尝试将响应marshall到请求者class中。此plugin允许您修改soap信封。您可以添加自己的属性。
class MyRequesterClass(object):
class _myServiceMarshalled(MessagePlugin):
def marshalled(self, context):
commons.set_service_common_header(context, "yourService")
body = context.envelope.getChild('Body')
service = body.getChild("childWhereYouWantAddYourCustomXML")
service.attributes.append(Attribute("sp:IncludeToken", "http://schemas.xmlsoap.org/ws/2005/07/securitypolicy/IncludeToken/AlwaysToRecipient"))
etc, etchttps://stackoverflow.com/questions/37501371
复制相似问题