我对SOAP请求和编程一般还是陌生的。我想访问一个需要承载令牌授权才能使用其服务之一的WSDL。
有关致电pyhton -mzeep *WSDL_url*
后要访问的服务的信息:
getInfo(param1: xsd:string, param2: xsd:anySimpleType, param3: xsd:anySimpleType) -> out: ns0:ResponseCurve[]
首先,我收到以下令牌:
import zeep
user = 'my_user'
userpass = 'my_pass'
token = client.service.getAuthToken(user,userpass)
然后,我想请求需要三个参数的服务getInfo:
my_info = client.service.getInfo('param1', 'param2', 'param3')
提供商知道,每次我想访问此服务时都需要令牌,并且在文档中对与身份验证有关的标头说明如下:
授权:承载eyJhbGciOiJIUzI1N [...]
我试图将标头作为dict在_soapheaders
中传递,但不起作用。
我可以通过使用强制请求来访问服务:
def get_response_from_provider(token, param1, param2, param3):
url = "WSDL url"
headers = {'Authorization': 'Bearer ' + token,
'content-type': 'text/xml'}
body = """
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:wsl="uri">
<soapenv:Header/>
<soapenv:Body>
<wsl:getInfo>
<param1>""" + param1 + """</param1>
<param2>""" + param2 + """ </param2>
<param3>""" + param3 + """ </param3>
</wsl:getInfo>
</soapenv:Body>
</soapenv:Envelope>"""
response = requests.post(url, data=body, headers=headers)
print("Info recieved...")
return response
但是我想通过SOAP客户端访问服务。
这是他们在PHP中添加令牌的方式:
$soap->soapClient->_stream_context = stream_context_create([
'http' => [
'header' => sprintf('Authorization: Bearer %s', $authTokenResponse->token)
]
]);
关于如何在Python中将带有令牌的标头添加到客户端请求的任何想法?
我在SOF中看到了很多有关SOAP + Python的文章,但无法解决问题。即使使用Zeep文档,我也无法使其正常工作。
谢谢
答案 0 :(得分:0)
我一直想做类似的事情,事实证明它在文档中,但是有点隐藏,您可以在这里找到它:
https://python-zeep.readthedocs.io/en/master/settings.html#context-manager
简而言之,您可以执行以下操作:
settings = Settings(extra_http_headers={'Authorization': 'Bearer ' + token})
client = zeep.Client(wsdl=url, settings=settings)
答案 1 :(得分:-1)
我不确定为什么接受的答案对我不起作用,但这是我最终做的
import requests
from zeep import Client, Transport
headers = {
"Authorization": "Bearer " + get_token()
}
session = requests.Session()
session.headers.update(headers)
transport = Transport(session=session)
client = Client(wsdl=url, transport=transport)