Tout à fait une vieille question, mais puisqu'il apparaît d'abord lorsque googler « authentification SOAPpy » - Je vais laisser mes résultats alors peut-être vous avez gagné Pas besoin de te cogner la tête pendant 10 heures. Redonner à la communauté.
recherche sur Google ne fournit pas beaucoup d'aide, mais cet exemple ici (http://code.activestate.com/recipes/444758-how-to-add-cookiesheaders-to-soappy-calls/) m'a fait écrire mon propre aide (version 0.0 beta)
from SOAPpy import (
WSDL,
HTTPTransport,
Config,
SOAPAddress,
)
import urllib2
import base64
class AuthenticatedTransport(HTTPTransport):
_username = None
_password = None
def call(self, addr, data, namespace, soapaction = None, encoding = None, http_proxy = None, config = Config, timeout = 10):
if not isinstance(addr, SOAPAddress):
addr = SOAPAddress(addr, config)
t = 'text/xml';
if encoding != None:
t += '; charset="%s"' % encoding
encoded_auth = None
if (isinstance(AuthenticatedTransport._username, str) != False):
if (isinstance(AuthenticatedTransport._password, str) == False):
AuthenticatedTransport._password = ""
encoded_auth = base64.b64encode('%s:%s' % (self._username, self._password))
this_request = None
if (encoded_auth is not None):
this_request = urllib2.Request(
url=address.proto + "://" + address.host + address.path,
data=data,
headers={
"Content-Type":content_type,
"SOAPAction":"%s" % soapaction,
"Authorization":"Basic %s" % encoded_auth
}
)
else:
this_request = urllib2.Request(
url=address.proto + "://" + address.host + address.path,
data=data,
headers={
"Content-Type":content_type,
"SOAPAction":"%s" % soapaction,
}
)
response = urllib2.urlopen(this_request)
data = response.read()
# get the new namespace
if namespace is None:
new_ns = None
else:
new_ns = self.getNS(namespace, data)
# return response payload
return data, new_ns
WSDL.Config.strictNamespaces = 0
username = "your_username"
password = "your_password"
WSDLFile = "https://%s:%[email protected]_host/your_wsdl.php?wsdl" % (username, password)
namespace = "http://futureware.biz/mantisconnect"
proxy = WSDL.Proxy(WSDLFile, namespace=namespace, transport = AuthenticatedTransport(username,password))
print(proxy.mc_get_version()) # This is my WSDL call, your will be different
Quelle qu'en soit la raison, il ne suffit pas d'utiliser la classe AuthenticatedTransport, le WSDL L'URL elle-même doit également contenir le nom d'utilisateur et le mot de passe. Peut-être que c'est parce que l'encapsuleur SOAP appelé par WSDL ici crée une session HTTP séparée (souvenez-vous de l'avoir lu sur la liste de diffusion SOAPpy).
Espérons que cela aide quelqu'un.
SOAPpy est déconseillé en faveur de [suds] (https://fedorahosted.org/suds/) - J'ai utilisé de la mousse avec succès, consultez leurs exemples. – Monkpit
@Monkey Merci, il y a une différence incroyable entre ces deux - c'est beaucoup plus facile. – erhesto
@Monkpit et @orhesto - suds semble être abandonné, SOAPpy bien que beaucoup plus «frais» que de mousse ... – Greg0ry