我正在尝试使用 Zeep 来实现 SOAP 客户端,因为它似乎是目前唯一维护的库:
- ZSI 看起来很不错,但它在 pypi 上的最新版本是 2006 年
- suds 似乎是一个流行的替代品,但 master 自 2011 年以来就没有维护过,那里有很多分支,但似乎没有一个足够“官方”和“最新”以用于大型项目。
因此,在尝试使用 Zeep 时,我遇到了服务器访问 WSDL 所需的身份验证问题。
使用 ZSI 这样的操作非常简单:
from ZSI.client import Binding
from ZSI.auth import AUTH
b = Binding(url='http://mysite.dom/services/MyWebServices?WSDL')
b.SetAuth(AUTH.httpbasic, 'userid', 'password')
我可以在 Zeep 的 __main__.py 中找到类似的东西:
from six.moves.urllib.parse import urlparse
from zeep.cache import InMemoryCache, SqliteCache
from zeep.client import Client
from zeep.transports import Transport
cache = SqliteCache() if args.cache else InMemoryCache()
transport_kwargs = {'cache': cache}
result = urlparse(args.wsdl_file)
if result.username or result.password:
transport_kwargs['http_auth'] = (result.username, result.password)
transport = Transport(**transport_kwargs)
client = Client(args.wsdl_file, transport=transport)
但这对我来说不起作用,我得到一个错误:
Exception: HTTPConnectionPool(host='schemas.xmlsoap.org', port=80): Max retries exceeded with url: /soap/encoding/ (Caused by NewConnectionError('<requests.packages.urllib3.connection.HTTPConnection object at 0x7f3dab9d30b8>: Failed to establish a new connection: [Errno 110] Connection timed out',))
最佳答案
可能对于较新版本的 zeep,旧的解决方案不再有效。 Here is the new way :
from requests.auth import HTTPBasicAuth # or HTTPDigestAuth, or OAuth1, etc.
from requests import Session
from zeep import Client
from zeep.transports import Transport
session = Session()
session.auth = HTTPBasicAuth(user, password)
client = Client('http://my-endpoint.com/production.svc?wsdl',
transport=Transport(session=session))
关于带有 Zeep 的 Python SOAP 客户端 - 身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40173217/